我一直在使用 android:background="?selectableItemBackground"
在单击视图(例如 LinearLayout
)时产生连锁反应。我想我在某处读到它向后兼容 API 14。
但是,我发现我需要在白色背景下使用这种涟漪效果。具体来说,我有一个列表项的布局,它将显示在默认颜色背景上(我从 Theme.AppCompat.Light.NoActionBar
扩展),所以我希望列表项通过为列表着色从这个背景中脱颖而出项目纯白色 ( #FFFFFF
)。
这是列表项布局:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:background="?selectableItemBackground"
android:layout_width="match_parent"
android:layout_height="wrap_content">
...
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:paddingLeft="@dimen/mdu_keyline_1"
android:paddingRight="@dimen/mdu_keyline_1"
android:paddingTop="@dimen/mdu_padding_normal"
android:paddingBottom="@dimen/mdu_padding_normal">
...
</LinearLayout>
</FrameLayout>
以上产生了没有白色背景的涟漪效果。
如果我尝试:
<FrameLayout ...
android:background="@color/white">
这显然会产生白色背景,但不会产生涟漪效应。
我还尝试了其他方法 - 这产生了最接近我正在寻找的结果:
<FrameLayout ...
android:background="@color/white">
...
<LinearLayout ...
android:background="?selectableItemBackground">
上面给了我带有涟漪效果的白色背景。 _然而_,无论我点击项目的哪一部分,波纹似乎总是从中心开始。
以下是显示当前结果的一些屏幕截图(忽略列表项顶部的阴影 - 这是来自 AppBarLayout
和 Toolbar
我正在使用的阴影)。
我怎样才能达到预期的效果?
原文由 Farbod Salamat-Zadeh 发布,翻译遵循 CC BY-SA 4.0 许可协议
您可以使用 FrameLayout 的前景: