相关疑难解决方法(0)

Android:你有一个涟漪效应,其默认状态颜色是透明的吗?

像下面的东西,但它不起作用.如果我将可绘制颜色切换为蓝色,它可以工作.

<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)

android android-layout android-view android-selector

23
推荐指数
1
解决办法
8981
查看次数

压态下的波纹效应+正常状态下的透明度

我希望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)

layout animation android imageview ripple

3
推荐指数
2
解决办法
4741
查看次数

Android Ripple:其他应用如何使它们的波纹如此透明而不影响视图的原始颜色

当您查看其他应用程序(例如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

android rippledrawable

3
推荐指数
1
解决办法
892
查看次数