作者:晓雷sky | 来源:互联网 | 2023-08-23 23:16
Android中提供一种xml的方式,让我们可以自由地定义背景,比较常用的就是shape标签和selector标签,这篇文章主要介绍了Android shape与selector标
目录
- shape
- corners 圆角
- stroke 边框
- solid 填充背景色
- gradient 渐变
- 圆形背景
- ripple 水波纹
- selector 标签
- 补充
Android中提供一种xml的方式,让我们可以自由地定义背景,比较常用的就是shape
标签和selector
标签
shape
shape的翻译为形状的意思,一般用来定义背景的形状,如长方形,线条,圆形
- rectangle 矩形 默认
- oval 椭圆
- line 线条
- ring 环形
简单使用:
android:tint="@color/white" android:shape="rectangle">
tint是用来设置背景颜色
上述代码即为白色的矩形,效果如下图:
一般我们将shape当做根标签来使用
corners 圆角
corners标签,即为圆角的意思,可定义的属性如下
属性 |
说明 |
---|
radius |
定义4个方向圆角宽度 |
topRightRadius |
右上角圆角宽度 |
bottomLeftRadius |
左下角圆角宽度 |
bottomRightRadius |
右下角圆角宽度 |
topLeftRadius |
左上角圆角宽度 |
android:tint="@color/white" android:shape="rectangle">
上述代码即为圆角矩形的效果:
stroke 边框
android:shape="rectangle">
注意: 这里代码中删除了shape中的tint属性,因为tint属性会优先级较高,导致边框无法显示出来!
solid 填充背景色
color 背景颜色
android:shape="rectangle">
上述代码,将背景设置了白色,且边框也能正常显示
gradient 渐变
属性 |
说明 |
---|
startColor |
开始颜色 |
endColor |
结束颜色 |
angle |
角度 0 90 180 270 可以设置渐变的方向 |
type |
渐变类型,linear:线性 radial:辐射状 sweep:扫射 |
angle属性记忆的方法是:先记住默认的方向,startColor到endColor,方向是从上到下,然后以逆时针为方向转动,如果为0,则是逆时针转动90°,以此类推
测试的方向,如果是45°的倍数,也是稍微有所区别
android:shape="rectangle">
PS: 注意solid和gradient两个标签的顺序,两者联用,位于xml下面的会覆盖上面的:
圆形背景
圆形背景,即设置了shape属性为oval
android:shape="oval">
android:
android: />
同时,加上了个size标签,用来定义宽高,这样才会显示出圆形,不然就是椭圆
这里size标签宽高似乎可以是任意值,因为是矢量,应用到View中会自动伸缩
PS:同理,如果想要正方形,设置shape属性了rectangle,同时加上size标签即可,如下图
ripple 水波纹
水波纹,需要用ripple标签,不过只支持Android5.0以上的版本,写法如下
xmlns:tools="http://schemas.android.com/tools"
android:color="@color/colorPrimary"
tools:targetApi="lollipop">
使用的话,View中background属性引用上面的xml文件即可
在自定义
时,我们一般把它放到 drawable-v21 文件夹下, 在drawable文件夹下放置兼容低版本的普通 Drawable 文件,如
或者
。
selector 标签
有时候需要自定义下按钮的点击变化背景等样式,就可以用到此标签来定义相关的点击变化效果
常用属性如下表所示:
属性 |
说明 |
---|
state_pressed |
设置是否按压状态,一般在true时设置该属性,表示已按压状态,默认为false |
state_selected |
设置是否选中状态,true表示已选中,false表示未选中 |
state_checkable |
设置是否勾选状态,主要用于CheckBox和RadioButton,true表示已被勾选,false表示未被勾选 |
state_checked |
设置勾选是否可用状态,类似state_enabled,只是state_enabled会影响触摸或点击事件,state_checkable影响勾选事件 |
state_focused |
设置是否获得焦点状态,true表示获得焦点,默认为false,表示未获得焦点 |
state_enabled |
设置触摸或点击事件是否可用状态,一般只在false时设置该属性,表示不可用状态 |
文本选中变色示例
checkbox选中效果变化示例
补充
关于透明色效果
透明色是定义在#
后面前面的两个数值,是十六进制
PS:注意,似乎也有规则是在后面加上两位数值代表透明度
如:#011627
-> #80011627
透明色
其中80即为透明度的十六进制,表示透明度为50%,可以参考下面透明度大全表格
android:color="#4DFFFFF2">
透明度大全
不透度对应16进制大全(0-100)不透明度16进制
不透明度 |
16进制 |
---|
0% |
00 |
1% |
03 |
2% |
05 |
3% |
08 |
4% |
0A |
5% |
0D |
6% |
0F |
7% |
12 |
8% |
14 |
9% |
17 |
10% |
1A |
11% |
1C |
12% |
1F |
13% |
21 |
14% |
24 |
15% |
26 |
16% |
29 |
17% |
2B |
18% |
2E |
19% |
30 |
20% |
33 |
21% |
36 |
22% |
38 |
23% |
3B |
24% |
3D |
25% |
40 |
26% |
42 |
27% |
45 |
28% |
47 |
29% |
4A |
30% |
4D |
31% |
4F |
32% |
52 |
33% |
54 |
34% |
57 |
35% |
59 |
36% |
5C |
37% |
5E |
38% |
61 |
39% |
63 |
40% |
66 |
41% |
69 |
42% |
6B |
43% |
6E |
44% |
70 |
45% |
73 |
46% |
75 |
47% |
78 |
48% |
7A |
49% |
7D |
50% |
80 |
51% |
82 |
52% |
85 |
53% |
87 |
54% |
8A |
55% |
8C |
56% |
8F |
57% |
91 |
58% |
94 |
59% |
96 |
60% |
99 |
61% |
9C |
62% |
9E |
63% |
A1 |
64% |
A3 |
65% |
A6 |
66% |
A8 |
67% |
AB |
68% |
AD |
69% |
B0 |
70% |
B3 |
71% |
B5 |
72% |
B8 |
73% |
BA |
74% |
BD |
75% |
BF |
76% |
C2 |
77% |
C4 |
78% |
C7 |
79% |
C9 |
80% |
CC |
81% |
CF |
82% |
D1 |
83% |
D4 |
84% |
D6 |
85% |
D9 |
86% |
DB |
87% |
DE |
88% |
E0 |
89% |
E3 |
90% |
E6 |
91% |
E8 |
92% |
EB |
93% |
ED |
94% |
F0 |
95% |
F2 |
96% |
F5 |
97% |
F7 |
98% |
FA |
99% |
FC |
100% |
FF |