图片拖拽,放大,缩小

布局:


 <ImageView
        android:id="@+id/imageView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="matrix"
        android:src="@drawable/i" />


mainactivity:

public class MainActivity extends AppCompatActivity {

    private final int MODE_DRAG = 1;
    private final int MODE_ZOOM = 2;
    private final int MODE_NONE = 0;
    private ImageView imageView;
    private int currentMode = MODE_NONE;
    private double distanceStart;
    private float xl;
    private float yl;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        imageView = (ImageView) findViewById(R.id.imageView);
        initView();
    }

    Matrix matrix = new Matrix();
    Matrix matrixNew = new Matrix();

    private void initView() {
        imageView.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch (event.getAction() & MotionEvent.ACTION_MASK) {
                    case MotionEvent.ACTION_DOWN:
                        currentMode = MODE_DRAG;
                        xl = event.getX();
                        yl = event.getY();
                        matrix.set(imageView.getImageMatrix());
                        break;
                    case MotionEvent.ACTION_POINTER_DOWN:
                        distanceStart = spacing(event);
                        if (distanceStart > 20) {
                            currentMode = MODE_ZOOM;
                            matrix.set(imageView.getImageMatrix());
                        }
                        break;
                    case MotionEvent.ACTION_MOVE:
                        if (currentMode == MODE_DRAG) {
                            matrixNew.set(matrix);
                            float xn = event.getX();
                            float yn = event.getY();
                            //matrix.setTranslate(xn,yn);
                            matrixNew.postTranslate(xn - xl, yn - yl);
                        } else if (currentMode == MODE_ZOOM) {
                            double distance = spacing(event);
                            float scale = (float) (distance / distanceStart);
                            PointF pointF = midPoint(event);
                            matrixNew.postScale(scale, scale, pointF.x, pointF.y);
                        }
                        break;
                    case MotionEvent.ACTION_UP:
                        currentMode = MODE_NONE;
                        break;
                }
                imageView.setImageMatrix(matrixNew);
                return true;
            }
        });
    }

    //计算两点之间的距离
    private double spacing(MotionEvent event) {
        float x = 0;
        float y = 0;
        try {
            x = event.getX(0) - event.getX(1);
            y = event.getY(0) - event.getY(1);
        } catch (IllegalArgumentException e) {
        }
        return Math.sqrt(x * x + y * y);
    }

    public PointF midPoint(MotionEvent event) {
        float x0 = event.getX(0);
        float x1 = event.getX(1);
        float y0 = event.getX(0);
        float y1 = event.getX(1);

        float x = (x0 + x1) / 2;
        float y = (y0 + y1) / 2;

        PointF pointF = new PointF(x, y);
        return pointF;
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值