我正在迁移Android应用以使用Material Design。为了验证我是否所做的一切正确,我创建了一个空活动来测试一些Material Design itens(FAB,凸起按钮,视图,卡片,列表等等)。
按钮显示为OK,但视图上的高程不是。我在互联网上搜索了答案,但没有找到答案。我没有使用填充,透明背景等。这是我的代码:
值-V21 / styles.xml:
<resources>
<style name="AppThemeNoActionBar" parent="AppTheme">
<item name="android:navigationBarColor">@color/colorPrimary</item>
</style>
<style name="AppTheme" parent="MyMaterialTheme.Base">
<item name="android:windowContentTransitions">true</item>
<item name="android:windowAllowEnterTransitionOverlap">true</item>
<item name="android:windowAllowReturnTransitionOverlap">true</item>
<item name="android:windowSharedElementEnterTransition">@android:transition/move</item>
<item name="android:windowSharedElementExitTransition">@android:transition/move</item>
</style>
<style name="MyMaterialTheme.Base" parent="Theme.AppCompat.Light.NoActionBar">
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="Button" parent="Base.Widget.AppCompat.Button.Colored">
<item name="android:backgroundTint">@color/colorAccent</item>
</style>
<color name="colorPrimary">#E88768</color>
<color name="colorPrimaryDark">#CC785C</color>
<color name="colorAccent">#E88768</color>
<color name="textColorPrimary">#000000</color>
<color name="windowBackground">#FFFFFF</color>
<color name="navigationBarColor">#E88768</color>
</resources>
布局-V21 / start_activity.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
xmlns:app="http://schemas.android.com/apk/res-auto">
<HorizontalScrollView
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentStart="true"
android:elevation="12dp"
android:translationZ="12dp"
android:id="@+id/scrollView">
</HorizontalScrollView>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:layout_below="@+id/scrollView">
</LinearLayout>
</RelativeLayout>
任何人都可以帮助我吗?
答案 0 :(得分:6)
尝试将背景颜色/可绘制设置为HorizontalScrollView
:
android:background="@android:color/white"
这似乎是绘制阴影所必需的。
答案 1 :(得分:1)
如果elevation
无法正常工作,您可以使用一种技巧,例如将内容放入CardView
然后设置:
card_view:cardElevation="2dp"
或者:
card_view:cardCornerRadius="4dp"
角落。
这是最佳方式,但您可能会在 Android Studio 的预览中看到elevations
,但实际上, 所有这些都不是在编译应用程序或在模拟器上运行 或真实设备时工作。因此,在这些情况下,最好使用CardView
。
例如:
<android.support.v7.widget.CardView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
card_view:cardCornerRadius="4dp"
card_view:cardElevation="2dp">
<HorizontalScrollView
android:id="@+id/scrollView"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentStart="true"
android:translationZ="12dp">
</HorizontalScrollView>
</android.support.v7.widget.CardView>