如何在Android中的操作栏下添加阴影?

时间:2016-02-21 10:43:44

标签: java android xml

我试图让阴影出现在我的操作栏下方,但由于某种原因,阴影不断出现并从屏幕的最顶部开始,而不是在操作栏下面。我在每个xml布局文件中都使用了CustomView android.support.v7.widget.Toolbar操作栏小部件。如何让阴影正确显示在此操作栏下方而不是顶部?在阴影出现之前,我可以将某种分隔符设置为等于此自定义视图的高度吗?我们可以做一些事情,比如将渐变的高度设置为50dp,但只显示该高度的最后5-10%的渐变吗?

我的主题:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- colorPrimary is used for the default action bar background -->
    <item name="colorPrimary">@color/white</item>

    <!-- colorPrimaryDark is used for the status bar -->
    <item name="colorPrimaryDark">#000</item>

    <!-- colorAccent is used as the default value for colorControlActivated
         which is used to tint widgets -->
    <item name="colorAccent">@color/teal</item>

    <!-- You can also set colorControlNormal, colorControlActivated
         colorControlHighlight & colorSwitchThumbNormal. -->

    <item name="android:textColorSecondary">#d7d7d7</item>

    <item name="android:windowContentOverlay">@drawable/actionbar_shadow</item>

</style>

影子可绘制:

<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <size android:height="4dp" />
    <gradient
        android:angle="270"
        android:endColor="@android:color/transparent"
        android:startColor="@color/grey" />
</shape>

工具栏:

<android.support.v7.widget.Toolbar
    xmlns:app="http://schemas.android.com/apk/res-auto"

    android:id="@+id/toolbar"
    android:layout_height="50dp"
    android:minHeight="30dp"
    android:layout_width="match_parent"
    android:paddingTop="10dp"
    android:paddingBottom="10dp"
    app:contentInsetLeft="0dp"
    app:contentInsetStart="0dp"
    android:background="@color/white">

    <ImageView
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:src="@drawable/actionbar_title_r"
        android:id="@+id/ActionBarTitle" />

</android.support.v7.widget.Toolbar>

1 个答案:

答案 0 :(得分:1)

工具栏仅在API 21或更高版本上运行的设备中具有阴影。为了达到这个效果,您可以添加属性android:elevation="4dp"并且它可以正常工作。希望这有帮助