CoordinatorLayout


title: CoordinatorLayout
date: 2017-04-12 20:46:01
tags: 学习
categories: android


[TOC]

CoordinatorLayout

CoordinatorLayout 主要使用于以下两个场景

  • 作为一个顶层父容器出现
  • 协调一个或多个子View之间的交互

CoordinatorLayout 通过Behaviors指定子View的交互行为。

使用CoordinatorLayout需要导入design包

我进入的误区

才开始接手CoordinatorLayout,没有理清CoordinatorLayout的具体用途和使用场所。所以在学习过程中出现了很多不必要的问题。

  1. 刚开始以为CoordinatorLayout和FrameLayout之类的布局一样,没有认清CoordinatorLayout的作用
  2. 忽视了Behavior的重要性。
  3. 不熟悉CoordinatorLayout,想着直接可以上手,忽视了对Demo的研究

CoordinatorLayout简单使用

CoordinatorLayout的核心就是Behavior,Behavior就是定制子View的行为。

布局

CoordinatorLayout 继承与ViewGroup,但是最基本的表现形式和FrameLayout很相识。

也就是布局是重叠的从左上角开始。

如果要用好CoordinatorLayout,那么最基本的就是通过Behavior去控制。

实现效果

想通过CoordinatorLayout布局,实现顶层Toolbar加中间Fragment加底部菜单这种通用型的布局。

  • 更换父布局为android.support.design.widget.CoordinatorLayout
  • 按照网上的实例,对toolbar上封装一层AppBarLayout
  • 添加frameLayout布局。
<FrameLayout
android:id="@+id/fragmet_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#ffffffff"
app:layout_behavior="@string/appbar_scrolling_view_behavior">

</FrameLayout>
  • 添加底部布局LinearLayout.因为CoordinatorLayout表现形式和FrameLayout很相识,所以底部布局我直接增加底部对齐

很好,效果实现了。效果图如下:


image

疑问

  • 对于网上的事例,我首先的问题是,Toolbar必须用AppBarLayout封装么?

我动手删掉了AppBarLayout,然后运行效果是:Toolbar直接不显示了!好诡异,开始纠结这个问题。半个小时后发现,Toolbar被FrameLayout给覆盖住了..

但是结果还是不对啊?难道要我主动对frameLayout增加一个marginTop?如果我不知道toolbar的高度,或者不好获取这个高度,那不是坑大了?

  • 对比发现唯一的不同之处就是多了layout_behavior属性。这个属性是干什么的?

看到这里。要感谢大神写的博客CoordinatorLayout的使用如此简单.

因为发现各种的坑,又不明白原理。基本快对CoordinatorLayout打差评的我,发现这个博客,然后一步一步研究这个,并且根据网上各种人的说法,把重心放在Behavior上。然后研究behavior的layoutDependsOn和onDependentViewChanged方法。

Behavior

最主要的两个方法:


image

可以看到大神的介绍:

  • layoutDependsOn主要是判断child布局是否依赖当前这个View。
  • onDependentViewChanged主要是当依赖的View改变时,这个child布局改变动作

看到这里,我突然有点明白了,CoordinatorLayout是协调一个或多个子View之间的交互。那么FrameLayout在Toolbar下面出现,这是不是也是一种依赖关系呢?

如果是我想的这样,那么我会在layoutDependsOn检查当dependency是Toolbar的时候,就返回true

在onDependentViewChanged的方法中,获取dependency的高度,然后动态的把这个高度设置给child,也就是FrameLayout。

AppBarLayout

懒得动手,我选择直接去找AppBarLayout中是如何实现Behavior中的两个方法的。打算复制过来看看。


layoutDependsOn

layoutDependsOn实现很简单粗暴。dependency是AppBarLayout,那么就返回true


onDependentViewChanged
offsetChildAsNeeded

虽然没用过ViewCompat.offsetTopBottom方法,但是大概理解这个方法的意思。好吧,我的猜想完全是正确的。

代码实现

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<FrameLayout
android:id="@+id/fragmet_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#00ffffff"
app:layout_behavior="com.xiaoqiang.view.MyBehavior">

</FrameLayout>

<include layout="@layout/tool_bar_base" />

<LinearLayout
android:id="@+id/rl_bottom_menu"
android:layout_width="match_parent"
android:layout_height="80dp"
android:layout_alignParentBottom="true"
android:layout_gravity="bottom"
android:orientation="horizontal">

<Button
android:id="@+id/btn_first"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="first" />

<Button
android:id="@+id/btn_second"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="second" />

<Button
android:id="@+id/btn_three"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="three" />
</LinearLayout>
</android.support.design.widget.CoordinatorLayout>

app:layout_behavior="com.xiaoqiang.view.MyBehavior",这里我自定义了一个MyBehavior.

public class MyBehavior extends CoordinatorLayout.Behavior<FrameLayout> {

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

@Override
public boolean layoutDependsOn(CoordinatorLayout parent, FrameLayout child, View dependency) {
return dependency instanceof ToolLinearLayout;
}

@Override
public boolean onDependentViewChanged(CoordinatorLayout parent, FrameLayout child, View dependency) {
ViewCompat.setPaddingRelative(child,0,dependency.getBottom() - child.getTop(),0,0);
return false;
}
}

layoutDependsOn中,当dependency是ToolLinearLayout的时候,直接返回true.这里我的想法是如果一个布局文件中有多个toolbar,那么直接使用会不会导致动作错乱。所以仿照了AppBarLayout。

执行后,效果果然和我的一样。对于CoordinatorLayout也才有了一点点的理解。感觉功能很强大!

image

后记

在网上看博客过程中,也了解了一些CoordinatorLayout的细节。

  • CoordinatorLayout只能对直接子view操作。
  • CoordinatorLayout和一些新的控件配合,可以实现很好的效果。CoordinatorLayout是 Material Design的一种很好体现
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,671评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,442评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,524评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,623评论 1 275
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,642评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,584评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,953评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,621评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,865评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,608评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,698评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,378评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,958评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,940评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,173评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,419评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,425评论 2 342

推荐阅读更多精彩内容