Android自定义单选按钮无法显示

时间:2016-06-27 05:32:15

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

您好我已经创建了一个使用xml drawable选中和取消选中的自定义单选按钮,我也创建了一个选择器。当我将按钮属性设置为我的自定义选择器时,在模拟器中它正确显示。但是当我在真实设备中运行这个项目时,没有任何东西显示出来。我只能看到文本。 我的真实设备是Android 4.4.2。

unselected.xml

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!-- larger circle at the back -->
<item
    android:width="@dimen/radiooutter"
    android:height="@dimen/radiooutter"
    android:gravity="center">
    <shape
        android:shape="oval"
        android:useLevel="false">
        >

        <solid android:color="@android:color/transparent" />

        <!-- thicker outer boarder -->
        <stroke
            android:width="2dp"
            android:color="@color/colorPrimary"/>
    </shape>
</item>


<!-- inner circle -->
<item
    android:width="@dimen/inner"
    android:height="@dimen/inner"
    android:gravity="center">
    <shape
        android:shape="oval">
        <solid android:color="@android:color/transparent" />

    </shape>
</item>

selected.xml

<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<!-- larger circle at the back -->
 <item
    android:width="@dimen/radiooutter"
    android:height="@dimen/radiooutter"
    android:gravity="center">
    <shape
        android:shape="oval">

        <solid
            android:color="#FFFFFF"/>

        <!-- thicker outer boarder -->
        <stroke
            android:width="1dp"
            android:color="@color/colorPrimary"/>
    </shape>
</item>


<!-- inner circle -->
<item
    android:width="@dimen/inner"
    android:height="@dimen/inner"
    android:gravity="center">
    <shape
        android:shape="oval">
        <solid
            android:color="@color/colorPrimaryLight"/>

    </shape>
</item>

selector.xml

 <selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:state_checked="true"     android:drawable="@drawable/radioselected"/>
<item android:state_checked="false" android:drawable="@drawable/radiounselected"/>
</selector>
布局xml中的

radiobutton

android:id="@+id/opt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:button="@drawable/selector"
android:paddingLeft="10dp"
android:paddingRight="10dp"
android:text="First option"
android:textSize="16dp"/>

1 个答案:

答案 0 :(得分:0)

试试这个

 android:id="@+id/opt"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@drawable/selector"
 android:button="@android:color/transparent"
 android:paddingLeft="10dp"
 android:paddingRight="10dp"
 android:text="First option"
 android:textSize="16dp"/>

这将有助于你