带有基本活动的工具栏的高程阴影不可见

Ste*_*e M 6 android android-elevation

我使用 Android Studio 创建了一个“基本活动”,并尝试使用toolbar-not-showing-elevation-in-android-9-api-28 中的答案在 API 28 Pixel 设备上创建高程阴影。但是,没有显示高程阴影。该activity_main.xml文件当前为:

<androidx.coordinatorlayout.widget.CoordinatorLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">

    <com.google.android.material.appbar.AppBarLayout
            android:layout_height="wrap_content"
            android:layout_width="match_parent"
            app:elevation="0dp"
            android:theme="@style/AppTheme.AppBarOverlay">

        <androidx.appcompat.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:elevation="16dp"
                android:layout_height="?attr/actionBarSize"
                android:background="?attr/colorPrimary"
                app:popupTheme="@style/AppTheme.PopupOverlay"/>

    </com.google.android.material.appbar.AppBarLayout>

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

    <com.google.android.material.floatingactionbutton.FloatingActionButton
            android:id="@+id/fab"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="bottom|end"
            android:layout_margin="@dimen/fab_margin"
            app:srcCompat="@android:drawable/ic_dialog_email"/>

</androidx.coordinatorlayout.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)

为什么高程阴影不再起作用Toolbar

Che*_*amp 12

使用您提供的 XML,添加android:clipChildren="false"CoordinatorLayout。这将允许在AppBarLayout的边界之外绘制阴影。

XML 现在看起来像这样(这里简化了):

<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:clipChildren="false">

    <com.google.android.material.appbar.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <androidx.appcompat.widget.Toolbar
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            android:elevation="16dp"
            app:title="The Toolbar"
            app:titleTextColor="@android:color/white" />

    </com.google.android.material.appbar.AppBarLayout>
Run Code Online (Sandbox Code Playgroud)

这确实足以显示阴影。我在这里遇到的问题是API 28 和 29 上的阴影微弱了,以至于我无法将它与工具栏区分开来。

要使阴影更明显,请为 v28 创建一个样式文件,并将以下内容添加到应用程序的主题中:

<item name="android:spotShadowAlpha">0.5</item>
Run Code Online (Sandbox Code Playgroud)

似乎默认的 alpha 值太微弱而无法轻易看到。该值纠正了问题。

“在 Android 中玩提升(第 1 部分)”很好地解释了这个问题。

布局现在在 API 29 模拟器上看起来像这样:

在此处输入图片说明