安卓selector和自定义shape

来源:互联网 发布:刷机平台软件 编辑:程序博客网 时间:2024/06/06 01:24

一、安卓Selector背景选择器
1.在drawable中配置Android的selector。
<?xml version="1.0" encoding="utf-8" ?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 默认时的背景图片-->
<item android:drawable="@drawable/pic1" />
<!-- 没有焦点时的背景图片-->
<item android:state_window_focused="false" android:drawable="@drawable/pic1" />
<!-- 非触摸模式下获得焦点并单击时的背景图片-->
<item android:state_focused="true"  android:state_pressed="true"
  android:drawable="@drawable/pic2" />
<!-- 触摸模式下单击时的背景图片-->
<item android:state_focused="false" android:state_pressed="true"
  android:drawable="@drawable/pic3" />
<!--选中时的图片背景-->
<item android:state_selected="true" android:drawable="@drawable/pic4" />
<!--获得焦点时的图片背景-->
<item android:state_focused="true" android:drawable="@drawable/pic5" />
</selector>
2.android:listSelector或者android:background属性设置
3.去除listView原有背景android:cacheColorHint="@android:color/transparent" 


二、安卓shape自定义背景几何图形
1.shape基本属性(rectangle、oval、line、ring)
android:shape=["rectangle" | "oval" | "line" | "ring"]   
shape的形状,默认为矩形,可以设置为矩形(rectangle)、椭圆形(oval)、线性形状(line)、环形(ring)   
下面的属性只有在android:shape="ring时可用:   
android:innerRadius         尺寸,内环的半径。   
android:innerRadiusRatio    浮点型,以环的宽度比率来表示内环的半径,   
android:thickness           尺寸,环的厚度   
android:thicknessRatio      浮点型,以环的宽度比率来表示环的厚度,例如,如果android:thicknessRatio="2",   
android:useLevel            boolean值,如果当做是LevelListDrawable使用时值为true,否则为false. 

2.子标签及所具有的基本属性(corners、gradient、padding、size、solid、stroke)
<corners    //定义圆角,其中radius与其它四个并不能共同使用。  
android:radius="dimension"      //全部的圆角半径   
android:topLeftRadius="dimension"   //左上角的圆角半径   
android:topRightRadius="dimension"  //右上角的圆角半径   
android:bottomLeftRadius="dimension"    //左下角的圆角半径   
android:bottomRightRadius="dimension" />    //右下角的圆角半径  
<solid  android:color="color" />   //solid用以指定内部填充色
<gradient  
android:type=["linear" | "radial" | "sweep"]    //共有3中渐变类型,线性渐变(默认)/放射渐变/扫描式渐变   
android:angle="integer"     //渐变角度,必须为45的倍数,0为从左到右,90为从上到下   
android:centerX="float"     //渐变中心X的相当位置,范围为0~1   
android:centerY="float"     //渐变中心Y的相当位置,范围为0~1   
android:startColor="color"   //渐变开始点的颜色   
android:centerColor="color"  //渐变中间点的颜色,在开始与结束点之间   
android:endColor="color"    //渐变结束点的颜色   
android:gradientRadius="float"  //渐变的半径,只有当渐变类型为radial时才能使用   
android:useLevel=["true" | "false"] />  //使用LevelListDrawable时就要设置为true。设为false时才有渐变效果   
<stroke        
android:width="dimension"   //描边的宽度   
android:color="color"   //描边的颜色   
// 以下两个属性设置虚线   
android:dashWidth="dimension"   //虚线的宽度,值为0时是实线   
android:dashGap="dimension" />      //虚线的间隔  

0 0
原创粉丝点击