CoordinatorLayout + AppBarLayout + CollapsingToolbarLayout

本文介绍了CoordinatorLayout、AppBarLayout和CollapsingToolbarLayout在Android中的使用,详细讲解了它们如何协同工作以实现折叠和收缩视图的效果。CoordinatorLayout作为一个强大的顶级布局,用于协调子布局的交互。AppBarLayout是垂直LinearLayout,支持Material Design的滚动手势,而CollapsingToolbarLayout则提供了折叠效果,允许子View在滚动时有不同的表现。文章还详细阐述了各种属性和模式,如layout_behavior、scrollFlags、collapseMode等,以及它们如何影响布局的行为。
摘要由CSDN通过智能技术生成

CoordinatorLayout

CoordinatorLayout相当于一个功能更加强大的FrameLayout,主要有两个用途:

  1. 作为顶层布局;
  2. 作为协调与子布局之间交互的容器。

通过为子布局指定Behaviors,可以为子布局之间提供不同的交互。CoordinatorLayout的子布局可以通过实现CoordinatorLayout.AttachedBehavior接口为自身添加默认行为(behavior)。简单来说,CoordinatorLayout相当于一个第三方,通过Behaviors属性对子布局之间进行行为交互控制。具体如何控制如下:

##CoordinatorLayout
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    ...
    for (int i = 0; i < childCount; i++) {
        final View child = mDependencySortedChildren.get(i);
        if (child.getVisibility() == GONE) {
            // If the child is GONE, skip...
            continue;
        }
        final LayoutParams lp = (LayoutParams) child.getLayoutParams();
        ...
        final Behavior b = lp.getBehavior();
        if (b == null || !b.onMeasureChild(this, child, childWidthMeasureSpec, keylineWidthUsed,
            childHeightMeasureSpec, 0)) {
            onMeasureChild(child, childWidthMeasureSpec, keylineWidthUsed,childHeightMeasureSpec, 0);
        }
        ...
    }
    ...
}

##CoordinatorLayout.Behavior<V extends android.view.View>
/**
 * @return true if the Behavior measured the child view, false if the CoordinatorLayout should perform its default measurement
 */
public boolean onMeasureChild(CoordinatorLayout parent, V child, int parentWidthMeasureSpec, int widthUsed,
        int parentHei
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值