android背景选择器selector用法

出路出路,走出去了,总是会有路的。困难苦难,困在家里就是难。


本讲内容:控件背景选择器selector的用法


selector选择器可以让你切换自定义的背景风格,背景可以使颜色或者图片资源。


一、selector结合使用shape,这样就能做出更加酷炫效果

shape的一些属性

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
</shape>
这里设置shape的形状为矩形

<shape>   
    <!-- 实心 -->    
    <solid android:color="#ff0000"/>    
    <!-- 渐变 -->    
    <gradient    
        android:startColor="#ff0000"    
        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> 

solid:实心,就是填充的意思
android:color指定填充的颜色

gradient:渐变
android:startColor和android:endColor分别为起始和结束颜色,ndroid:angle是渐变角度,必须为45的整数倍。
另外渐变默认的模式为android:type="linear",即线性渐变,可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"。

stroke:描边
android:width="2dp" 描边的宽度,android:color 描边的颜色。
我们还可以把描边弄成虚线的形式,设置方式为:android:dashWidth="5dp"    android:dashGap="3dp"
其中android:dashWidth表示'-'这样一个横线的宽度,android:dashGap表示之间隔开的距离。

corners:圆角
android:radius为角的弧度,值越大角越圆。
我们还可以把四个角设定成不同的角度,方法为:

<corners    
        android:topRightRadius="20dp"    右上角    
        android:bottomLeftRadius="20dp"    右下角    
        android:topLeftRadius="1dp"    左上角    
        android:bottomRightRadius="0dp"    左下角    
/> 

示例一、



下面是res/layout/activity_main.xml 布局文件:

下面是res/layout/activity_main.xml 布局文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:background="@drawable/bg"<!-- 调用方法 -->
    tools:context="com.example.test1.MainActivity$PlaceholderFragment" >
    
    <TextView 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="你好"
        android:textSize="50sp"/>
    
</LinearLayout>

下面是res/drawable/bg.xml 文件:

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

    <stroke android:width="4dp" android:color="#f0f" /><!-- 描边,width是边得宽度,color是颜色 -->  
    
    <padding android:left="40dp" android:top="80dp"
        android:right="4dp" android:bottom="4dp"/>  <!-- 四周边距 -->  
        
    <corners android:radius="10dp"/>    <!-- 边角圆弧的半径 -->  

</shape>


示例二、

                

                 一般状态:                        按下状态:

下面是res/drawable/button_selector.xml 文件:(使用color:)

<?xml version="1.0" encoding="UTF-8"?>    
<selector xmlns:android="http://schemas.android.com/apk/res/android">    
    <!-- 选中时的颜色 -->  
    <item android:state_selected="true">
        <shape >
            <solid android:color="#ff0"/>
        </shape>
    </item>  
    
    <!-- 获得焦点时的颜色 -->  
    <item android:state_focused="true">
        <shape >
            <solid android:color="#fff"/>
        </shape>
    </item>  
    
    <!-- 点击时的颜色 -->  
     <item android:state_pressed="true" >
        <shape>
            <!-- 渐变 -->
            <gradient
                android:startColor="#000000"
                android:endColor="#FFFFFF"
                android:type="radial"
                android:gradientRadius="50" />
            <!-- 描边 -->
            <stroke
                android:width="8dp"
                android:color="#dcdcdc"
                android:dashWidth="5dp" 
                android:dashGap="3dp" />
            <!-- 圆角 -->
            <corners
                android:radius="8dp" />
            <padding
                android:left="10dp"
                android:top="10dp"
                android:right="10dp"
                android:bottom="10dp" />
        </shape>
    </item>
    
    <!-- 默认的颜色 -->  
    <item>
         <shape >
            <solid android:color="#f0f"/>
        </shape>
    </item>  
</selector>   

<item android:state_pressed="true" android:color="#FF0" /> 网上很多这样写会报错


下面是res/drawable/button_selector.xml 文件:(使用drawable:)

<?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/g11" />    
    <!-- 获取焦点时的背景图 -->  
    <item android:state_focused="true"    
        android:drawable="@drawable/g12" />    
    <!-- 默认的背景图 -->  
    <item android:drawable="@drawable/o" />    
</selector>   

下面是res/layout/activity_main.xml 布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.test1.MainActivity$PlaceholderFragment" >
    
    <Button 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TestShapeButton"
        android:background="@drawable/button_selector"/><span style="background-color: rgb(248, 248, 248); color: rgb(0, 130, 0); font-family: Consolas, 'Courier New', Courier, mono, serif; line-height: 18px;"><!-- 调用方法 --></span>
        android:focusable="true"
</LinearLayout>

注意:这个方法可以用来设置Button背景的选择效果,也可以用来设置Button上面文字的选择效果。

也可以为button增加style,如下

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.test1.MainActivity$PlaceholderFragment" >
    
    <Button 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TestShapeButton"
        android:focusable="true"
        style="@style/ButtonText"/>
    
</LinearLayout>

然后在res/values下面定义这个style:

<?xml version="1.0" encoding="utf-8"?>  
    <resources>  
        <style name="ButtonText">  
            <item name="android:layout_width">fill_parent</item>  
            <item name="android:layout_height">wrap_content</item>  
            <item name="android:textColor">#ffffff</item>  
            <item name="android:gravity">center</item>  
            <!-- 阴影风格,如粗体,斜体 -->  
            <item name="android:textStyle">bold</item>  
            <!-- 阴影颜色,这里可以处理阴影,外发光,描边等效果 -->  
            <item name="android:shadowColor">#000000</item>  
            <!-- 阴影x偏移 -->  
            <item name="android:shadowDx">1</item>  
            <!-- 阴影y偏移 -->  
            <item name="android:shadowDy">1</item>  
            <!-- 阴影半径 -->  
            <item name="android:shadowRadius">2</item>  
            <!-- 背景 -->  
            <item name="android:background">@drawable/button_selector</item>  
        </style>  
    </resources>  


Take your time and enjoy it


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值