自定义CoordinatorLayout的Behavior实现

Behavior有好多种,有APPBarLayout的Behavior,有FloatingActionButton的Behavior,还有CoordinatorLayout的Behavior

Behavior是什么呢?
打开一下知乎,首页上拉后,actionBar先上滑隐藏,继续上拉,地下的tab栏下滑隐藏,当你停止上拉,而是下拉时,两个都又出现
原谅我不造怎么传动图。。。学会了再来传图。。。。

神奇的Behavior依据类似观察者的模式实现两个或者多个控件的联动联系
需要说明的是,要能实现Behavior的功能,控件的父控件应该是coordinatorLayout,只有他才能传递事件,才能回调注册中的方法

现在说一下CoordinatorLayout的Behavior

我们分为两种:
A:一个View对于另一个View注册的监听

B:一个View对CoordinatorLayout注册的滑动监听

首先来讲一下A:

我们这边主要是通过自定义Behavior的方式来实现,所以先看一下代码

自定义CoordinatorLayout的Behavior实现_第1张图片
CustomBehavior

需要关心的就是两个方法,一个layoutDependsOn,是绑定需要关心的View,这边返回的就是关心的条件,CoordinatorLayout遍历所有的childView,满足条件的就会建立监控关系
另一个方法onDependentViewChanged,就是建立关系的两个Veiw,被监控的发生变化就会回调此方法,此方法三个参数,第二个是跟着变化的Veiw,第三个就是需要监控的View,我们这边做的就是监控的View跟着被监控的一起上下移动

好了,这个Behavior就ok了,现在我们去做一下布局

自定义CoordinatorLayout的Behavior实现_第2张图片
布局。。

在布局里面加一个CoordinatorLayout,然后在里面加两个Button
在监控的button里面添加behavior属性
app:layout_behavior="com.ddstar.customcomponent.CusBehaivor"
然后就做好了监控关系

如果确定依赖监听关系的条件是只要CoordinatorLayout里面的Button发生了变化就会有反应,所以CoordinatorLayout会遍历childView,只要是Button发生移动,“跟屁虫”这个Button就会跟着上下移动

自定义CoordinatorLayout的Behavior实现_第3张图片
注册监听

然后就动了-------------------

接下来说一下B:

自定义CoordinatorLayout的Behavior实现_第4张图片
Scroll的监听

这个稍微复杂一些,我们主要关注的是三个方法

onStartNestedScroll
开始滚动前,设置我们要关心的条件
这边设置的条件是竖直方向的滚动

onNestedScroll
滚动时的状态变化,被监控的控件发生Lee变化,就可以拿到相对应的变化参数进行设置
onNestedFling
此方法是当你滑动屏幕后手离开屏幕,整个页面还是在滑动,此方法就是当此情况发生时回调的方法

所以知道回调方法何时回调,实现起来就容易了
需要注意的是:

要让以上方法能够回调,所关心的能滑动的控件应该实现NestedScrollingChild接口,像一般的ListView/ScrollView是没办法的,所以Recycleview你值得拥有

自定义CoordinatorLayout的Behavior实现_第5张图片
Paste_Image.png

我这边实现的是简单地功能:

底部一个控件,Recycleview上拉时隐藏,下拉又显示
数学不太好,这个方法好久才看懂

那就这样

源码:
https://github.com/DDstar/CoordinatorLayoutBehaviorDemo.git

你可能感兴趣的:(自定义CoordinatorLayout的Behavior实现)