【待处理】Android设置Selector不同状态下颜色及图片

Selector常用状态:

      android:state_selected 控件选中状态,可以为true或false

      android:state_focused 控件获得焦点状态,可以为true或false

      android:state_pressed 控件点击状态,可以为true或false

      android:state_enabled 控件使能状态,可以为true或false

      android:state_checkable 控件可勾选状态,可以为true或false

      android:state_checked 控件勾选状态,可以为true或false

 

设置不同状态下颜色:

      btn_enabled.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">   

<!-- 默认 -->
    <item android:state_enabled="true">
        <color android:color="#e25050" />
        </item>
 <item android:state_enabled="false">
        <color android:color="#908e8e" />
        </item>
</selector>

设置不同状态下图片:

    btn_pressed.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:drawable="@drawable/btn_arrow_left_pressed" />
    <item android:state_window_focused="true" android:state_focused="true" android:drawable="@drawable/btn_arrow_left_pressed" />
    <item android:state_window_focused="false" android:state_focused="false" android:drawable="@drawable/btn_arrow_left_normal" />

</selector>




我们在定义一个drawable的时候可以通过xml定义的drawable对象。它使得一个图片能在不同的状态下显示不同的图案,比如一个Button,它有pressed,focused,或者其它状态,通过使用state list drawable,你就可以为每种状态提供不同的图片。

先看一个范例:

 

XML file saved at res/drawable/button.xml:

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

his layout XML applies the state list drawable to a Button:

<Buttonandroid:layout_height="wrap_content"android:layout_width="wrap_content"android:background="@drawable/button"/>

ndroid:drawable 放一个drawable资源
android:state_pressed 是否按下,如一个按钮触摸或者点击。
android:state_focused 是否取得焦点,比如用户选择了一个文本框。
android:state_hovered 光标是否悬停,通常与focused state相同,它是4.0的新特性
android:state_selected 被选中,它与focus state并不完全一样,如一个list view 被选中的时候,它里面的各个子组件可能通过方向键,被选中了。
android:state_checkable 组件是否能被check。如:RadioButton是可以被check的。
android:state_checked 被checked了,如:一个RadioButton可以被check了。
android:state_enabled 能够接受触摸或者点击事件
android:state_activated 被激活(例子)
android:state_window_focused 应用程序是否在前台,当有通知栏被拉下来或者一个对话框弹出的时候应用程序就不在前台了

 

注意:如果有多个item,那么程序将自动从上到下进行匹配,最先匹配的将得到应用。(不是通过最佳匹配)
如果一个item没有任何的状态说明,那么它将可以被任何一个状态匹配。

 

详细的请看官方的API,那里写的更详细~!http://developer.android.com/guide/topics/resources/drawable-resource.html#StateList




Android之代码设置selector

以一个textView为例:



TextView tv = new TextView(UIUtils.getContext());
            tv.setText(data);
            tv.setTextSize(16);
            tv.setTextColor(Color.WHITE);
            tv.setGravity(Gravity.CENTER);
            tv.setClickable(true);

            int padding = DensityUtil.dip2px(UIUtils.getContext(), 6);
            tv.setPadding(padding, padding, padding, padding);

            GradientDrawable normalDrawable = new GradientDrawable();
            //状态选择器
            StateListDrawable stateListDrawable = new StateListDrawable();


            normalDrawable.setColor(Color.RED);
            normalDrawable.setShape(GradientDrawable.RECTANGLE);
            normalDrawable.setCornerRadius(DensityUtil.dip2px(UIUtils.getContext(), 5));

            //按下时的drawable
            GradientDrawable pressedDrawable = new GradientDrawable();
            pressedDrawable.setColor(Color.DKGRAY);
            pressedDrawable.setShape(GradientDrawable.RECTANGLE);
            pressedDrawable.setCornerRadius(DensityUtil.dip2px(UIUtils.getContext(), 5));
            //给状态选择器添加状态
            stateListDrawable.addState(new int[]{android.R.attr.state_pressed},pressedDrawable);
            stateListDrawable.addState(new int[]{}, normalDrawable);

            tv.setBackgroundDrawable(stateListDrawable);

            tv.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Toast.makeText(UIUtils.getContext(), data, Toast.LENGTH_SHORT).show();
                }
            });





新加评论 评论标题:

文章评论

        2018-01-12    
    修改 删除
    评论测试: stateListDrawable.addState(new int[]{}, normalDrawable); tv.setBackgroundDrawable(stateListDrawable); tv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.makeText(UIUtils.getContext(), data, Toast.LENGTH_SHORT).show(); } });

        2018-01-12    
    修改 删除

    评论测试:

        stateListDrawable.addState(new int[]{}, normalDrawable); 

       tv.setBackgroundDrawable(stateListDrawable); 

          tv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) 

         { Toast.makeText(UIUtils.getContext(), data, Toast.LENGTH_SHORT).show(); } }); 

        2018-01-12 09:00:34.0
评论列表