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


    一、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!

  • 相关阅读:
    一个tomcat 增加多个端口
    转项目经理
    apicloud 解析
    七行代码搞定 任意数据库中的数据迁移
    语语
    农家设计图纸
    日期再总结
    X删除数据表的新用法
    c#中各类日期的计算方法,收藏
    IIS 7.5 高并发参数配置
  • 原文地址:https://www.cnblogs.com/xingyyy/p/3323251.html
Copyright © 2020-2023  润新知