添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

虽然开发过程中,一直都在使用shape、selector,但总是现学现用—项目中需要的时候才去学习一下,用完就忘了,而且都是针对项目中需要的内容进行学习,而没有对这些属性进行全面深入的理解和总结,所以就对这些常用的基础知识点进行总结归纳。

首先对着三种drawable的功能简单介绍一下:

shape —— 用于设置控件的自身属性的效果形状,这些效果不会因为状态的改变而改变,比如圆形,圆角,边框效果等等。

selector —— 顾名思义就是选择器,所以使用Selector设置的是跟状态有关的效果,比如点击时,获取焦点时,选中时等所展现的控件效果。

layer-list —— 用于控件效果的层叠。每一个item都可以实现独立的效果,比如shape或者selector,甚至item中也可以再包含一个layer-list。

1. shape

<?xml version="1.0" encoding="utf-8"?> 
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
    android:shape=["rectangle" | "oval" | "line" | "ring"] > 矩形|椭圆|线|圆环
    <gradient 渐变  
       android:angle="integer"                       渐变角度,0从左到右,90表示从下到上,数值为45的整数倍,默认为0android:centerX="integer"                     渐变中心X(相对drawable本身)位置,范围为01   
       android:centerY="integer"                     渐变中心Y(相对drawable本身)位置,范围为01   
       android:centerColor="integer"                 中间颜色
       android:endColor="color"                      结束颜色          
       android:gradientRadius="integer"              渐变的半径,只有当渐变类型为radial时才能使用
       android:startColor="color"                    起始颜色  
       android:type=["linear" | "radial" | "sweep"]  渐变的样式 liner线性渐变 radial环形渐变 sweep  
       android:usesLevel=["true" | "false"] /> 
    <solid 填充          
        android:color="color" 填充的颜色 /> 
    <stroke 描边
        android:width="integer"     描边的宽度  
        android:color="color"       描边的颜色  
        android:dashWidth="integer" 表示横线的宽度(虚线)
        android:dashGap="integer"   表示横线之间的距离(虚线)   /> 
    <padding 
       android:left="integer" 
       android:top="integer" 
       android:right="integer" 
       android:bottom="integer" /> 
    <corners 圆角  
        android:radius="integer"            圆角的半径 值越大角越圆  
        android:topLeftRadius="integer"     左上圆角半径  
        android:topRightRadius="integer"    右上圆角半径  
        android:bottomLeftRadius="integer"  左下圆角角半径  
        android:bottomRightRadius="integer" 右下圆角角半径  /> 
</shape>

实例1,矩形/圆形,渐变色:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
    <stroke android:width="5dp"
            android:color="@color/colorAccent"/>
    <corners android:bottomLeftRadius="15dp"
             android:bottomRightRadius="15dp"
             android:topLeftRadius="25dp"
             android:topRightRadius="25dp"/>
    <gradient android:type="radial"
              android:gradientRadius="150"
              android:startColor="@color/colorGreen"
              android:centerColor="@color/colorGray"
              android:endColor="@color/colorBlack"/>
</shape>

效果1:android:shape=”rectangle”,gradientRadius = 150
这里写图片描述

效果2:android:shape=”rectangle”,gradientRadius = 80
这里写图片描述

效果3:android:shape=”oval”,gradientRadius = 150
这里写图片描述

效果4:android:shape=”oval”,gradientRadius = 80
这里写图片描述

实例2,扇形,渐变色:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <gradient android:type="sweep"
              android:centerX="0.5"
              android:centerY="0.5"
              android:startColor="@color/colorGreen"
              android:centerColor="@color/colorAccent"
              android:endColor="@color/colorBlack"/>
</shape>

效果1:android:centerX=”0.5”,android:centerY=”0.5”
这里写图片描述

效果2:android:centerX=”0.3”,android:centerY=”0.6”
这里写图片描述

实例3,圆环

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
       android:shape="ring"
       android:useLevel="false">
    <gradient android:type="sweep"
              android:startColor="@color/colorGreen"
              android:centerColor="@color/colorAccent"
              android:endColor="@color/colorBlack"/>
</shape>

实例4,自定义ProgressBar进度条

将上面的shape外层,增加rotate属性,并将这个shape设置到progressBar中。

<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
        android:fromDegrees="0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toDegrees="1080.0">
    <shape
        android:shape="ring"
        android:useLevel="false">
        <gradient
            android:centerColor="@color/colorAccent"
            android:endColor="@color/colorBlack"
            android:startColor="@color/colorGreen"
            android:type="sweep"/>
    </shape>
</rotate>
    <ProgressBar
        android:id="@+id/socket_progress_bar"
        style="?android:attr/progressBarStyle"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:indeterminate="false"
        android:indeterminateDrawable="@drawable/test_shape_radial"/>

效果:
height="388" width="222" src="https://img-my.csdn.net/uploads/201711/21/1511246856_2225.gif">

注意:无论这里shape取什么形状,他的子标签都是可用的,但有时并不会有效果,比如在shape为椭圆时,那corners标签就不会有效果,很显然的道理。

2. selector
根据不同的选定状态来定义不同的现实效果
分为四大属性:
android:state_selected 是否选中
android:state_focused 是否获得焦点
android:state_pressed 是否按压
android:state_enabled 设置是否响应事件,指所有事件

另:
android:state_window_focused 默认时的背景图片

各属性说明

<?xml version="1.0" encoding="utf-8" ?>       
<selector xmlns:Android="http://schemas.android.com/apk/res/android">      
<!-- 没有焦点时的背景图片 -->      
   Android:state_window_focused="false"        
   android:drawable="@drawable/pic_blue"   
<!-- 非触摸模式下获得焦点并单击时的背景图片 -->      
   Android:state_focused="true"   
   android:state_pressed="true"     
   android:drawable= "@drawable/pic_red"   
<!-- 触摸模式下单击时的背景图片-->      
   Android:state_focused="false"   
   Android:state_pressed="true"     
   Android:drawable="@drawable/pic_pink"   
<!--选中时的图片背景-->      
   Android:state_selected="true"   
   android:drawable="@drawable/pic_orange"   
<!--获得焦点时的图片背景-->      
   Android:state_focused="true"   
   Android:drawable="@drawable/pic_green"   
   <!-- 默认时的背景图片-->      
<item Android:drawable="@drawable/pic1" />              
</selector>   

注意:1. drawable中可以使用图片,也可以使用自定义的shape;2. item是从上往下匹配的,如果匹配到一个item那它就将采用这个item,而不是采用最佳匹配的规则;所以设置默认的状态,一定要写在最后,如果写在前面,则后面所有的item都不会起作用了。

3. layer-list
layer-list可以添加多个item子节点,每个item子节点对应一个drawable资源,按照item从上到下的顺序叠加在一起,再通过设置每个item的偏移量就可以看到阴影等效果了。layer-list的item可以通过下面四个属性设置偏移量:

android:top 顶部的偏移量
android:bottom 底部的偏移量
android:left 左边的偏移量
android:right 右边的偏移量
实例:在selector中增加layer-list节点,设置点击阴影效果

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <layer-list>
            <!--深绿色背景-->
            <item android:drawable="@color/colorGreenDark" android:left="5dp" android:top="5dp"/>
            <!--前绿色背景-->
            <item android:bottom="5dp" android:drawable="@color/colorGreenLight" android:right="5dp"/>
        </layer-list>
    </item>
        <layer-list>
            <!--灰色背景-->
            <item android:drawable="@color/colorGray" android:left="5dp" android:top="5dp"/>
            <!--前白色背景-->
            <item android:bottom="5dp" android:drawable="@color/colorWhite" android:right="5dp"/>
        </layer-list>
    </item>
</selector>

效果:
height="388" width="222" src="https://img-my.csdn.net/uploads/201711/21/1511252422_9696.gif">

所以,在实际使用中,layer-list可以提供更丰富,更深层次的UI界面,与selector结合使用,可以实现更绚丽的状态UI。

另外,关于item的用法,也做下总结:
根节点不同时,可设置的属性是会不同的,比如selector下,可以置一些状态属性,而在layer-list下,可以设置偏移量;
就算父节点同样是selector,放在drawable目录和放在color目录下可用的属性也会不同,比如drawable目录下可用的属性为android:drawable,在color目录下可用的属性为android:color;
item的子节点可以为任何类型的drawable类标签,除了上面例子中的shape、color、layer-list,也可以是selector,还有其他没讲过的bitmap、clip、scale、inset、transition、rotate、animated-rotate、lever-list等等。

虽然开发过程中,一直都在使用shape、selector,但总是现学现用—项目中需要的时候才去学习一下,用完就忘了,而且都是针对项目中需要的内容进行学习,而没有对这些属性进行全面深入的理解和总结,所以就对这些常用的基础知识点进行总结归纳。首先对着三种drawable的功能简单介绍一下:shape —— 用于设置控件的自身属性的效果形状,这些效果不会因为状态的改变而改变,比如圆形,圆角,边框效果等等。
< shape >和< selector >在 Android UI设计 中经常用到。比如我们要 自定义 一个圆角Button,点击Button有些效果的变化,就要用到< shape >和< selector >。 可以这样说,< shape >和< selector >在美化控件中的作用是至关重要。 先来看一个例子: 通过xml文件实现 自定义 圆角镂空按...
在实际开发中,我们经常会对控件的样式进行一些修改已满足我们的要求,这时候就会引用 Drawable 资源的样式文件。 1、State List Drawable 资源         State List Drawable 用于组织多个 Drawable 对象。当使用 State List Drawable 作为目标组件的背景、前景图片时, State List Drawable 对象所显示的 Drawab
shape 的优势, Android 开发中,使用 shape 可以方便的帮我们画出背景,相对于png图片来说,使用 shape 可以减少安装包的大小,而且能够更好的适应不同的手机; 1. shape (Gradient Drawable ) shape 顾名思义就是形状的意思,我们在平时开发的中,应用的频率也很高,该文件是一个xml文件,并放在 drawable 文件夹下如res/ drawable /filename.xml,那么引用方式也很简单,我们一般在控件的background使用,如 android :background=.
关于 shape selector android 界面布局中,很多需要 自定义 样式的地方,经常会使用到 shape selector 的,可以用简单的代码写出我们想要的样式。下面分别进行详细说明 shape 的使用 从字义上就可以知道它是用来定义形状的,具体操作如下: 在res/ drawable 文件下新建 drawable resource文件 新建为 shape 类型: 生成的 shape 文件之...
使用 layer - list 可以将多个 drawable 按照顺序层叠在一起显示,默认情况下,所有的item中的 drawable 都会自动根据它附上view的大小而进行缩放, layer - list 中的item是按照顺序从下往上叠加的,即先定义的item在下面,后面的依次往上面叠放 <?xml version=1.0 encoding=utf-8?> < layer - list xmlns: android =http://schemas. android .com/apk/res/ android > < shape android : shape =rectangle>
&lt;?xml version="1.0" encoding="utf-8"?&gt; &lt; selector xmlns: android ="http://schemas. android .com/apk/res/ android "&gt; &lt;item android : drawable ="@ drawable /govaffairs_pres. (1). layer - list 是啥? 简单理解, layer 是层, list 是列表,那么 layer - list 就是层列表的意思。但是,是什么层列表呢?? 其实 layer - list 是用来创建 Layer Drawable 的, Layer Drawable Drawable Resource 的一种, 所以, layer - list 创建出来的是 图层列表,也就是一个 drawable 图形。
安卓开发中我们会经常使用到Button,checkBox等控件,但是原生的控件非常丑一般情况下我们会给它加入一些点击或者选择样式,这时候就会使用到状态选择器。 下面我们以一个Button的点击样式为例介绍一个Button控件在正常情况和点击之后的样式。 先来看下我们要实现的效果图 未点击的Button效果: 点击状态下的Button效果: 下面一步一步实现: 1.在re
1、本文内容看似简单,但是 drawable 的种类比较繁多,导致开发者对不同的 drawable 理解比较混乱。 2、熟练掌握各种类型的 drawable 可以方便我们做出一些特殊的ui效果。 drawable 在开发中优点有很多 1、使用简单,比 自定义 的成本要低。 2、非图片类型的 drawable 占用空间较小,对减小apk的体积有很大的帮助。 Drawable 简...