22

我已经创建了这样的 AppBar 布局

<android.support.design.widget.AppBarLayout
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/appbar_layout"
    android:layout_height="@dimen/app_bar_height"
    android:layout_width="match_parent"
    android:fitsSystemWindows="true"
    android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
    app:elevation="20dp">

    <android.support.design.widget.CollapsingToolbarLayout...>
</android.support.design.widget.AppBarLayout>

它工作并在 LinearLayout 中投下阴影:

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <include layout="@layout/app_bar_large" />
</LinearLayout>

然而,当我把它放入 CoordinatorLayout 时,阴影消失了:

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <include layout="@layout/app_bar_large" />
</android.support.design.widget.CoordinatorLayout>

我怎样才能让 appbar 再次显示它的影子?

在此处输入图像描述

4

4 回答 4

17

这实际上是一个实现细节CollapsingToolbarLayout,如源代码所示:

if (Math.abs(verticalOffset) == scrollRange) {
  // If we have some pinned children, and we're offset to only show those views,
  // we want to be elevate
  ViewCompat.setElevation(layout, layout.getTargetElevation());
} else {
  // Otherwise, we're inline with the content
  ViewCompat.setElevation(layout, 0f);
}

CollapsingToolbarLayout当显示非固定元素时,它会删除高程- 默认情况下,只有在只有固定子项可见时才会有高程。

于 2015-12-07T19:41:22.113 回答
9

原因在上面,试试这个解决:

appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
        @Override
        public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
            //some other code here
            ViewCompat.setElevation(appBarLayout, The Elevation In Px);
        }
    });
于 2017-07-05T07:17:17.437 回答
4

解决办法是用app:elevation=0dp去掉默认的高程,设置android:translationZ成你想要的高程。

注意:下面的代码使用最新的 AndroidX / Material 库,如果您使用旧的支持库,可能无法正常工作

<com.google.android.material.appbar.AppBarLayout
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:translationZ="8dp"
    app:elevation="0dp">

    <!--
      * `app:elevation=0dp` disables the default shadow that is automatically added on
      scroll ; other values e.g. `6dp` are ignored despite what the official doc says
      (see below)
      * so instead we're using `android:translationZ` to add a shadow with a custom
      elevation
    -->

AppBarLayout # setTargetElevation()的文档声明您可以使用该app:elevation属性设置自定义高程值,但是对于大于 的值,它对我不起作用0dp,因此我将translationZ其用作解决方法。

于 2020-03-16T18:24:04.657 回答
1

setTargetElevation()现在已弃用 AppBarLayout。

根据布局状态将自定义提升应用到 AppBarLayout 的新正确实现是使用 StateListAnimator。如您在此处看到的,材料组件使用它

我在这个 gist中添加了一个始终显示 AppBarLayout 高度的示例实现。

您只需要 1. 在下面创建一个自定义状态列表动画/res/animator器 2. 像这样设置 AppBarLayout 的 StateListAnimator:

appBarLayout.stateListAnimator = AnimatorInflater.loadStateListAnimator(context, R.animator.appbar_always_elevated_state_list_animator)
于 2020-06-01T21:21:02.110 回答