Android-改变颜色并同时在布局上产生涟漪

时间:2015-05-26 18:23:25

标签: android android-layout android-selector rippledrawable

我有LinearLayout。我已经应用了涟漪效果,它工作正常。我正在做的是当用户点击它时,它应该将其颜色更改为白色(默认为灰色)。如果再次点击,它应该再次变为灰色。这是我使用layout.setBackgroundColor(Color.WHITE);实现的。

但我想要涟漪和这种颜色切换。如果我使用setBackgroundColor,涟漪效应会消失。关于如何做到这一点的任何线索?

涟漪的XML(LinearLayout的背景):

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/divider">
<item android:drawable="@color/background" />
</ripple>

请为棒棒糖前设备提供等效解决方案。前棒棒糖上LinearLayout的背景是,

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@color/divider" android:state_pressed="true" />
<item android:drawable="@android:color/transparent" />
</selector>

1 个答案:

答案 0 :(得分:1)

使用setImageDrawable()代替setBackgroundColor,并传递xml布局的ID(R.drawable.your_layout)。

定义两种不同的xml布局:一种是灰色背面,另一种是白色背景。

白色背景

 <?xml version="1.0" encoding="utf-8"?>
    <ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/divider">
    <item android:drawable="#ffffff" />
    </ripple>

灰色背景

 <?xml version="1.0" encoding="utf-8"?>
    <ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/divider">
    <item android:drawable="888888" />
    </ripple>