Android: how to detect touch location on ImageView if the image view is scaled by matrix?

13,622

Solution 1

getX and getY will return the touch location in the ImageView's coordinate system. If you're looking for the point within the image's coordinate system, you can use the inverse matrix of the matrix used by the ImageView. I've done something like the following:

// calculate inverse matrix
Matrix inverse = new Matrix();
imageView.getImageMatrix().invert(inverse);

// map touch point from ImageView to image
float[] touchPoint = new float[] {event.getX(), event.getY()};
inverse.mapPoints(touchPoint);
// touchPoint now contains x and y in image's coordinate system

Solution 2

Zorgbargle answer is right but there is another consideration when your loading images from resource folder and that's density of the device.

Android scale images base on the device density so you if you only have the image in mdpi folder, you must also divide the points by the density to find the real point on the image:

float[] point = new float[] {event.getX(), event.getY()};

Matrix inverse = new Matrix();
imageView.getImageMatrix().invert(inverse);
inverse.mapPoints(point);

float density = getResources().getDisplayMetrics().density;
point[0] /= density;
point[1] /= density;
Share:
13,622

Related videos on Youtube

hzxu
Author by

hzxu

Updated on June 01, 2022

Comments

  • hzxu
    hzxu almost 2 years

    I set OnTouchListener of an ImageView and implement onTouch method, but if the image is scaled using matrix, how do I calculate the location of the touch?

    Or does the motion event automatically takes that into account when returning getX() and getY() ?