Android涟漪背景颜色

qwe*_*rtz 39 android android-listview android-activity navigation-drawer rippledrawable

我在导航抽屉上使用了涟漪效果.我已经像这样设置并将其应用到我的ListView:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_activated="true" android:drawable="@color/black_200" />

    <item android:state_pressed="true" android:color="@color/black_200">
        <ripple android:color="@color/black_400" />
    </item>

    <item android:drawable="@color/white" />
</selector>
Run Code Online (Sandbox Code Playgroud)

我希望纹波背景与正常激活状态保持一致.即使我将颜色定义为与激活状态相同,它也会变暗,并且波纹气泡会变得更暗.如何将背景颜色设置为相同,如激活状态和波纹气泡是我告诉它的颜色?

i.s*_*rin 67

使用样式更容易:

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
   ...
   <item name="colorControlHighlight">@color/ripple_material_dark</item>
   ...
</style>
Run Code Online (Sandbox Code Playgroud)

  • 作为接受答案的海报,我投票这成为公认的答案 (8认同)

Gil*_*yof 49

您可以RippleDrawable通过执行以下操作来控制颜色:

RippleDrawable rippleDrawable = (RippleDrawable)view.getBackground(); // assumes bg is a RippleDrawable

int[][] states = new int[][] { new int[] { android.R.attr.state_enabled} };
int[] colors = new int[] { Color.BLUE }; // sets the ripple color to blue

ColorStateList colorStateList = new ColorStateList(states, colors);
rippleDrawable.setColor(colorStateList);
Run Code Online (Sandbox Code Playgroud)

或者,通过XML:

<?xml version="1.0" encoding="utf-8"?>
<ripple
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#FFFF0000"> <!-- The ripple will be red -->

    <!-- the normal bg color will be light grey -->
    <item>
        <color android:color="#FFDDDDDD" />
    </item>

    <!-- make sure the ripple doesn't exceed the bounds -->
    <item android:id="@android:id/mask">
        <shape android:shape="rectangle">
            <solid android:color="?android:colorAccent" />
        </shape>
    </item>
</ripple>
Run Code Online (Sandbox Code Playgroud)

编辑

在看到@ i.shadrin的答案之后,我必须承认这是一种更简单的方法(使用样式).如果这是你的选择,我会推荐它.

  • 你可以分享你的xml解决方案用于反向API(在api版本21之前)吗? (2认同)

Abd*_*wan 13

在视图中添加这两行代码以产生连锁效果.

android:clickable="true"
android:background="?attr/selectableItemBackground"
Run Code Online (Sandbox Code Playgroud)