博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CoordinatorLayout的使用
阅读量:6121 次
发布时间:2019-06-21

本文共 3841 字,大约阅读时间需要 12 分钟。

官方文档中对CoordinatorLayout有如下的描述:

CoordinatorLayout is a super-powered FrameLayout.

CoordinatorLayout is intended for two primary use cases:

  • As a top-level application decor or chrome layout

  • As a container for a specific interaction with one or more child views

即,可以作为顶层布局,或者协调子布局的容器。

与snackbar的配合使用。

先看一个效果图。当弹出snackbar之后,floatbutton的位置会相应向上提升一个snackbar的高度。并且,通过右滑操作,可以删除这个snackbar。这在普通的Layout容器中无法实现。

CoordinatorLayout与Snackbar

显示SnackBar的代码:

Snackbar.make(view, "Hello. I am Snackbar!", Snackbar.LENGTH_SHORT).setAction("OK", null).show();

在显示snackbar的时候,需要传入一个view,snackbar会从view开始向上寻找父view,直到找到一个顶级view或者CoordinatorLayout,然后显示在这个view的底部。如果是CoordinatorLayout,则会有上述的高级效果。

上述的页面布局代码:

Activity中的java代码:

public class MainActivity extends AppCompatActivity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        findViewById(R.id.fab).setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View view) {                Snackbar.make(view,"FAB",Snackbar.LENGTH_LONG)                        .setAction("cancel", new View.OnClickListener() {                            @Override                    c void onClick()                        }.show();            }        });    }}

CoordinatorLayout实现可隐藏的Toolbar

首先要说明的是,老旧的ActionBar并不能与CoordinatorLayout兼容。需要使用较新的Toolbar。

先看效果图:
(向下滑动列表时)
clipboard.png

(向上滑动列表时)

clipboard.png

这里需要使用AppBarLayout讲Toolbar包裹起来:

注意,在比较旧的版本中,AppBarLayout必须作为CoordinatorLayout的第一个子元素,但是现在好像可以只作为AppBarLayout的直接子元素就可以了。

为了实现向上滑动时能够隐藏Toolbar,需要在Toolbar中添加如下的属性:

app:layout_scrollFlags="scroll|enterAlways"

要实现滑动的高级效果,Scroll标志是必须的。flags还有几个取值:

  1. scroll: 所有想滚动出屏幕的view都需要设置这个flag, 没有设置这个flag的view将被固定在屏幕顶部。例如,TabLayout 没有设置这个值,将会停留在屏幕顶部。

  2. enterAlways: 设置这个flag时,向下的滚动都会导致该view变为可见,启用快速“返回模式”。

  3. enterAlwaysCollapsed: 当你的视图已经设置minHeight属性又使用此标志时,你的视图只能已最小高度进入,只有当滚动视图到达顶部时才扩大到完整高度。

  4. exitUntilCollapsed: 滚动退出屏幕,最后折叠在顶端。

与AppBarLayout同级,作为CoordinatorLayout的另一个直接子元素的则是产生滑动事件的view。这里ListView并不兼容,可以使用RecycledView。RecycledView是一个高度解耦的列表视图,提供子视图的回收功能。并且,布局方式高度可定制。对控件的操作变成了面向ViewHolder的操作。

布局文件:

注意,列表视图中有这样一个属性:app:layout_behavior="@string/appbar_scrolling_view_behavior",这个属性告诉CoordinateLayout,我希望我的滑动操作能够引起Toolbar的变化。CoordinatorLayout就会去检查Toolbar的scrollFlags,并在滑动时作出相应的调整。

同时,这个属性还可以让下方的视图顶端保持在Toolbar的下方,而不是被Toolbar覆盖。

可折叠的Toolbar

clipboard.png

clipboard.png

clipboard.png

这时候,需要在AppBarLayout中将Toolbar用CollapsingToolbarLayout再包裹起来:

这种效果在详情页面用的较多,展示个性化内容,图像有强烈的吸引力。这个效果重点使用了CollapsingToolbarLayout 。

CollapsingToolbarLayout可实现Toolbar的折叠效果。CollapsingToolbarLayout的子视图类似与LinearLayout垂直方向排放。

CollapsingToolbarLayout 提供以下属性和方法是用:

  1. Collapsing title:ToolBar的标题,当CollapsingToolbarLayout全屏没有折叠时,title显示的是大字体,在折叠的过程中,title不断变小到一定大小的效果。你可以调用setTitle(CharSequence)方法设置title。

  2. Content scrim:ToolBar被折叠到顶部固定时候的背景,你可以调用setContentScrim(Drawable)方法改变背景或者 在属性中使用 app:contentScrim=”?attr/colorPrimary”来改变背景。

  3. Status bar scrim:状态栏的背景,调用方法setStatusBarScrim(Drawable)。还没研究明白,不过这个只能在Android5.0以上系统有效果。

  4. Parallax scrolling children:CollapsingToolbarLayout滑动时,子视图的视觉差,可以通过属性app:layout_collapseParallaxMultiplier=”0.6”改变。值de的范围[0.0,1.0],值越大视察越大。

  5. CollapseMode :子视图的折叠模式,在子视图设置,有两种“pin”:固定模式,在折叠的时候最后固定在顶端;“parallax”:视差模式,在折叠的时候会有个视差折叠的效果。我们可以在布局中使用属性app:layout_collapseMode=”parallax”来改变。

CoordinatorLayout 还提供了一个 layout_anchor 的属性,连同 layout_anchorGravity 一起,可以用来放置与其他视图关联在一起的悬浮视图(如 FloatingActionButton)。本例中使用FloatingActionButton。

通过下面的参数设置了FloatingActionButton的位置,两个属性共同作用使得FAB 浮动按钮也能折叠消失,展现。

app:layout_anchor="@id/appbar"

app:layout_anchorGravity="bottom|right|end"

使用CollapsingToolbarLayout实现折叠效果,需要注意3点

  1. AppBarLayout的高度固定

  2. CollapsingToolbarLayout的子视图设置layout_collapseMode属性

  3. 关联悬浮视图设置app:layout_anchor,app:layout_anchorGravity属性

自定义behavior

(占坑,挖坑学习中)

转载地址:http://komka.baihongyu.com/

你可能感兴趣的文章
前端学习之正则表达式
查看>>
配置 RAILS FOR JRUBY1.7.4
查看>>
AndroidStudio中导入SlidingMenu报错解决方案
查看>>
修改GRUB2背景图片
查看>>
Ajax异步
查看>>
好记性不如烂笔杆-android学习笔记<十六> switcher和gallery
查看>>
JAVA GC
查看>>
codeforce 599B Spongebob and Joke
查看>>
3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)
查看>>
9、Dubbo-配置(4)
查看>>
前端第七天
查看>>
BZOJ 2190[SDOI2008]仪仗队
查看>>
图解SSH原理及两种登录方法
查看>>
[转载] 七龙珠第一部——第058话 魔境圣地
查看>>
【总结整理】JQuery基础学习---样式篇
查看>>
查询个人站点的文章、分类和标签查询
查看>>
基础知识:数字、字符串、列表 的类型及内置方法
查看>>
JSP的隐式对象
查看>>
P127、面试题20:顺时针打印矩阵
查看>>
JS图片跟着鼠标跑效果
查看>>