我有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>
答案 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>