Unikaj efektu marszczenia łączenie kolorów [duplikat]

Dec 18 2020

Mam prosty program, który używa efektu ripple przy użyciu tego kodu ( edytowanego stąd ):

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="#0000ff"><!--blue-->
    <item android:id="@android:id/mask">
        <shape android:shape="rectangle">
            <solid android:color="#0000ff" /><!--blue-->
            <corners android:radius="20dp" />
        </shape>
    </item>

    <item android:id="@android:id/background">
        <shape android:shape="rectangle">
            <solid android:color="#ff0000"/><!--red-->
            <corners android:radius="20dp" />
        </shape>
    </item>
</ripple>

wszystko działa dobrze, ale chcę, aby kolor tętnienia (niebieski) był powyżej koloru tła (czerwony), a nie był połączony z fioletem.

ZRZUT EKRANU:

before:


in process:

after : po

co chcę być:

jakikolwiek sposób, aby to osiągnąć?
Z góry dziękuję.

Odpowiedzi

MohammedAlaa Dec 18 2020 at 01:27

Trochę to zredagowałem, możesz wypróbować tę próbkę

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="#0000ff">
<item>
    <selector>
        <item android:state_pressed="true">
            <shape android:shape="rectangle">
                <solid android:color="@android:color/transparent"/>
                <corners android:radius="20dp" />
            </shape>
        </item>

        <item android:state_pressed="false">
            <shape android:shape="rectangle">
                <solid android:color="#ff0000"/>
                <corners android:radius="20dp" />
            </shape>
        </item>

    </selector>
</item>
<item android:id="@android:id/mask">
    <shape android:shape="rectangle">
        <solid android:color="#0000ff" />
        <corners android:radius="20dp" />
    </shape>
</item>
</ripple>