安卓开发中selector的使用方法详解,让你的按钮活起来

相信熟悉android开发的童鞋对selector选择器都有一定的了解,在程序开发中我们常常使用selector来做组件的背景,这样我们就可以不需要使用代码来控制组件在不同状态下不同背景或 图片的变化,使用非常方便。那对于初学者而言对selector又了解多少呢?对selector的使用又有怎样的认识呢?

    为了帮助广大初学者更好的认识、了解和掌握selector选择器的用法,下面小编在网上搜罗了一篇写得非常详细的有关selector具体用法的文章,一起来看看吧。

 

selector的定义

 

selector就是状态列表(StateList),算是安卓开发中比较基础的知识点, 它分为两种,一种Color-Selector 和Drawable-Selector。下面我们分别来看看。

 

Color-Selector

color-selector ,顾名思义就是颜色状态列表,可以跟color一样使用,颜色会随着组件的状态而改变。文件的位置存储于

 

/res/color/filename.xml

 

在Java中使用是:R.color.filename

在XML中使用是:@[package]color/filename

 

具体语法如下:

 

<?xml version="1.0" encoding="utf-8"?>

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

    <item

        android:color="hex_color"               //颜色值,#RGB,$ARGB,#RRGGBB,#AARRGGBB

        android:state_pressed=["true" | "false"]//是否触摸

        android:state_focused=["true" | "false"]//是否获得焦点

        android:state_selected=["true" | "false"]//是否被状态

        android:state_checkable=["true" | "false"]//是否可选

        android:state_checked=["true" | "false"]//是否选中

        android:state_enabled=["true" | "false"]//是否可用

        android:state_window_focused=["true" | "false"] />//是否窗口聚焦

</selector>

 

下面通过一个具体示例为大家展示:

 

在/res/color/文件夹下新建test_color_selector.xml

 

<?xml version="1.0" encoding="utf-8"?>

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

    <item android:state_pressed="true"

          android:color="#ffff0000"/> <!-- pressed -->

    <item android:state_focused="true"

          android:color="#ff0000ff"/> <!-- focused -->

    <item android:color="#ff000000"/> <!-- default -->

</selector>

 

调用:

 

    <Button

        android:id="@+id/bt_about"

        style="@style/Button_style"

        android:layout_width="250dp"

        android:layout_height="50dp"

        android:layout_margin="5dp"

        android:textColor="@color/test_color_selector"

        android:text="@string/about" />

 

通过如上代码,实现的效果如下,大家可以注意一下下图中“关于”两字字体的颜色变化:

安卓开发中selector的使用方法详解.gif

 

Drawable-Selector

 

drawable-selector 是背景图状态列表,可以跟图片一样使用,背景会根据组件的状态变化而变化。文件存储于

 

/res/drawable/filename.xml

 

Java中调用:R.drawable.filename

XML中调用:@[package:]drawable/filename

 

drawable-selector的具体语法如下:

 

<?xml version="1.0" encoding="utf-8"?>

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

    android:constantSize=["true" | "false"]//drawable的大小是否当中状态变化,true表示是变化,false表示不变换,默认为false

    android:dither=["true" | "false"]//当位图与屏幕的像素配置不一样时(例如,一个ARGB为8888的位图与RGB为555的屏幕)会自行递色(dither)。设置为false时不可递色。默认true

    android:variablePadding=["true" | "false"] >//内边距是否变化,默认false

    <item

        android:drawable="@[package:]drawable/drawable_resource"//图片资源

        android:state_pressed=["true" | "false"]//是否触摸

        android:state_focused=["true" | "false"]//是否获取到焦点

        android:state_hovered=["true" | "false"]//光标是否经过

        android:state_selected=["true" | "false"]//是否选中

        android:state_checkable=["true" | "false"]//是否可勾选

        android:state_checked=["true" | "false"]//是否勾选

        android:state_enabled=["true" | "false"]//是否可用

        android:state_activated=["true" | "false"]//是否激活

        android:state_window_focused=["true" | "false"] />//所在窗口是否获取焦点

</selector>

 

下面我们仍然通过一个具体的示例展示:

 

<?xml version="1.0" encoding="utf-8"?>

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

    <item android:state_selected="true" android:drawable="@drawable/button_bg_press" />

    <item android:state_focused="true" android:drawable="@drawable/button_bg_press" />

    <item android:state_pressed="true" android:drawable="@drawable/button_bg_press"  />

    <item android:drawable="@drawable/button_bg_normol"  />

</selector>

 

调用:

 

 <Button

        android:id="@+id/bt_about"

        style="@style/Button_style"

        android:background="@drawable/button_selector"

        android:layout_width="250dp"

        android:layout_height="50dp"

        android:layout_margin="5dp"

        android:textColor="@color/test_color_selector"

        android:text="@string/about" />

 

通过以上的代码,我们可以实现下图效果,这里大家可以注意一下button背景的变化。

安卓开发中selector的使用方法详解.gif

 

      在安卓开发中,selector是实现View状态变化后背景与颜色变化的很好的方式,可简化很多逻辑代码。大家在android编程中不妨可以试试selector的使用,掌握它的用法,还能帮助大家设计出更漂亮的界面哦~~如果大家在使用中,还有任何疑问,欢迎去“学习问答”版块提出。

 

相关文章:《Android内核开发之repo工具详解

文章来源:CSDN

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值