Android 是否可以使用样式选择器?

Android 是否可以使用样式选择器?,android,xml,layout,Android,Xml,Layout,有没有办法让选择器选择可以在使用@style的布局中使用的样式元素?具体地说,我正试图根据state_pressed、state_focused和state_selected更改TextView元素,例如颜色和阴影。我尝试了选择器、项目和样式的多种XML安排,但都没有成功。您的问题是使用@drawable解决,而不是使用@style 创建一个包含一个按钮的xml文件 <Button android:id="@+id/button1" android:layout_cente

有没有办法让选择器选择可以在使用@style的布局中使用的样式元素?具体地说,我正试图根据state_pressed、state_focused和state_selected更改TextView元素,例如颜色和阴影。我尝试了选择器、项目和样式的多种XML安排,但都没有成功。

您的问题是使用@drawable解决,而不是使用@style

创建一个包含一个按钮的xml文件

<Button android:id="@+id/button1"
        android:layout_centerHorizontal="true" android:layout_centerVertical="true"
        android:layout_height="50dip" android:layout_width="150dip"
        android:text="Click To Check Style" android:background="@drawable/ef_button"></Button>

试试看..

您到底想实现什么,到目前为止您尝试了什么?我希望文本阴影在按下状态时改变
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <!--  <color android:color="#800517" />-->
        <shape>
            <gradient android:startColor="#FFFF00" android:endColor="#AF7817"
                android:angle="270" />
            <stroke android:width="5dp" android:color="#747170" />
            <corners android:radius="5dp" />
            <padding android:left="10dp" android:top="10dp"
                android:right="10dp" android:bottom="10dp" />

        </shape>
    </item>
    <item android:state_focused="true">
        <!--  <color android:color="#00FFFF" />-->
        <shape>
            <gradient android:endColor="#F433FF" android:startColor="#F6358A"
                android:angle="270" />
            <stroke android:width="5dp" android:color="#747170" />
            <corners android:radius="5dp" />
            <padding android:left="10dp" android:top="10dp"
                android:right="10dp" android:bottom="10dp" />
        </shape>

    </item>
    <item>
        <!-- <color android:color="#FFFFFF" /> -->
        <shape>
            <gradient android:endColor="#A0CFEC" android:startColor="#736AFF"
                android:angle="270" />
            <stroke android:width="5dp" android:color="#747170" />
            <corners android:radius="5dp" />
            <padding android:left="10dp" android:top="10dp"
                android:right="10dp" android:bottom="10dp" />
        </shape>

    </item>
</selector>
TxtVw.setClickable(true);
TxtVw.setFocusable(true);