3

Hello Android、3rd Edition for PinchtoZoom機能にあるコードを使用しています。これを使用した後、ピンチによるズームは正常に機能しますが、ズームした後、画像ビューの絶対クリック位置を取得したいと思います。

これが私のコードです

package org.example.touch;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.Matrix;
import android.graphics.PointF;
import android.os.Bundle;
import android.util.FloatMath;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.GridView;
import android.widget.ImageView;

public class Touch extends Activity implements OnTouchListener {
private static final String TAG = "Touch";

private static final float MIN_ZOOM = 1.0f;
private static final float MAX_ZOOM = 5.0f;

// These matrices will be used to move and zoom image
Matrix matrix = new Matrix();
Matrix savedMatrix = new Matrix();

// We can be in one of these 3 states
static final int NONE = 0;
static final int DRAG = 1;
static final int ZOOM = 2;
int mode = NONE;

// Remember some things for zooming
PointF start = new PointF();
PointF mid = new PointF();
float oldDist = 1f;

ImageView image2;
image2 = (ImageView)this.findViewById(R.id.imageView2);
image2.setOnTouchListener(new OnTouchListener() {

                public boolean onTouch(View v, MotionEvent event) {

                     ImageView view = (ImageView) image2;
                      // Handle touch events here...
                        switch (event.getAction() & MotionEvent.ACTION_MASK) {
                        case MotionEvent.ACTION_DOWN:
                            savedMatrix.set(matrix);
                            start.set(event.getX(), event.getY());
                            mode = DRAG;
                            break;
                        case MotionEvent.ACTION_POINTER_DOWN:
                            oldDist = spacing(event);
                            if (oldDist > 10f) {
                                savedMatrix.set(matrix);
                                midPoint(mid, event);
                                mode = ZOOM;
                            }
                            break;
                        case MotionEvent.ACTION_UP:
                        case MotionEvent.ACTION_POINTER_UP:
                            mode = NONE;
                            break;
                        case MotionEvent.ACTION_MOVE:
                            if (mode == DRAG) {
                                matrix.set(savedMatrix);
                                matrix.postTranslate(event.getX() - start.x, event.getY() - start.y);
                            }
                            else if (mode == ZOOM) {
                                float newDist = spacing(event);
                                if (newDist > 10f) {
                                    matrix.set(savedMatrix);
                                    float scale = newDist / oldDist;
                                    matrix.postScale(scale, scale, mid.x, mid.y);
                                }
                            }
                            break;
                        }
                        view.setImageMatrix(matrix);
}

        /** Determine the space between the first two fingers */
        private float spacing(MotionEvent event) {
            float x = event.getX(0) - event.getX(1);
            float y = event.getY(0) - event.getY(1);
            return FloatMath.sqrt(x * x + y * y);
        }

        /** Calculate the mid point of the first two fingers */
        private void midPoint(PointF point, MotionEvent event) {
            float x = event.getX(0) + event.getX(1);
            float y = event.getY(0) + event.getY(1);
            point.set(x / 2, y / 2);
        }
4

2 に答える 2

2

imageview に現在適用されているマトリックスを使用して、元のデフォルト ポイントとの間でポイントをマッピングできます。

//points from a touch/click event on the zoomed/translated imageview
float X;
float Y;

float initialPoints = new float[]{X, Y};

//invert the matrix and map points back
    if(transformMatrix.invert(inverseTransformMatrix))
            inverseTransformMatrix.mapPoints(initialFocalPoints);

initialPoints元のポイントが含まれるようになりました。つまり、マトリックスがイメージビューに適用されなかった場合にクリックポイントがあった場所です。

編集:これをどこかに追加して、それらが何であるかがわかるようにする必要があります。

Matrix inverseTransformMatrix = new Matrix();
Matrix transformMatrix = new Matrix();
于 2013-09-11T15:35:31.660 に答える
0

以下のロジックを適用します

float[] values = new float[9];
matrix.getValues(values);

ピンチズームの前に倍率を計算します。

scaleX=values[0];
scaleY=vales[4];

ピンチズーム後の画像に応じて相対タッチ座標を計算するようになりました

float relativeX = ((event.getX() - values[2])*sacleX) / values[0];
float relativeY = ((event.getY() - values[5])*scaleY) / values[4];
于 2012-11-21T12:41:53.980 に答える