【问题标题】:android, custom state_pressed doesn't workandroid,自定义 state_pressed 不起作用
【发布时间】:2019-09-03 23:40:00
【问题描述】:

如下所示,我的自定义选择器没有按预期工作,我根本看不到 pressed 状态。任何提示?谢谢

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"

    >
    <!-- this state button has special design:
        + enabled state has white text on green background
        + disabled state has grey text on greyer background
    -->


    <item android:state_enabled="true"
        android:drawable="@drawable/cb_shape_button_primary"
        android:color="@color/white"

        />
    <item android:state_pressed="true"
        android:drawable="@drawable/cb_shape_button_pressed"
        android:color="@color/white"

        />

    <item android:state_focused="true"
        android:drawable="@drawable/cb_shape_button_pressed"
        android:color="@color/white"

        />
    <item android:state_enabled="false"
        android:drawable="@drawable/cb_shape_button_flat"
        android:color="@color/grey_subtext"
        />

</selector>

【问题讨论】:

标签: android android-custom-view android-custom-drawable


【解决方案1】:

尝试像这样将 state_pressed 移到顶部:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"

>
<!-- this state button has special design:
    + enabled state has white text on green background
    + disabled state has grey text on greyer background
-->

<item android:state_pressed="true"
    android:drawable="@drawable/cb_shape_button_pressed"
    android:color="@color/white"

    />

<item android:state_enabled="true"
    android:drawable="@drawable/cb_shape_button_primary"
    android:color="@color/white"

    />

<item android:state_focused="true"
    android:drawable="@drawable/cb_shape_button_pressed"
    android:color="@color/white"

    />
<item android:state_enabled="false"
    android:drawable="@drawable/cb_shape_button_flat"
    android:color="@color/grey_subtext"
    />

编辑:
正如 @forcewill 提到的,请注意,将按下状态移动到顶部的原因与 Android 将使用匹配的第一个状态这一事实有关,在您的情况下,小部件已启用并且同时按下,因此它首先匹配启用状态。

【讨论】:

  • 请注意,将按下状态移动到顶部的原因与 Android 将使用匹配的第一个状态有关,在您的情况下,小部件已启用并同时按下,因此首先匹配启用状态
【解决方案2】:

选择器 XML 标记始终选择 first 匹配项。这意味着如果启用视图,它将始终显示@drawable/cb_shape_button_primary。选择器的一般经验法则是,您的“默认”项应该是列表中的最后一项。

尝试最后移动您的默认状态,看看是否能解决您的问题。

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"

    >
    <!-- this state button has special design:
        + enabled state has white text on green background
        + disabled state has grey text on greyer background
    -->

    <item android:state_pressed="true"
        android:drawable="@drawable/cb_shape_button_pressed"
        android:color="@color/white"

        />

    <item android:state_focused="true"
        android:drawable="@drawable/cb_shape_button_pressed"
        android:color="@color/white"

        />
    <item android:state_enabled="false"
        android:drawable="@drawable/cb_shape_button_flat"
        android:color="@color/grey_subtext"
        />

   <item android:state_enabled="true"
        android:drawable="@drawable/cb_shape_button_primary"
        android:color="@color/white"

        />

</selector>

【讨论】:

    【解决方案3】:

    试试这个,

    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/select_item" android:state_checked="true" android:state_focused="true" />
    <item android:drawable="@drawable/unselect_item" android:state_checked="false" android:state_focused="true" />
    <item android:drawable="@drawable/unselect_item" android:state_checked="false" />
    <item android:drawable="@drawable/select_item" android:state_checked="true" />
    

    【讨论】:

    • 您不应该只发布代码,还应该解释您提出建议的原因。
    【解决方案4】:

    对于简单的选择和取消选择使用这个

    <selector><item android:state_checked="false" android:drawable="@drawable/radiobtnunselected"/><item android:state_checked="true" android:drawable="@drawable/radiobtnselected"/></selector>
    

    并将图像设置为 android:drawable

    真:选择

    错误:未选中

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-03-03
      相关资源
      最近更新 更多