Lienzo Zoom va al punto (0,0)
Tengo un problema en el zoom del lienzo. He hecho una vista personalizada en la que estoy dibujando diagramas de relación ahora cuando alejo el lienzo en va a la posición (0,0). He visto diferentes hilos y preguntas pero no pude encontrar la respuesta apropiada.
Lo que estoy haciendo en el método onDraw es.
- Canvas.scale (mScaleFactor, mScaleFactor, detector.getFocusX (), detector.getFocusY ()) arrastrando límite de lío?
- Dibujar y hacer zoom sobre ImageView y lienzo en Android
- Wiki sobre android-zoom-view.jar
- Galería de Android: reemplaza el mapa de bits en ImageView después de que el desplazamiento se detuvo
- Cómo configurar Google Maps API v2 para mostrar mapa del mundo entero?
canvas.scale(mScaleFactor, mScaleFactor);
También he visto el método canvas.scale (x, y, px, py) pero no sé cómo obtener los puntos de pivote de xyy.
public boolean onScale(ScaleGestureDetector detector) { mScaleFactor *= detector.getScaleFactor(); // Don't let the object get too small or too large. mScaleFactor = Math.max(0.4f, Math.min(mScaleFactor, 5.0f)); if(mScaleFactor>=1) mScaleFactor=1f; invalidate(); return true;
}
- Implementar pinch Zoom usando ViewPager
- Zoom y arrastrar imágenes usando matriz en android
- En evento de zoom para google maps en android
- ¿Cómo obtener el valor de zoom de la matriz arbitraria?
- Toca dos veces para acercar y pellizcar para hacer zoom en ImageView en android
- Android: no se muestra ImageView con UIL y TouchImageView
- Zoom suave en vista de mapa
- MapController, OSMdroid, zoomToSpan () congela la aplicación
Los puntos de pivote son básicamente el punto que su lienzo será transformado alrededor, por lo que la escala con un pivote de 0,0 hace que encoger hacia ese punto. Utilizando el siguiente método puede cambiar el punto de pivote a donde lo desee:
canvas.scale(x, y, px, py);
Ahora para las cosas nuevas: Si quieres que tu lienzo sea escalado hacia su centro, solo tendrás que saber el punto en medio de tu lienzo:
float cX = canvas.getWidth()/2.0f; //Width/2 gives the horizontal centre float cY = canvas.getHeight()/2.0f; //Height/2 gives the vertical centre
Y luego se puede escalar con esas coordenadas:
canvas.scale(x, y, cX, cY);
Eche un vistazo a estas dos respuestas, que describen el problema y sus soluciones muy bien.
Android Bitmap / Desplazamiento de lienzos después de la escala
Escala de imagen de ImageView mientras mantiene el punto central en el mismo lugar
- Después del cambio de orientación, el menú de opciones del fragmento no desaparece
- Uso de javascript para capturar fotos desde iPhone / Android Cámara