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>