Android中的事件坐标和视图坐标不匹配?

Android中的事件坐标和视图坐标不匹配?,android,events,coordinates,touch,Android,Events,Coordinates,Touch,我一直在尝试编写一个能够识别Android中自定义事件的小应用程序:将手指放在TextView上一段时间,它就会改变颜色。我正在使用MotionEvent坐标并检查它们是否在特定TextView的范围内,该TextView位于表中 private boolean checkBounds(TextView v, MotionEvent event) { int[] origin = new int[2]; v.getLocationOnScreen(origin)

我一直在尝试编写一个能够识别Android中自定义事件的小应用程序:将手指放在TextView上一段时间,它就会改变颜色。我正在使用MotionEvent坐标并检查它们是否在特定TextView的范围内,该TextView位于表中

private boolean checkBounds(TextView v, MotionEvent event) {

        int[] origin = new int[2];
        v.getLocationOnScreen(origin);

        if ((event.getX() > origin[0]) && (event.getX() < (origin[0] + v.getMeasuredWidth()))) {
            if ((event.getY() > origin[1]) && (event.getY() < (origin[1] + v.getMeasuredHeight()))) {
                return true;
            }
        }
        return false;
    }
私有布尔校验边界(TextView v,MotionEvent){
int[]原点=新int[2];
v、 getLocationOnScreen(原点);
if((event.getX()>origin[0])&&(event.getX()<(origin[0]+v.getMeasuredWidth()){
if((event.getY()>origin[1])&&(event.getY()<(origin[1]+v.getMeasuredHeight()){
返回true;
}
}
返回false;
}

我只是将onTouch侦听器附加到活动中的表。但是我得到了奇怪的错误:坐标似乎偏离了一个视图(即,如果我触摸下面的视图,上面的视图会做出反应);或者有时候一个会反应,而另一个不会。知道会发生什么吗?

我通常会因为通知栏的大小而发生这种情况。。。。尝试这样做:

private boolean checkBounds(TextView v, MotionEvent event) {
    // here you will have to get a reference of the global view (the View that holds the UI)
    View globalView = ...; // the main view of my activity/application
    DisplayMetrics dm = new DisplayMetrics();
    this.getWindowManager().getDefaultDisplay().getMetrics(dm);
    int topOffset = dm.heightPixels - globalView.getMeasuredHeight();

        int[] origin = new int[2];
        v.getLocationOnScreen(origin);

    final int x = origin[0];
    final int y = origin[1] - topOffset;


        if ((event.getX() > x) && (event.getX() < (x + v.getMeasuredWidth()))) {
            if ((event.getY() > y) && (event.getY() < (y + v.getMeasuredHeight()))) {
                return true;
            }
        }
    return false;
}
私有布尔校验边界(TextView v,MotionEvent){
//在这里,您必须获得全局视图(保存UI的视图)的引用
View globalView=…;//我的活动/应用程序的主视图
DisplayMetrics dm=新的DisplayMetrics();
这个.getWindowManager().getDefaultDisplay().getMetrics(dm);
int topOffset=dm.heightPixels-globalView.getMeasuredHeight();
int[]原点=新int[2];
v、 getLocationOnScreen(原点);
最终整数x=原点[0];
最终int y=原点[1]-拓扑偏移;
如果((event.getX()>x)和(&(event.getX()<(x+v.getMeasuredWidth())){
如果((event.getY()>y)和(&(event.getY()<(y+v.getMeasuredHeight())){
返回true;
}
}
返回false;
}

无论如何。。。我相信有更好的方法来实现你想要的。据我所知,
TextView
s能够发送
OnClik
事件。

I通常是因为通知栏的大小。。。。尝试这样做:

private boolean checkBounds(TextView v, MotionEvent event) {
    // here you will have to get a reference of the global view (the View that holds the UI)
    View globalView = ...; // the main view of my activity/application
    DisplayMetrics dm = new DisplayMetrics();
    this.getWindowManager().getDefaultDisplay().getMetrics(dm);
    int topOffset = dm.heightPixels - globalView.getMeasuredHeight();

        int[] origin = new int[2];
        v.getLocationOnScreen(origin);

    final int x = origin[0];
    final int y = origin[1] - topOffset;


        if ((event.getX() > x) && (event.getX() < (x + v.getMeasuredWidth()))) {
            if ((event.getY() > y) && (event.getY() < (y + v.getMeasuredHeight()))) {
                return true;
            }
        }
    return false;
}
私有布尔校验边界(TextView v,MotionEvent){
//在这里,您必须获得全局视图(保存UI的视图)的引用
View globalView=…;//我的活动/应用程序的主视图
DisplayMetrics dm=新的DisplayMetrics();
这个.getWindowManager().getDefaultDisplay().getMetrics(dm);
int topOffset=dm.heightPixels-globalView.getMeasuredHeight();
int[]原点=新int[2];
v、 getLocationOnScreen(原点);
最终整数x=原点[0];
最终int y=原点[1]-拓扑偏移;
如果((event.getX()>x)和(&(event.getX()<(x+v.getMeasuredWidth())){
如果((event.getY()>y)和(&(event.getY()<(y+v.getMeasuredHeight())){
返回true;
}
}
返回false;
}

无论如何。。。我相信有更好的方法来实现你想要的。据我所知,
TextView
s能够发送
OnClik
事件。

使用getRawX()getRawY()似乎有效。

使用getRawX()getRawY()似乎有效。

谢谢,效果很好!顺便说一句,我使用我自己的事件框架,因为点击不是一个标准的点击(它是一秒钟的保持,以滑动结束)。谢谢你,尼克。谢谢,效果很好!顺便说一句,我使用我自己的事件框架,因为点击不是一个标准的点击(它是一秒钟的保持,以滑动结束)。谢谢,尼克。