Material 设计:在 android 样式中的何处放置立面?

Material design: Where to place elevation in android styles?

我想在我的某些应用样式中设置项目高度。现在海拔只有 21 和更高,没有支持库,所以我的自然倾向是创建一个 styles-v21 xml 并将它放在那里:

<style name="Widget.MyApp.Drawer" parent="ThemeOverlay.AppCompat.Dark.ActionBar">
    <item name="android:elevation">4dp</item>
</style>

问题是我在常规 styles.xml 文件中对 Widget.MyApp.Drawer 所做的任何更改都将被它完全覆盖。我想要的是将提升添加到我为 styles.xml.

中列出的此样式的 v21 版本所做的样式更改列表的底部

所以我着手创建基本样式,我在视图中使用的样式继承自:

<style name="BaseListElement">
    <item name="android:background">@drawable/listitem_background</item>
    <item name="android:layout_height">@dimen/list_item_height</item>
</style>

<style name="BaseListElement.ListItem">

</style>

我在 styles.xml 中将样式留空,在 styles-v21 中,我添加了高度并且它起作用了。

然而,当我想使用一些高级样式时,这有点棘手:

<style name="BaseListElement">
    <item name="android:background">@drawable/listitem_background</item>
    <item name="android:layout_height">@dimen/list_item_height</item>
</style>

<style name="BaseListElement.BaseItem">
    <item name="android:padding">@dimen/list_item_padding</item>
</style>

<style name="Widget.MyApp.ListItem" parent="@style/BaseListElement.BaseItem">

</style>

<style name="BaseListElement.BaseHeader">

</style>

在这种情况下,BaseItem只是继承自BaseListElement的一种样式,BaseHeader等样式也继承自它。如您所见,这有点荒谬。

我是不是想多了?在我看来,这里有 3 个选择:

1) 照原样继续,感觉自己像个白痴

2) 在 BaseListElement 级别上,创建一个带有一些愚蠢名称的子样式,这是我应用高程的点,然后(希望)将其渗透到所有子项。但是,一旦我在基础的 v21 子代之间有区别,这就不起作用了。

3) 只需将 android:elevation 放入 styles.xml 文件(不要使用 v21 文件)并在元素上放置一个忽略标志。我这里只有 5.0 设备,所以我目前无法轻松测试这是否会导致旧版本崩溃。

有什么想法吗?

要完成这样的事情,您可以在 styles.xmlsyles-v21.xml 中创建一个 BaseListElement.BaseItem,第一个没有海拔,第二个有海拔。然后只需从 BaseListElement.BaseItem 扩展 Widget.MyApp.ListItem,它应该在 v21 中更新以使用 elevation.

styles.xml

<style name="BaseListElement.BaseItem">

</style>

<style name="Widget.MyApp.ListItem" parent="@style/BaseListElement.BaseItem">

</style>

样式-v21.xml

<style name="BaseListElement.BaseItem">
    <item name="android:padding">@dimen/list_item_padding</item>
</style>

方法3你可以安全的实现如下:

<item name="android:elevation" tools:ignore="NewApi">4dp</item>