3.20MayBeAndroid

invalidate里放着ONDRAW的方法,当调用I时,会自动更新图片

如果上次记录的位置在-1,那么就更新为现在的位置,更新后就不再为-1了,就不再变了

也就是说是保留第一次触碰到的位置

复制代码
public class CustomView extends View {
    private int mLastX, mLastY;
    private boolean isDragging = false;

    public CustomView(Context context) {
        super(context);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        int action = event.getAction();
        int currX = (int) event.getX();
        int currY = (int) event.getY();

        switch (action) {
            case MotionEvent.ACTION_DOWN:
                if (event.getPointerCount() == 1) {
                    isDragging = true;
                }
                mLastX = currX;
                mLastY = currY;
                break;

            case MotionEvent.ACTION_MOVE:
                if (isDragging) {
                    int dx = currX - mLastX;
                    int dy = currY - mLastY;

                    // 拖拽
                    int left = getLeft() + dx;
                    int top = getTop() + dy;
                    int right = getRight() + dx;
                    int bottom = getBottom() + dy;
                    layout(left, top, right, bottom);
                } else {
                    int dx = currX - mLastX;
                    int dy = currY - mLastY;

                    // 拉伸
                    ViewGroup.LayoutParams layoutParams = getLayoutParams();
                    layoutParams.width += dx;
                    layoutParams.height += dy;
                    setLayoutParams(layoutParams);
                }

                mLastX = currX;
                mLastY = currY;
                break;

            case MotionEvent.ACTION_UP:
                isDragging = false;
                break;
        }

        return true;
    }
}

public class CustomView extends View {
    private int mLastX, mLastY;
    private boolean isDragging = false;
    private boolean isScaling = false;
    private float initialDistance;

    public CustomView(Context context) {
        super(context);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        int action = event.getAction();
        int currX = (int) event.getX();
        int currY = (int) event.getY();

        switch (action & MotionEvent.ACTION_MASK) {
            case MotionEvent.ACTION_DOWN:
                if (event.getPointerCount() == 1) {
                    isDragging = true;
                }
                mLastX = currX;
                mLastY = currY;
                break;

            case MotionEvent.ACTION_POINTER_DOWN:
                if (event.getPointerCount() == 2) {
                    isDragging = false;
                    isScaling = true;
                    initialDistance = getDistance(event);
                }
                break;

            case MotionEvent.ACTION_MOVE:
                if (isDragging) {
                    int dx = currX - mLastX;
                    int dy = currY - mLastY;

                    // 拖拽
                    int left = getLeft() + dx;
                    int top = getTop() + dy;
                    int right = getRight() + dx;
                    int bottom = getBottom() + dy;
                    layout(left, top, right, bottom);
                } else if (isScaling) {
                    float currentDistance = getDistance(event);
                    float scale = currentDistance / initialDistance;

                    // 拉伸
                    ViewGroup.LayoutParams layoutParams = getLayoutParams();
                    layoutParams.width *= scale;
                    layoutParams.height *= scale;
                    setLayoutParams(layoutParams);
                }

                break;

            case MotionEvent.ACTION_POINTER_UP:
                if (event.getPointerCount() == 2) {
                    isScaling = false;
                }
                break;

            case MotionEvent.ACTION_UP:
                isDragging = false;
                isScaling = false;
                break;
        }

        return true;
    }

    private float getDistance(MotionEvent event) {
        float dx = event.getX(0) - event.getX(1);
        float dy = event.getY(0) - event.getY(1);
        return (float) Math.sqrt(dx * dx + dy * dy);
    }
}
相关推荐
SimonKing4 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean4 小时前
Jackson View Extension Spring Boot Starter
java·后端
Seven975 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55114 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河15 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程18 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅19 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者20 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺20 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端