有没有办法让选择器选择可以使用@style在布局中使用的样式元素?具体来说,我正在尝试根据state_pressed,state_focused和state_selected更改TextView元素,如颜色和阴影。我已经尝试了多种选择器,项目和样式的XML安排,并且没有成功。
答案 0 :(得分:6)
使用@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>
并在res中的drawable文件夹上创建.. 创建一个ef_button.xml文件
<?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>
同样可以使用TextView ... 设置一些textview属性......
TxtVw.setClickable(true);
TxtVw.setFocusable(true);
试试..