问题描述
我有一个自定义的 drawable,有 3 种状态(按下、选择和默认)。 在 Android Studio 预览中切换状态时,按下状态不会触发可绘制对象的任何更改。选定状态按预期工作。 我在聚焦状态下也经历过这种行为,state_checked 似乎正在工作。 在我为测试目的创建的另一个 drawable 中,一切都按预期工作,即使状态的顺序完全相同。
<item android:state_pressed="true">
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<padding android:bottom="@dimen/sev_margin_xsmall"
android:top="@dimen/sev_margin_xsmall"
android:left="@dimen/sev_margin_xsmall"
android:right="@dimen/sev_margin_xsmall" />
<stroke
android:width="2dp"
android:color="@color/sev_btn_color_primary" />
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item android:drawable="@drawable/ic_sev_male" android:top="20dp" android:bottom="20dp" android:start="30dp" android:end="30dp" android:gravity="center">
</item>
</layer-list>
</item>
<item android:state_selected="true">
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<padding android:bottom="@dimen/sev_margin_xsmall"
android:top="@dimen/sev_margin_xsmall"
android:left="@dimen/sev_margin_xsmall"
android:right="@dimen/sev_margin_xsmall" />
<stroke
android:width="2dp"
android:color="@color/sev_btn_color_primary" />
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item android:drawable="@drawable/ic_sev_male" android:top="20dp" android:bottom="20dp" android:start="30dp" android:end="30dp" android:gravity="center">
</item>
</layer-list>
</item>
<item>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/sev_ripple_color">
<item>
<shape android:shape="rectangle">
<padding android:bottom="@dimen/sev_margin_xsmall"
android:top="@dimen/sev_margin_xsmall"
android:left="@dimen/sev_margin_xsmall"
android:right="@dimen/sev_margin_xsmall" />
<stroke
android:width="2dp"
android:color="#CCCCCC" />
<solid android:color="@android:color/white" />
<corners android:radius="10dp" />
</shape>
</item>
</ripple>
</item>
<item android:drawable="@drawable/ic_sev_male" android:top="20dp" android:bottom="20dp" android:start="30dp" android:end="30dp" android:gravity="center">
</item>
</layer-list>
</item>
具有相同顺序和正确行为的自定义可绘制:
<!-- Todo Redundanz prüfen,ändert sich ja nur checkBox state -->
<item android:state_pressed="true">
<shape android:shape="rectangle">
<solid android:color="@android:color/holo_blue_bright" />
</shape>
</item>
<item android:state_selected="true">
<shape android:shape="rectangle">
<solid android:color="@android:color/white" />
</shape>
</item>
<item>
<shape android:shape="rectangle">
<solid android:color="@android:color/red" />
</shape>
</item>
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)