文档章节

Android 关于shape和selector和layer-list(UI 设计)

Mr-Red
 Mr-Red
发布于 2015/07/23 00:18
字数 781
阅读 197
收藏 15

简介

相当于 xml 实现的drawable

Shape

作用:XML中定义的几何形状 位置:res/drawable/文件的名称.xml

使用的方法:

Java代码中:R.drawable.文件的名称 XML中:Android:background="@drawable/文件的名称"

属性:

<shape> Android:shape=["rectangle" | "oval" | "line" | "ring"] 其中rectagle矩形,oval椭圆,line水平直线,ring环形 <shape>中子节点的常用属性:

  1. <gradient> 渐变
  • Android:startColor 起始颜色
  • Android:endColor 结束颜色
  • Android:angle 渐变角度,0从左到右,90表示从下到上,数值为45的整数倍,默认为0;
  • Android:type 渐变的样式 liner线性渐变 radial环形渐变 sweep <solid > 填充
  • Android:color 填充的颜色
  1. <stroke >描边
  • Android:width 描边的宽度
  • Android:color 描边的颜色
  • Android:dashWidth 表示'-'横线的宽度
  • Android:dashGap 表示'-'横线之间的距离
  1. <corners >圆角
  • Android:radius 圆角的半径 值越大角越圆
  • Android:topRightRadius 右上圆角半径
  • Android:bottomLeftRadius 右下圆角角半径
  • Android:topLeftRadius 左上圆角半径
  • Android:bottomRightRadius 左下圆角半径
  1. <padding >填充
  • android:bottom="1.0dip" 底部填充
  • android:left="1.0dip" 左边填充
  • android:right="1.0dip" 右边填充
  • android:top="0.0dip" 上面填充

Selector

根据不同的选定状态来定义不同的现实效果 分为四大属性:

  • android:state_selected 是选中
  • android:state_focused 是获得焦点
  • android:state_pressed 是点击
  • android:state_enabled 是设置是否响应事件,指所有事件
  • android:state_window_focused 默认时的背景图片 引用位置:res/drawable/文件的名称.xml
使用的方法:

Java代码中:R.drawable.文件的名称 XML中:Android:background="@drawable/文件的名称"

示例:
<?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/pic_blue" 
   />     
<!-- 非触摸模式下获得焦点并单击时的背景图片 -->    
<item 
   Android:state_focused="true" 
   android:state_pressed="true"   
   android:drawable= "@drawable/pic_red" 
   />   
<!-- 触摸模式下单击时的背景图片-->    
<item 
   Android:state_focused="false" 
   Android:state_pressed="true"   
   Android:drawable="@drawable/pic_pink" 
   />    
<!--选中时的图片背景-->    
<item 
   Android:state_selected="true" 
   android:drawable="@drawable/pic_orange" 
   />     
<!--获得焦点时的图片背景-->    
<item 
   Android:state_focused="true" 
   Android:drawable="@drawable/pic_green" 
   />     
</selector> 

layer-list(多个shape)

将多个图片或上面两种效果按照顺序层叠起来

示例:
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
      <bitmap android:src="@drawable/android_red"
        android:gravity="center" />
    </item>
    <item android:top="10dp" android:left="10dp">
      <bitmap android:src="@drawable/android_green"
        android:gravity="center" />
    </item>
    <item android:top="20dp" android:left="20dp">
      <bitmap android:src="@drawable/android_blue"
        android:gravity="center" />
    </item>
</layer-list>

:fa-pencil: 感觉很像多个drawable

三者可以结合使用

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <layer-list>
            <item android:bottom="8.0dip">
                <shape>
                    <solid android:color="#ffaaaaaa" />
                </shape>
            </item>
            <item>
                <shape>
                    <corners android:bottomLeftRadius="4.0dip" android:bottomRightRadius="4.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" />

                    <solid android:color="#ffaaaaaa" />

                    <padding android:bottom="1.0dip" android:left="1.0dip" android:right="1.0dip" android:top="0.0dip" />
                </shape>
            </item>
            <item>
                <shape>
                    <corners android:bottomLeftRadius="3.0dip" android:bottomRightRadius="3.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" />

                    <solid android:color="@color/setting_item_bgcolor_press" />
                </shape>
            </item>
        </layer-list>
    </item>
    <item>
        <layer-list>
            <item android:bottom="8.0dip">
                <shape>
                    <solid android:color="#ffaaaaaa" />
                </shape>
            </item>
            <item>
                <shape>
                    <corners android:bottomLeftRadius="4.0dip" android:bottomRightRadius="4.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" />

                    <solid android:color="#ffaaaaaa" />

                    <padding android:bottom="1.0dip" android:left="1.0dip" android:right="1.0dip" android:top="0.0dip" />
                </shape>
            </item>
            <item>
                <shape>
                    <corners android:bottomLeftRadius="3.0dip" android:bottomRightRadius="3.0dip" android:topLeftRadius="1.0dip" android:topRightRadius="1.0dip" />

                    <solid android:color="@color/setting_item_bgcolor" />
                </shape>
            </item>
        </layer-list>
    </item>
</selector>

© 著作权归作者所有

共有 人打赏支持
上一篇: IDEA 插件篇
Mr-Red
粉丝 0
博文 37
码字总数 8379
作品 0
泉州
私信 提问
使用Selector对UI控件美化问题请教

今天看了一个例程,在Selector中设计了控件带阴影的效果(两层),xml文件配置如下,想请教下各位,以下红色字体的作用是什么?是层的偏移值吗?

lwm1368
2014/10/30
57
2
Android样式的开发系列

最近花了比较长的时间总结了样式开发的系列文章,从最简单的自定义形状Shape,到selector的用法,以及layer-list的使用,drawable资源的汇总,还有动画的编写,到最后style的整合。 [Android...

Keegan小钢
2015/11/03
976
10
android res资源 drawable自定义背景 values格式

res anim 动画目录 leftin.xml scale.xml drawable 自定义动画目录 redbuttonbg.xml circlebuttonbg.xml drawable-xhdpi 放资源文件图片 layout 放布局文件图片 raw 音频、数据库等资源文件 ...

cicue
2014/09/25
0
0
Android开发教程:shape和selector的结合使用

shape和selector是Android UI设计中经常用到的,比如我们要自定义一个圆角Button,点击Button有些效果的变化,就要用到shape和selector。可以这样说,shape和selector在美化控件中的作用是至...

方毅超
2014/05/16
0
0
在Android中自定义IOS风格的按钮

IOS风格的UI比较流行,很多Android的UI设计者也愿意将Android的UI设计成类似IOS系统的UI风格。下面是一个例子,说明如何使用Shape来定义一个IOS风格的按钮。 定义一个iosbuttongrouped.xml。...

迷途d书童
2012/03/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

聊聊GarbageCollectionNotificationInfo

序 本文主要研究一下GarbageCollectionNotificationInfo CompositeData java.management/javax/management/openmbean/CompositeData.java public interface CompositeData { public Co......

go4it
15分钟前
0
0
阿里云ECS的1M带宽理解

本文就给大家科普下阿里云ECS的固定1M带宽的含义。 “下行带宽”和“上行带宽” 为了更好的理解,需要先给大家解释个词“下行带宽”和“上行带宽”: 下行带宽:粗略的解释就是下载数据的最大...

echojson
17分钟前
0
0
0323 第六次课:磁盘管理

用户和组管理 一、磁盘使用情况 df命令 df命令是用来查看系统磁盘空间占用情况 常用示例: df -h 更人性化的显示磁盘使用信息 df -m 以m为单位显示 df -i 显示磁盘inode使用情况,有的时候磁...

wxy丶
38分钟前
0
0
为论坛做负载均衡集群

1. 克隆虚拟机 修改IP地址修改主机名 2. 准备工作 两台机器上开启nginx,保证能访问论坛第二台机器上,关闭mariadb 修改配置文件:config/config_global.php config/config_ucenter.ph...

wzb88
38分钟前
1
0
__attribute__ 总结

attribute是GNU C特色之一,在iOS用的比较广泛.系统中有许多地方使用到. attribute可以设置函数属性(Function Attribute )、变量属性(Variable Attribute )和类型属性(Type Attribute)等...

天王盖地虎626
44分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部