出路出路,走出去了,总是会有路的。困难苦难,困在家里就是难。
本讲内容:控件背景选择器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