android-如果子级返回false,则让父级视图承担MotionEvents

android-如果子级返回false,则让父级视图承担MotionEvents,第1张

概述我有一个需要以异常方式处理事件的应用程序.对于我的问题,让我首先说明一个简单的案例,即当前的Android事件处理系统不适合我.假设我有一个FrameLayout(从现在开始我将其称为ViewSwiper),其上添加的所有View均为MATCH_PARENTXMATCH_PARENT(我称为PageView),它通过转换实际View

我有一个需要以异常方式处理事件的应用程序.

对于我的问题,让我首先说明一个简单的案例,即当前的Android事件处理系统不适合我.

假设我有一个FrameLayout(从现在开始我将其称为VIEwSwiper),其上添加的所有VIEw均为MATCH_PARENT X MATCH_PARENT(我称为PageVIEw),它通过转换实际VIEw并根据方向替换它来处理事件的感动.@H_403_5@我已经完成并正常工作了该组件(Using Animation to swipe views).

但是问题在于我在其上添加的PageVIEw上,如果ImageVIEws的ontouchEvent返回false,则VIEwSwiper将处理事件并让另一个PageVIEw进入屏幕,但是如果我在上面添加ScrollVIEw,则所有事件将由Scroll占用,并且VIEwSwiper将没有机会替换PageVIEw.

因此,我发现返回父级的ScrollVIEw的ontouchEvent错误可以假定它是事件,因此我编写了ScrollVIEw的此子类来对其进行测试:

public class ScrollVIEwVertical extends ScrollVIEw {    public ScrollVIEwVertical(Context context) {        super(context);        setoverScrollMode(OVER_SCRolL_ALWAYS);        setVerticalScrollbarEnabled(false);    }    public boolean ontouchEvent(MotionEvent evt) {        super.ontouchEvent(evt);        return false;    }}

但是返回false将使任何其他事件被分派给父级,但是我需要这些事件来进行垂直滚动,因此我有一个想法,只有在用户移动水平方向时才返回false,这就是我的代码:

public class ScrollVIEwVertical extends ScrollVIEw {    private MovementTracker moveTracker;    public ScrollVIEwVertical(Context context) {        super(context);        setoverScrollMode(OVER_SCRolL_ALWAYS);        setVerticalScrollbarEnabled(false);        moveTracker = new MovementTracker();    }    public boolean ontouchEvent(MotionEvent evt) {        if (moveTracker.track(evt))            if (moveTracker.getDirection() == Direction.HORIZONTAL)                return false;        return super.ontouchEvent(evt);    }}

PS:MovealTracker将在发生某些事件后在track()上返回true,并告诉用户移动的方向.

但是在那种情况下,ScrollVIEw会继续接收事件,因为它在第一个事件中返回true.

关于如何在VIEwSwiper的子级返回false时如何处理事件的任何想法(即使返回了某些true).

PS:如果需要,我可以提供更多有关此的信息,也可以接受其他解决方案.

根据答案,我尝试了以下 *** 作:

@OverrIDepublic boolean dispatchtouchEvent(MotionEvent ev) {    ontouchEvent(ev);    return intercept;}public boolean ontouchEvent(MotionEvent evt) {    boolean x = super.ontouchEvent(evt);    if (moveTracker.track(evt)) {        intercept = moveTracker.getDirection() != Direction.VERTICAL;        if (!intercept)            getParent().requestdisallowIntercepttouchEvent(false);    }    return x;}

依然没有.

@R_502_6120@:

在scrollvIEw的ontouchEvent()中尝试一下

     //if (evt.getAction() == MotionEvent.ACTION_MOVE) {    if (moveTracker.track(evt)){       if (moveTracker.getDirection() == Direction.VERTICAL){          //Or the direction you want the scrollvIEw keep moving          getParent().requestdisallowIntercepttouchEvent(true);            }        }  return true;

更新资料

请尝试以下自定义ScrollvIEw

@OverrIDepublic boolean dispatchtouchEvent(MotionEvent ev) {super.dispatchtouchEvent(ev);    return false;}

没别的

这样,我假设MotionEvent将在两个视图上执行.而且由于它们没有冲突(一个是垂直的,另一个是水平的),所以可以工作

总结

以上是内存溢出为你收集整理的android-如果子级返回false,则让父级视图承担MotionEvents全部内容,希望文章能够帮你解决android-如果子级返回false,则让父级视图承担MotionEvents所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1083721.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存