Android样式开发之selector总结

作者: 芒果味的你呀 | 来源:发表于2017-10-30 17:20 被阅读166次

android的样式主要则是通过shape、selector、layer-list、level-list、style、theme等组合实现。

selector篇

主要解决的问题是:处理不同状态下的控件展示不同的需求,比如按钮,正常状态下和按下状态会有不同的效果。想让文字颜色在按钮和正常状态下的变化。

selector标签<selector>,可以添加一个或多个item子标签,而相应的状态是在item标签中定义的。

<item>标签状态有以下这些:

  • android:state_enabled: 设置触摸或点击事件是否可用状态,一般只在false时设置该属性,表示不可用状态
  • android:state_pressed: 设置是否按压状态,一般在true时设置该属性,表示已按压状态,默认为false
  • android:state_selected: 设置是否选中状态,true表示已选中,false表示未选中
  • android:state_checked: 设置是否勾选状态,主要用于CheckBox和RadioButton,true表示已被勾选,false表示未被勾选
  • android:state_checkable: 设置勾选是否可用状态,类似state_enabled,只是state_enabled会影响触摸或点击事件,而state_checkable影响勾选事件
  • android:state_focused: 设置是否获得焦点状态,true表示获得焦点,默认为false,表示未获得焦点
  • android:state_window_focused: 设置当前窗口是否获得焦点状态,true表示获得焦点,false表示未获得焦点,例如拉下通知栏或弹出对话框时,当前界面就会失去焦点;另外,ListView的ListItem获得焦点时也会触发true状态,可以理解为当前窗口就是ListItem本身
  • android:state_activated: 设置是否被激活状态,true表示被激活,false表示未激活,API Level 11及以上才支持,可通过代码调用控件的* setActivated(boolean)方法设置是否激活该控件
  • android:state_hovered: 设置是否鼠标在上面滑动的状态,true表示鼠标在上面滑动,默认为false,API Level 14及以上才支持

关于使用selector,必读的注意事项

  • 定义的xml文件可以作为两种资源使用:drawable和color。

  • 作为drawable资源使用时,放于drawable目录下,item必须指定android:drawable属性;

  • 作为color资源使用时,则放于color目录下,item必须指定android:color属性。

  • android:drawable属性除了引用@drawable资源,也可以引用@color颜色值;但android:color只能引用@color;

  • item是从上往下匹配的,如果匹配到一个item那它就将采用这个item,而不是采用最佳匹配的规则;所以设置默认的状态,一定要写在最后,如果写在前面,则后面所有的item都不会起作用了。

  • API Level 11及以上支持selector标签下有两个比较有用的属性:(添加了下面两个属性之后,则会在状态改变时出现淡入淡出效果)

    • android:enterFadeDuration 状态改变时,新状态展示时的淡入时间,以毫秒为单位

    • android:exitFadeDuration 状态改变时,旧状态消失时的淡出时间,以毫秒为单位

  • listview

实例:

1.以下是bg_btn_selector.xml的代码,用于按钮的背景:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 当前窗口失去焦点时 -->
    <item android:drawable="@drawable/bg_btn_lost_window_focused" android:state_window_focused="false" />
    <!-- 不可用时 -->
    <item android:drawable="@drawable/bg_btn_disable" android:state_enabled="false" />
    <!-- 按压时 -->
    <item android:drawable="@drawable/bg_btn_pressed" android:state_pressed="true" />
    <!-- 被选中时 -->
    <item android:drawable="@drawable/bg_btn_selected" android:state_selected="true" />
    <!-- 被激活时 -->
    <item android:drawable="@drawable/bg_btn_activated" android:state_activated="true" />
    <!-- 默认时 -->
    <item android:drawable="@drawable/bg_btn_normal" />
</selector>

2.text_btn_selector.xml的代码,用于按钮的文本颜色:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 当前窗口失去焦点时 -->
    <item android:color="@android:color/black" android:state_window_focused="false" />
    <!-- 不可用时 -->
    <item android:color="@android:color/background_light" android:state_enabled="false" />
    <!-- 按压时 -->
    <item android:color="@android:color/holo_blue_light" android:state_pressed="true" />
    <!-- 被选中时 -->
    <item android:color="@android:color/holo_green_dark" android:state_selected="true" />
    <!-- 被激活时 -->
    <item android:color="@android:color/holo_green_light" android:state_activated="true" />
    <!-- 默认时 -->
    <item android:color="@android:color/white" />
</selector>

3.引用

<Button 
    android:id="@+id/btn_default"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="8dp"
    android:background="@drawable/bg_btn_selector"
    android:text="默认按钮"
    android:textColor="@color/text_btn_selector" />

相关文章

网友评论

    本文标题:Android样式开发之selector总结

    本文链接:https://www.haomeiwen.com/subject/nosypxtx.html