使用xml文件建立Button,EditText以及文字的点击效果Selector

一直习惯使用png图片进行背景设置,虽然有时候使用点9图会帮助我们建立较好的交互,但是点9图在绘制方面还是会较为繁琐,然而使用xml绘制则会更加简单,适合程序员操作,所以,如果能用xml直接配置出来的背景,就不必要麻烦点9;下面列举一些常用的背景制作;

EditText  带边框选中高亮的背景

res/drawable/edit_selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    
    <item android:state_focused="false" >
        <shape>
            <stroke
                android:width="2dp"
                android:color="#22FFFFFF" />        
            <corners
                android:radius="2dp" />
		</shape>
    </item>
    
     <item android:state_focused="true" >
         <shape>
            <stroke
                android:width="2dp"
                android:color="#FFFFFFFF" />    
            <corners
                android:radius="2dp" />
		</shape>
     </item>

</selector>


或者分成3个文件写:

res/drawable/edit_selector.xml

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

edit_bg_off.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
            <stroke
                android:width="2dp"
                android:color="#22FFFFFF" />         
            <corners
                android:radius="2dp" />
</shape>

edit_bg_on.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
            <stroke
                android:width="2dp"
                android:color="#FFFFFFFF" />        
            <corners
                android:radius="2dp" />
</shape>

效果: 

    

如果想修改分别修改圆角,修改<corners/>标签即可:

<corners
android:topLeftRadius="0dp"
android:topRightRadius="0dp"
android:bottomLeftRadius="15dp"
android:bottomRightRadius="15dp" />


从上面可以看出,Selector中,android:drawable可以被完全替代成<shape/>标签


Button 文字颜色设置点击效果Selector

res/drawable/text_color_selector.xml

res/drawable/text_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="@color/red"/>
    <item android:state_pressed="false" android:color="@color/black"/>
</selector>

android:textColor="@drawable/text_color_selector"

暂时没有找到其他方法设置,有待补充;


Button 带描边,背景渐变,边角带弧度

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" >
        <shape>
            <gradient
                android:startColor="#ff8c00"
                android:endColor="#FFFFFF"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#dcdcdc" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>

    <item android:state_focused="true" >
        <shape>
            <gradient
                android:startColor="#ffc2b7"
                android:endColor="#ffc2b7"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#dcdcdc" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>

    <item>        
        <shape>
            <gradient
                android:startColor="#ff9d77"
                android:endColor="#ff9d77"
                android:angle="270" />
            <stroke
                android:width="2dp"
                android:color="#fad3cf" />
            <corners
                android:radius="2dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>
</selector>



本例参考:http://kofi1122.blog.51cto.com/2815761/521605


纯色背景Button点击效果

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

    <item android:state_pressed="true"><color android:color="#FFFF0000" />
    </item>
    <item android:state_pressed="false"><color android:color="#FF00FFFF" />
    </item>

</selector>

或者这样:

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

    <item android:drawable="@color/blue" android:state_pressed="false"/>
    <item android:drawable="@color/red" android:state_pressed="true"/>

</selector>

两种效果均是一样:

点击前:

点击后:



四个角不同弧度的圆角矩形

可以看上面的EditText背景设置

修改标签:

<corners
android:topLeftRadius="0dp"
android:topRightRadius="0dp"
android:bottomLeftRadius="15dp"
android:bottomRightRadius="15dp" />


本文来自CSDN博客 转载请联系作者
注明出处 http://blog.csdn.net/dreamintheworld/article/details/39668601


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android中,Selector是一个用于定义不同状态下View的样式和背景XML文件。它可以根据View的不同状态(如按下、选中、禁用等)来设置不同的样式和背景。下面是Selector的用法详解及实例。 1. 创建selector xml文件 在res/drawable目录下创建一个XML文件,文件名以selector_开头,如selector_button.xml,然后在文件中定义不同状态下View的样式和背景。例如: ```xml <selector xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 按下状态 --> <item android:drawable="@drawable/button_pressed" android:state_pressed="true" /> <!-- 选中状态 --> <item android:drawable="@drawable/button_selected" android:state_selected="true" /> <!-- 默认状态 --> <item android:drawable="@drawable/button_normal" /> </selector> ``` 2. 在View中应用selector 在布局文件中使用android:background属性来应用selector,如: ```xml <Button android:id="@+id/btn_login" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="登录" android:background="@drawable/selector_button" /> ``` 这样,当Button的状态改变时,它的背景就会自动变化。 除了android:background属性外,还可以在TextView、EditText等View中使用android:textColor属性来应用selector,如: ```xml <TextView android:id="@+id/tv_text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" android:textColor="@drawable/selector_text_color" /> ``` 其中,selector_text_color.xml文件的内容如下: ```xml <selector xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 按下状态 --> <item android:color="@color/colorAccent" android:state_pressed="true" /> <!-- 选中状态 --> <item android:color="@color/colorPrimary" android:state_selected="true" /> <!-- 默认状态 --> <item android:color="@android:color/black" /> </selector> ``` 这样,当TextView的状态改变时,它的文字颜色就会自动变化。 以上就是SelectorAndroid中的用法详解及实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值