代码实现selector的StateListDrawable(选择器),定义xml中的selector,AnimatedStateListDrawable

> AnimatedStateListDrawable,Android 5.0
  AnimatedStateListDrawable是在API21提出,针对于Android 5.0。Drawable包含一组可绘制的关键帧,其中当前显示的关键帧是基于当前状态集来选择的。 关键帧之间的动画可以可选地使用过渡元素来定义。
  AnimatedStateListDrawable- https://www.jianshu.com/p/d1fdfe546595  点击图片之后,会经过几个颜色变化,但是并不会停止到你设定的off状态的那个drawable,但是会停止到你设置的<animation-list>中你设置的最后一个<item>上。

<?xml version="1.0" encoding="utf-8"?>
<animated-selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:id="@+id/off" android:drawable="@drawable/test" android:state_checked="false"/>
    <item android:id="@+id/on"  android:drawable="@drawable/xlj" android:state_checked="true"/>
    <transition
        android:fromId="@id/off"
        android:toId="@id/on"
        >
        <animation-list >
            <item android:drawable="@drawable/red_drawable" android:duration="100"/>
            <item android:drawable="@drawable/blue_drawable" android:duration="100"/>
            <item android:drawable="@drawable/green_drawable" android:duration="100"/>
            <item android:drawable="@drawable/xlj" android:duration="60"/>
        </animation-list>
    </transition>
</animated-selector>

<shape xmlns:android="http://schemas.android.com/apk/res/android">
      <!-- 填充颜色 -->
     <solid android:color="@color/transparent" />
      <!--边框-->
     <stroke android:color="@color/white"
       android:width="1.5dp"/>
       <!-- 圆角 -->
     <corners android:radius="1dp" />
</shape>

> 代码编写selector--StateListDrawable使用,selector里(normal,focused,pressed)
  selector.xml会被解析成一个StateListDrawable对象,然后进行解析。selector的本质是一个drawable对象。StateListDrawable 用于组织多个 Drawable 对象。当使用 StateListDrawable 作为目标组件的背景、前景图片时,StateListDrawable 对象所显示的 Drawable 对象会随目标组件的状态的改变而自动切换。
StateListDrawable stateListDrawable = new StateListDrawable();
 stateListDrawable.addState(new int[] {android.R.attr.state_pressed}, recCirclePressStateDrawable);
 stateListDrawable.addState(new int[] {android.R.attr.state_selected}, recCirclePressStateDrawable);
 stateListDrawable.addState(new int[] {android.R.attr.state_focused},
                ContextCompat.getDrawable(context, R.drawable.com_bg_foucs));
 stateListDrawable.addState(new int[] {android.R.attr.drawable}, new ColorDrawable(Color.TRANSPARENT));
return stateListDrawable;

StateListDrawable stateListDrawable = new StateListDrawable();
 //注意该处的顺序,只要有一个状态与之相配,背景就会被换掉
 //所以不要把大范围放在前面了,如果sd.addState(new[]{},normal)放在第一个的话,就没有什么效果了
 stateListDrawable.addState(new int[]{android.R.attr.state_pressed, android.R.attr.state_enabled}, getDrawable(android.R.attr.state_pressed));
 stateListDrawable.addState(new int[]{-android.R.attr.state_enabled}, getDrawable(-android.R.attr.state_enabled));
        //没有任何状态时显示的图片,就设置空集合,默认状态
 stateListDrawable.addState(new int[]{}, getDrawable(android.R.attr.state_enabled));

 其中“-”表示对应的属性为false。android.R.attr.state_selected为true的话,那么-android.R.attr.state_selected为false,注意前面的负号。

public class DrawableUtil {
   public static StateListDrawable addStateListBgDrawable(Context context,
            int idNormal, int idPressed) {
        StateListDrawable drawable = new StateListDrawable();
        drawable.addState(new int[] { android.R.attr.state_selected }, context
                .getResources().getDrawable(idPressed));
        drawable.addState(new int[] { android.R.attr.state_pressed }, context
                .getResources().getDrawable(idPressed));
        drawable.addState(new int[] { android.R.attr.state_enabled }, context
                .getResources().getDrawable(idNormal));
        drawable.addState(new int[] {},
                context.getResources().getDrawable(idNormal));
        return drawable;
    }
}

/**
     * 设置背景选择器
     *
     * @param pressedDraw
     * @param normalDraw
     * @return
     */
    private StateListDrawable getSelector(Drawable normalDraw, Drawable pressedDraw) {
        StateListDrawable stateListDrawable = new StateListDrawable();
        stateListDrawable.addState(new int[]{android.R.attr.state_selected}, pressedDraw);
        stateListDrawable.addState(new int[]{}, normalDraw);
        return stateListDrawable;
    }
  这是在代码中创建selector,创建的类型是StateListDrawable,可以通过addState()为selector添加状态,但是要注意一点添加state时,是有顺序的,stateListDrawable会先执行最新添加的state,如果不是该state,在执行下面的state,如果把大范围的state放到前面添加,会导致直接执行大范围的state,而不执行后面的state。此外,在添加state中,在state前添加“-”号,表示此state为false(例如:-android.R.attr.state_selected),否则为true。

/**
     * 设置shape
     *
     * @param radius
     * @param fillColor
     * @param width
     * @param strokeColor
     * @return
     */
   private GradientDrawable getDrawable(int radius, int fillColor, int width, int strokeColor) {
       GradientDrawable gradientDrawable = new GradientDrawable();
       gradientDrawable.setCornerRadius(radius);
       gradientDrawable.setColor(fillColor);
       gradientDrawable.setStroke(width, strokeColor);
       return gradientDrawable;
   }
  在代码中动态创建GradientDrawable ,可实现drawable样式中shape样式的功能,setColor等于shape中的填充色,setCornerRadius是设置shape中的圆角半径,如果要设置单个角的弧度,可以用setCornerRadii()设置每个角的弧度,setStroke()是描边,需要填写描边的宽和边的颜色。

android 代码编写selector--StateListDrawable使用- https://blog.csdn.net/mackkill/article/details/50979503
Drawable子类之StateListDrawable(选择器)- https://www.cnblogs.com/tc310/p/8978056.html

> xml中的selector里(normal,focused,pressed)

定义xml中的selector里android:state_focused,xml中设置pressed selected focused:@drawable/item_mxbg
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:drawable= "@drawable/item_mxbg2" />
    <item android:state_focused="true" android:drawable= "@drawable/item_mxbg2" />
    <item android:drawable= "@drawable/item_mxbg" />
</selector>

-- Button状态(normal,focused,pressed)显示不同背景图片
<?xml version="1.0" encoding="UTF-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android">
       <!-- pressed -->  
   <item android:state_pressed="true" android:drawable="@drawable/btn_pressed" /> 
       <!-- focused --> 
   <item android:state_focused="true" android:drawable="@drawable/btn_normal" />
       <!-- default --> 
   <item android:drawable="@drawable/btn_normal" /> 
</selector>

<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:state_enabled="true" android:state_window_focused="false"
          android:drawable="@drawable/button_pressed" /> <!-- pressed,enable等多个属性 -->
    <item android:state_focused="true"
          android:drawable="@drawable/button_focused" /> <!-- focused -->
    <item android:state_hovered="true"
          android:drawable="@drawable/button_focused" /> <!-- hovered -->
    <item android:drawable="@drawable/button_normal" /> <!-- default -->
</selector>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值