像下面的东西,但它不起作用.如果我将可绘制颜色切换为蓝色,它可以工作.
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="?android:colorControlHighlight">
<item android:drawable="@android:color/transparent"/>
</ripple>
Run Code Online (Sandbox Code Playgroud) 我希望ViewGroup中的ImageView,当按下时,绘制波纹,这是有效的!但是当按下ViewGroup时,其中的ImageView应保持透明,否则ImageView背景可见:(实际上,您看到的颜色为alpha-orange,是按下时的纹波).

这仅适用于设备API 21+.设备API <21时,我使用选择器,按下ViewGroup时图像背景保持透明.
layout.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/item_detail_field"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingLeft="@dimen/margin_left"
android:paddingStart="@dimen/margin_left"
android:paddingTop="@dimen/margin_top_item_field"
android:paddingBottom="@dimen/margin_bottom"
android:baselineAligned="false"
android:background="@drawable/layout"
android:stateListAnimator="@anim/touch_raise"
android:orientation="horizontal">
...
<ImageView
android:id="@+id/item_detail_showfield_icon"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/button_mini_oval"
android:stateListAnimator="@anim/touch_raise"
android:clickable="true"
android:contentDescription="@null"
android:scaleType="center"
android:visibility="invisible"
android:src="@drawable/show_button"/>
...
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)
绘制/ button_mini_oval.xml
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true">
<shape android:shape="oval">
<solid android:color="@color/primary_highlight" />
</shape>
</item>
<item>
<shape android:shape="oval">
<solid android:color="@android:color/transparent" />
</shape>
</item>
</selector>
Run Code Online (Sandbox Code Playgroud)
可绘制-V21/button_mini_oval.xml
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:exitFadeDuration="@android:integer/config_shortAnimTime"
android:color="?android:colorControlHighlight">
<item android:state_pressed="true">
<shape android:shape="oval">
<solid android:color="@android:color/white" />
</shape>
</item>
<item>
<color android:color="@android:color/transparent" />
</item>
</ripple> …Run Code Online (Sandbox Code Playgroud) 当您查看其他应用程序(例如yPlan或Google Play商店)时,它们在按钮上的波纹效果就像浅灰色或黑色,不会改变整个按钮的颜色。
我想要同样的效果。
这是我尝试过的,但是不一样
这是我的色彩控制亮点:带有99%alpha的灰色
<color name="colorHighlight">#fc8c969f</color>
Run Code Online (Sandbox Code Playgroud)
这是我的纽扣抽屉
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="?android:colorControlHighlight">
<item android:id="@android:id/mask" android:drawable="@android:color/white"/>
<item android:drawable="@color/colorAccentWith92PercentOpacity"/>
</ripple>
Run Code Online (Sandbox Code Playgroud)
注意drawable是使按钮的颜色为黄色,因为我不能两次使用android:background