事件分发,View坐标相关

原创 2017年07月02日 20:15:04

1.在 dispatchTouchEvent(MotionEvent ev),onTouchEvent(MotionEvent event)中ev.getX(),ev.getY()得到的是当天触摸位置相对于控件自己左边,顶部距离。ev.getRawX(),ev.getRawY()获取的是触摸位置相对于屏幕最左边和最顶部的距离。
2。view.getX,view.getLeft,view.getTop,view.getTranslationX区别:

这里写图片描述

a.view.getTranslationX计算的是该view的偏移量。初始值为0,向左偏移值为负,向右偏移值为正。一般是发生了位移动画产生的。
b.view.getX相当于该view距离父容器左边缘的距离,等于getLeft+getTranslationX。
c.view.getMeasuredWidth是onmeasure之后的宽度,view.getWidth是onmeasure,onlayout之后最终显示的宽度,一般情况下两个值相等,但是如果重写了onlayout方法,里面的尺寸发生变化则最终显示的view.getWidth与view.getMeasuredWidth不等。
3.还有一点要区别的是scrollTo,scrollBy是滑动当前整个View的画布,看上去似乎是内容变了,但说scrollTo,scrollBy是滑动的类容是不对的。比如自定义ProInnerRelativeLayout里面有一个TextView,在ProInnerRelativeLayout的
float startX, startY;

@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
    switch (ev.getAction()) {
        case MotionEvent.ACTION_DOWN:
            Log.d(TAG, "ACTION_DOWN");
            startX = ev.getX();
            startY = ev.getY();
            break;
        case MotionEvent.ACTION_MOVE:
            Log.d(TAG, "ACTION_MOVE");

            float dx = ev.getX() - startX;
            float dy = ev.getY() - startY;
            **scrollBy(-(int)dx,-(int)dy);**
            startX = ev.getX();
            startY = ev.getY();
            break;
        case MotionEvent.ACTION_UP:
            Log.d(TAG, "ACTION_UP");
            break;
        case MotionEvent.ACTION_OUTSIDE:
            Log.d(TAG, "ACTION_OUTSIDE");
            break;
        case MotionEvent.ACTION_CANCEL:
            Log.d(TAG, "ACTION_CANCEL");
            break;
    }
    return super.dispatchTouchEvent(ev);
}

其中 scrollBy(-(int)dx,-(int)dy);是对整个ProInnerRelativeLayout的画布进行移动,而ProInnerRelativeLayout本身显示的View大小位置均不会变化,而在视觉效果上好像是在移动里面的TextView。
所以ProInnerRelativeLayout本身的大小还是移动之前那么大,相对于外边父布局的坐标位置关系均不变,里面TextView的坐标关系均不变,即假如从写TextView的方法打印log:
float startX,startY;
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
Log.d(TAG, “ACTION_DOWN”);
startX = ev.getX();
startY = ev.getY();
break;
case MotionEvent.ACTION_MOVE:
Log.d(TAG, “ACTION_MOVE”);
Log.d(TAG, “dispatchTouchEvent ACTION_MOVE ,getScrollX:”+getScrollX()+”,getTranslationX:”+getTranslationX()+”,:getLeft”+getLeft()
+”;getX”+getX());
float dx = ev.getX() - startX;
float dy = ev.getY() - startY;

            startX = ev.getX();
            startY = ev.getY();
            break;
        case MotionEvent.ACTION_UP:
            Log.d(TAG, "ACTION_UP");
            break;
        case MotionEvent.ACTION_OUTSIDE:
            Log.d(TAG, "ACTION_OUTSIDE");
            break;
        case MotionEvent.ACTION_CANCEL:
            Log.d(TAG, "ACTION_CANCEL");
            break;
    }
    return super.dispatchTouchEvent(ev);
}

Log的值均和滑动之前一样,即滑动里面的TextView本身的大小还是移动之前那么大,相对于外边ProInnerRelativeLayout布局的坐标位置关系均不变,因为是ProInnerRelativeLayout的画布整体移动,只是你看到的只有显示区域那么大。
通常使用getScrollX,getScrollY获取滑动的值。
4.touch事件引起view运动从以下几点考虑:
a.view.setX,view.setTranslationX引起坐标发生变化
b. LayoutParams params = (LayoutParams) view.getLayoutParams();
params.leftMargin = ?;动态修改margin值
c.scrollTo,scrollBy以及结合Scroller的使用。

相关文章推荐

View相关 Android事件分发机制完全解析,带你从源码的角度彻底理解(上)

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9097463 其实我一直准备写一篇关于Android事件分发机制的文章,从我的...

坐标相关的 android应用程序中获取view的位置

获取View类界面控件的位置,有助于添加新的控件。 获取在parent里的相对坐标位置     这个比较简单,不用多说,直接调用View的方法:getLeft , getTop...

【Android】View事件分发思维导图

  • 2017年03月09日 16:57
  • 116KB
  • 下载

Android自定义View研究(六)--View中的原点坐标相关问题

我们自定义了View,但是有没想过一个问题,就是View中的(0,0)坐标,也就是原点坐标在哪??我们是不是有时候很困惑,接下来我们就来研究View中的原点坐标相关的问题。   一、new Hel...

view的事件分发机制demo2

  • 2016年02月20日 14:05
  • 402KB
  • 下载

View的事件分发测试例子

  • 2016年02月25日 17:04
  • 5.95MB
  • 下载

Android自定义View研究(六)--View中的原点坐标相关问题

我们自定义了View,但是有没想过一个问题,就是View中的(0,0)坐标,也就是原点坐标在哪??我们是不是有时候很困惑,接下来我们就来研究View中的原点坐标相关的问题。   一、new Hel...

View事件分发

  • 2015年03月30日 16:51
  • 2.21MB
  • 下载

Android View事件分发处理机制Demo

  • 2015年11月13日 22:59
  • 2.66MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:事件分发,View坐标相关
举报原因:
原因补充:

(最多只允许输入30个字)