您的位置:首页 > 移动开发 > Android开发

Android笔记之TextView、Button、Imageiew点击selector

2013-09-15 21:06 369 查看
一、Textiew动态改变颜色

概述:

使用selector为Textiew设置各个状态下的颜色

在代码中改变Textiew的颜色

在代码中setTextColor后如何还原selector中对Textiew的设定

1、使用selector为Textiew设置各个状态下的颜色

(1)在res/color文件夹下新建title_color.xml文件

<item android:color="#0099cc"/>表示文本一般状态下的颜色
pressed,focused,selected分别表示:按下,控件获得焦点


<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="true" android:color="#FF0000"/>
<item android:state_focused="true" android:color="#FF0000"/>
<item android:state_pressed="true" android:color="#FF0000"/>
<item android:color="#0099cc"/>
</selector>


(2)layout文件下的TextView:

<TextView
android:id="@+id/hello"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world"
android:textColor="@color/title_color" />


(3)最后,这一步必不可少

private TextView tv1;
...
tv1=(TextView)findViewById(R.id.hello);
tv1.setOnClickListener(null);


也可以给textview的背景设置选择器,而不是textview本身

<TextView
android:id="@+id/notice"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/setting_item_selector"
android:padding="15dp"
android:text="消息通知" />


2、在代码中给Textiew设置颜色

(1)android自带的颜色:tv1.setTextColor(Color.BLUE);

(2)/ res/ values/ colors.xml中定义的颜色:

<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="myGreen">#669966</color>
</resources>


代码:

tv1.setTextColor(getResources().getColor(R.color.title_color));


xml中设置:

android:color="@color/myGreen"


(3)设置在/ res/ color/ title_color.xml下定义的颜色选择器

tv1.setTextColor(getResources().getColorStateList(R.color.title_color));

二、Button动态改变样式

1、 Button的三种状态:(pressed, focused, or niether)

2、在Button里为android:textColor设置颜色选择器,可以动态Button上的文本颜色,使用和Textiew改变颜色基本相同

3、设置Button更美观的样式,并动态变化

(1)4张图片

button.9.png button_disable.9.png button_down.9.png button_highlighted.9.png

(2)新建selector:preview_button_bg.xml

<?xml version="1.0" encoding="utf-8"?>
<selector
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_focused="true" android:state_enabled="true" android:drawable="@drawable/preview_button_highlighted" />
<item android:state_enabled="true" android:state_selected="true" android:drawable="@drawable/preview_button_highlighted" />
<item android:state_enabled="true" android:state_pressed="true" android:drawable="@drawable/preview_button_highlighted" />
<item android:state_enabled="false" android:drawable="@drawable/preview_button_disable" />
<item android:drawable="@drawable/preview_button" />
</selector>


(3) 为Button设置属性:

android:background="@drawable/preview_button_bg"

三、Imageiew的selector

<ImageView
android:id="@+id/imageview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/tab_home_btn">
</ImageView>


selector:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/home_btn_bg" android:state_pressed="true"/>
<item android:drawable="@drawable/icon_home_sel" android:state_selected="true"/>
<item android:drawable="@drawable/icon_home_nor"/>
</selector>


Done!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: