嵌套滑动温习小结

嵌套滑动机制相比传统事件分发在方向、体验和复杂性上有所改进,允许子控件到父控件的方向处理,提供更流畅的体验。开启嵌套滑动的关键在于子View在ACTION_DOWN事件中调用相应方法,并处理剩余滑动距离。实现嵌套滑动不一定需要协调布局和Behavior,自定义View实现NestedScrollingChild或NestedScrollingParent接口即可。在不同版本中,通过不同方式实现接口和方法来支持嵌套滑动。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

NestedScrollingParent:以下简称“NSP”,NestedScrollingChild:以下简称“NSC”,这两个接口是嵌套滑动的精髓,是我们实现嵌套滑动遵守的“规则”。

NOTE:本博文非详细原理篇,原理分析网上资料很多!!

与传统事件分发相比,好在哪?

  • 方向维度

    -  传统事件分发机制

      方向:父控件 -> 子控件,且是一锤子买卖,即事件总是先传递给父控件,父控件不拦截该事件,则该事件才会传递给子控件,一旦父控件拦截了该事件,则子View就没有机会处理该事件了,同一事件序列的事件均由父控件处理。

同一事件序列:从手指按下屏幕的那刻起,到抬起手指,这中间产生的一系列事件:一个ACTION_DOWN、N个ACTION_MOVE、一个ACTION_UP等。

    -  嵌套滑动机制

      方向:子控件 -> 父控件,且不是一锤子买卖,且嵌套滑动由子控件来触发,且在同一事件序列中,父控件和子控件都有机会处理该事件。

  • 体验维度

   注意:传统的事件分发机制一样可以实现嵌套滑动。

    -  传统事件分发机制

       体验相对较差,基于传统事件分发与拦截的特点,实现的嵌套滑动不连贯,比如向上滑动到一定位置之后,如吸顶的位置,如果用户不抬起手指,则页面就不会继续向上滑动了。为啥?因为不抬起手指,产生的事件还是同一事件序列,还是由父View消耗,子View没机会消耗。

    -  嵌套滑动机制

        由于同一事件序列,父子View都有机会参与处理,因此体验较好。至于怎么做到[同一事件序列,父子View都有机会参与]的,本文后面会讲。

  • 复杂维度

       嵌套滑动机制实现嵌套滑动更容易一些,为啥?

       传统事件分发机制需要父控件首先拦截处理滑动事件,当到达比如吸顶位置了,此时滑动事件不再满足父控件的处理要求了,此时子View才有机会处理后面的滑动(此处用户应该抬一把手指,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值