关于getRawX和getX、getMeasureWidth和getWidth之间的区别

以前总是在复写事件点击的时候分不清getRawX和getX获取点击位置的区别,今天提空写个demo,打个log看一下到底有什么区别!!打出来的结果我都开始怀疑我自己了!!
先看一下我的xml文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <camera.android.com.uiposition.TestGroup
        android:background="@color/colorAccent"
        android:layout_alignParentBottom="true"
        android:layout_alignParentEnd="true"
        android:layout_width="80dp"
        android:layout_height="80dp">
        <camera.android.com.uiposition.TextImageView
            android:layout_alignParentBottom="true"
            android:layout_alignParentEnd="true"
            android:background="@color/colorPrimaryDark"
            android:src="@mipmap/ic_launcher"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </camera.android.com.uiposition.TestGroup>
</RelativeLayout>

很简单,没什么好说的!
在看两个自定义View的代码:

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.widget.RelativeLayout;

/**
 * Created by Administrator on 2017/9/10 0010.
 */

public class TestGroup extends RelativeLayout {
    public TestGroup(Context context) {
        super(context);
    }

    public TestGroup(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public TestGroup(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        Log.i("zyq","TestGroup : RawX = "+event.getRawX()+",X = "+event.getX());
        Log.i("zyq","TestGroup : RawY = "+event.getRawY()+",Y = "+event.getY());
        return super.onTouchEvent(event);
    }
}
import android.content.Context;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.support.v7.widget.AppCompatImageView;


/**
 * Created by Administrator on 2017/9/10 0010.
 */

public class TextImageView extends AppCompatImageView {
    public TextImageView(Context context) {
        super(context);
    }

    public TextImageView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public TextImageView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        Log.i("zyq","TextImageView : RawX = "+event.getRawX()+",X = "+event.getX());
        Log.i("zyq","TextImageView : RawY = "+event.getRawY()+",Y = "+event.getY());
        Log.i("zyq","TextImageView : Left = "+getLeft()+",getRight = "+getRight());
        Log.i("zyq","TextImageView : view.getX() = "+getX()+",view.getY() = "+getY());

        return super.onTouchEvent(event);
    }
}

log结果:

09-10 05:39:14.810 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : RawX = 999.8767,X = 63.87671
09-10 05:39:14.810 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : RawY = 1671.7969,Y = 39.796875
09-10 05:39:14.810 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : Left = 96,getRight = 240
09-10 05:39:14.811 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : view.getX() = 96.0,view.getY() = 96.0
09-10 05:39:14.811 6744-6744/camera.android.com.uiposition I/zyq: TestGroup : RawX = 999.8767,X = 159.87671
09-10 05:39:14.811 6744-6744/camera.android.com.uiposition I/zyq: TestGroup : RawY = 1671.7969,Y = 135.79688
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : RawX = 1042.9211,X = 106.92114
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : RawY = 1742.8125,Y = 110.8125
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : Left = 96,getRight = 240
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TextImageView : view.getX() = 96.0,view.getY() = 96.0
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TestGroup : RawX = 1042.9211,X = 202.92114
09-10 05:39:23.888 6744-6744/camera.android.com.uiposition I/zyq: TestGroup : RawY = 1742.8125,Y = 206.8125

根据log结果可以看到:getRow*打印出来是触摸点相对于屏幕左上角的位置,即坐标系的原点是屏幕的左上角

MotionEvent.getX()为当前触摸点相对于当前点击View的左上角的位置!!!

view.getX() 和view.getY()获取的是当前view的左上角相对于其父布局左上角的位置!!

view.getLeft()和view.getRight()获取的都是当前view相对于其父布局的位置!!

关于getMeasureWidth和getWidth在这里就不写demo,打log了,有兴趣的可以自己测试一下!!
getWidth(): View在设定好布局后整个View的宽度。(这个值只有在view的onMeasure方法调用完成之后,才能取到相应的值,一般在onDraw方法中可以打印出来)
getMeasuredWidth(): 对View上的内容进行测量后得到的View内容占据的宽度,前提是你必须在父布局的onLayout()方法或者此View的onDraw()方法里调用measure(0,0);(measure中的参数的值你自己可以定义),否则你得到的结果和getWidth()得到的结果是一样的。

好了,关于这几个长得差不多的函数就说到这里,有兴趣的朋友可以关注我一下,有什么问题大家可以相互交流!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这种情况可以通过在PopupWindow的setOnTouchListener()中监听手势事件,判断手势方向,然后决定是否让RecyclerView或者PopupWindow处理手势事件。 具体实现可以按照以下步骤: 1. 在PopupWindow的构造函数中设置setTouchable(true)和setFocusable(true),使PopupWindow能够响应点击和触摸事件。 2. 在PopupWindow的setOnTouchListener()中监听手势事件,并根据手势方向来判断是否让RecyclerView或者PopupWindow处理手势事件。例如: ``` popupWindow.setOnTouchListener(new View.OnTouchListener() { private float mLastY; @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: mLastY = event.getRawY(); break; case MotionEvent.ACTION_MOVE: float dy = event.getRawY() - mLastY; if (Math.abs(dy) > 10) { // 如果手指上下滑动距离大于10,则拦截事件,让RecyclerView处理滑动事件 recyclerView.onTouchEvent(event); return true; } break; } return false; } }); ``` 3. 在RecyclerView的OnTouchListener()中,判断是否在PopupWindow内部,并根据需要决定是否拦截事件。例如: ``` recyclerView.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { // 判断是否在PopupWindow内部 Rect rect = new Rect(); popupWindow.getContentView().getGlobalVisibleRect(rect); if (!rect.contains((int) event.getRawX(), (int) event.getRawY())) { // 如果不在PopupWindow内部,则让PopupWindow处理手势事件 popupWindow.onTouchEvent(event); return true; } return false; } }); ``` 通过这种方式,可以在PopupWindow中嵌套RecyclerView,并解决它们之间的手势冲突问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值