安卓selector和自定义shape

    xiaoxiao2021-12-14  23

    一、安卓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" />      //虚线的间隔  

    转载请注明原文地址: https://ju.6miu.com/read-963746.html

    最新回复(0)