当前位置: 首页 > article >正文

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);
    }
}


http://www.kler.cn/a/415294.html

相关文章:

  • 二叉树知识
  • BurpSuite安装教程(详细!!附带下载链接)
  • C++算法练习-day50——538.把二叉树转换为累加树
  • 第7篇 寻找最大数___ARM C语言程序<三>
  • Elasticsearch与NLP的深度融合:文本嵌入与向量搜索实战指南
  • Linux:makefile的使用
  • DIY-Tomcat part 3 实现对动态资源的请求
  • 在shardingsphere执行存储过程
  • 力扣每日一题 单调数组对的数目(dp)
  • 期权懂|期权中的期权到期日引力是什么意思?
  • TextFSM模板太复杂?ntc-templates让一切变得简单!
  • Android studio与JS交互
  • Android Studio 右侧Gradle窗口只有test的task问题解决
  • pytest+allure生成报告显示loading和404
  • 浅谈C#库之DevExpress
  • Rust 组织管理
  • 知识点回顾
  • python的文件操作练习
  • 基于Java Springboot社区助老志愿者服务平台
  • 如何在 GitHub 上下载并切换到仓库的历史版本