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);
    }
}
相关推荐
代码雕刻家4 分钟前
3.1.Maven-课程介绍
java·maven
li357410 分钟前
深入理解:MQ监听类 vs Spring事件监听类 —— 区别、用法与适用场景全解析
java·数据库·spring
灵感蛙23 分钟前
《苍穹外卖》项目日记_Day7
java·spring boot·redis
lifallen24 分钟前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
索迪迈科技27 分钟前
java后端工程师进修ing(研一版‖day42)
java·开发语言·学习·算法
半桔32 分钟前
【Linux手册】消息队列从原理到模式:底层逻辑、接口实战与责任链模式的设计艺术
java·linux·运维·服务器
Chris.Yuan7701 小时前
Java代理模式详解
java·开发语言·代理模式
Mr.朱鹏1 小时前
ShardingJDBC实战指南
java·jvm·数据库·spring·分库分表·shardingjdbc·shardingshere
Forever_Hopeful1 小时前
【C 语言生成指定范围随机数(整数 + 小数):原理、实现与避坑指南】
服务器·c语言·开发语言
学习OK呀1 小时前
从 java8 升级 java17 的调整
java·后端