Drawable 使用详解
极力推荐文章:欢迎收藏
Android 干货分享
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android
Drawable
是Android
中图像显示的常用方法。
概念:Drawable
是指可在屏幕上绘制的图形,已经通过getDrawable(int)
等API检索或者应用到具有 android:drawable
和 android:icon
等属性的其他 XML
资源的图形。
本篇文章主要介绍 Android
开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:
- Drawable 分类
- Bitmap 位图 BitmapDrawable
- 可拉伸图(*.9.png) NinePatchDrawable。
- 图层 LayerDrawable
- 不同状态图(选择器) StateListDrawable
- 级别列表 LevelListDrawable
- 转换图像 TransitionDrawable
- 插入可绘制对象
- 剪裁可绘制对象 ClipDrawable
- 缩放可绘制对象 ScaleDrawable
- 形状可绘制对象 ShapeDrawable
- Drawable与 Bitmap 常用方法总结
1.Drawable 简介
继承关系如下:
[java.lang.Object]
↳
android.graphics.drawable.Drawable
Drawable 分类如下:
- Bitmap 位图
BitmapDrawable
- 可拉伸图
(*.9.png)
NinePatchDrawable。
- 图层
LayerDrawable
- 不同状态图(选择器)
StateListDrawable
- 级别列表
LevelListDrawable
- 转换图像
TransitionDrawable
- 插入可绘制对象
- 剪裁可绘制对象
ClipDrawable
- 缩放可绘制对象
ScaleDrawable
- 形状可绘制对象
ShapeDrawable
资源引用:
在 Java
中:
R.drawable.filename
在 XML
中:
@[package:]drawable/filename
1. Bitmap 位图 BitmapDrawable
位图图像。Android
支持以下三种格式的位图文件:.png
(首选)、.jpg
(可接受)、.gif
(不建议)。这些文件保存到 res/drawable/
目录中
在构建过程中,可通过aapt
工具自动优化位图文件,对图像进行无损压缩。例如,不需要超过 256
色的真彩色 PNG
可通过调色板转换为 8
位 PNG
。这样产生的图像质量相同,但所需内存更少。因此请注意,此目录中的图像二进制文件在构建时可能会发生变化。如果您计划将图像解读为比特流以将其转换为位图,请改为将图像放在res/raw/
文件夹中,在那里它们不会进行优化
使用方法如下:
1.常规位图
- XML 布局中使用方法
<ImageView
android:id="@+id/img_round"
android:layout_width="80dp"
android:layout_height="80dp"
android:src="@drawable/gril" />
- Java 代码中使用方法
getResources().getDrawable(R.drawable.xml_bitmap)
2.XML 位图
- 在XML中创建位图资源文件
注意一下属性使用方法:
antialias
启用、停用抗锯齿dither
当位图的像素配置与屏幕不同时(例如:RGB 8888
位图和RGB 565
屏幕),启用或停用位图抖动。
3. `filter `
启用或停用位图过滤。当位图收缩或拉伸以使其外观平滑时使用过滤。
mipmap
启用或停用mipmap
提示
5.tileMode
定义平铺模式。当平铺模式启用时,位图会重复。重力在平铺模式启用时将被忽略
xml_bitmap
位图实现
<?xml version="1.0" encoding="utf-8"?>
<bitmap xmlns:android="http://schemas.android.com/apk/res/android"
android:antialias="true"
android:dither="true"
android:filter="false"
android:gravity="center_vertical|clip_vertical"
android:mipMap="true"
android:src="@drawable/gril"
android:tileMode="repeat" >
<!--
antialias
启用、停用抗锯齿
dither
当位图的像素配置与屏幕不同时(例如:ARGB 8888 位图和 RGB 565 屏幕),启用或停用位图抖动。
filter
启用或停用位图过滤。当位图收缩或拉伸以使其外观平滑时使用过滤。
mipmap
启用或停用 mipmap 提示
tileMode
定义平铺模式。当平铺模式启用时,位图会重复。重力在平铺模式启用时将被忽略
-->
</bitmap>
- 引用XML位图资源方法
<ImageView
android:id="@+id/img_drawable_bitmap"
android:layout_width="match_parent"
android:layout_height="50dp"
android:src="@drawable/xml_bitmap" />
- java 代码实现方法
2. 可拉伸图(*.9.png) NinePatchDrawable。
NinePatch
是一种 PNG
图像,在其中可定义当视图中的内容超出正常图像边界时 Android
缩放的可拉伸区域。此类图像通常指定为至少有一个尺寸设置为 "wrap_content"
的视图的背景,而且当视图扩展以适应内容时,九宫格图像也会扩展以匹配视图的大小。Android
的标准 Button
小部件使用的背景就是典型的九宫格图像,其必须拉伸以适应按钮内的文本(或图像)。
- 常规使用方法同其他图片引用方式
- XML .9.png 图片同Bitmap XML的使用方式
<nine-patch xmlns:android="http://schemas.android.com/apk/res/android"
android:src="@drawable/main_bg_green"
android:dither="false">
</nine-patch>
3. 图层 LayerDrawable
LayerDrawable
是管理其他可绘制对象阵列的可绘制对象。列表中的每个可绘制对象按照列表的顺序绘制,列表中的最后一个可绘制对象绘于顶部。每个可绘制对象由单一 <layer-list>
元素内的 <item>
元素表示。
<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/bird001"
android:drawable="@drawable/bird0001_risk">
</item>
<item
android:id="@+id/bird002"
android:drawable="@drawable/bird0002_risk"
android:left="50dp"
android:top="50dp">
</item>
<item
android:id="@+id/bird003"
android:drawable="@drawable/bird0003_risk"
android:left="100dp"
android:top="100dp">
</item>
</layer-list>
4. 不同状态图(选择器) StateListDrawable
StateListDrawable
是在 XML
中定义的可绘制对象,它根据对象的状态,使用多个不同的图像来表示同一个图形。例如,Button
小部件可以是多种不同状态(按下、聚焦或这两种状态都不是)中的其中一种,而且可以利用状态列表可绘制对象为每种状态提供不同的背景图片。
您可以在 XML
文件中描述状态列表。每个图形由单一 <selector>
元素内的 <item>
元素表示。每个<item>
均使用各种属性来描述应用作可绘制对象的图形的状态。
在每个状态变更期间,将从上到下遍历状态列表,并使用第一个与当前状态匹配的项目 —此选择并非基于“最佳匹配”,而是选择符合状态最低条件的第一个项目。
此方法非常常用,比如状态选择器
- 常规使用方法同其他图片引用方式
- 选择器 XML的使用方式
5. 级别列表 LevelListDrawable
管理大量备选可绘制对象的可绘制对象,每个可绘制对象都分配有最大的备选数量。使用setLevel()
设置可绘制对象的级别值会加载级别列表中 android:maxLevel
值大于或等于传递到方法的值的可绘制对象资源。
资源引用:
在 Java 中:
R.drawable.filename
在 XML 中:
@[package:]drawable/filename
<?xml version="1.0" encoding="utf-8"?>
<level-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:drawable="@drawable/gril"
android:maxLevel="100"
android:minLevel="10"/>
</level-list>
可通过 setLevel()
或 setImageLevel()
更改级别。
6. 转换图像 TransitionDrawable
TransitionDrawable
是可在两种可绘制对象资源之间交错淡出的可绘制对象。
每个可绘制对象由单一<transition>
元素内的 <item>
元素表示。不支持超过两个项目。要向前转换,请调用 startTransition()
。要向后转换,则调用 reverseTransition()
。
- xml 布局声明
<?xml version="1.0" encoding="utf-8"?>
<transition xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@drawable/bird0001_risk" />
<item android:drawable="@drawable/bird0002_risk" />
</transition>
- java 代码中使用
7. 插入可绘制对象
在 XML
文件中定义的以指定距离插入其他可绘制对象的可绘制对象。当视图需要小于视图实际边界的背景时,此类可绘制对象很有用。
<?xml version="1.0" encoding="utf-8"?>
<inset xmlns:android="http://schemas.android.com/apk/res/android"
android:drawable="@drawable/gril"
android:insetBottom="10dp"
android:insetLeft="10dp"
android:insetRight="10dp"
android:insetTop="10dp"
android:visible="true" >
</inset>
8. 剪裁可绘制对象 ClipDrawable
在 XML
文件中定义的对其他可绘制对象进行裁剪(根据其当前级别)的可绘制对象。您可以根据级别以及用于控制其在整个容器中位置的重力,来控制子可绘制对象的裁剪宽度和高度。通常用于实现进度栏之类的项目。
- xml 初始化剪裁样式
<?xml version="1.0" encoding="utf-8"?>
<clip xmlns:android="http://schemas.android.com/apk/res/android"
android:clipOrientation="vertical"
android:drawable="@drawable/gril"
android:gravity="center" >
</clip>
- java 代码中使用
9. 缩放可绘制对象 ScaleDrawable
在 XML
文件中定义的更改其他可绘制对象大小
<?xml version="1.0" encoding="utf-8"?>
<scale xmlns:android="http://schemas.android.com/apk/res/android"
android:drawable="@drawable/gril"
android:scaleGravity="center"
android:scaleHeight="10%"
android:scaleWidth="10%" >
</scale>
10. 形状可绘制对象 ShapeDrawable
在 XML
中定义的一般形状。
- 绘制直线
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="line" >
<gradient
android:angle="45"
android:centerX="0.5"
android:centerY="0.5"
android:centerColor="@android:color/holo_green_dark"
android:endColor="@android:color/holo_orange_light"
android:gradientRadius="5dp"
android:startColor="@android:color/holo_purple"
android:type="linear"
android:useLevel="true"/>"
<padding
android:left="5dp"
android:top="5dp"
android:right="5dp"
android:bottom="5dp" />
<size
android:width="1dp"
android:height="1dp" />
<solid
android:color="@android:color/holo_orange_light" />
<stroke
android:width="5dp"
android:color="@android:color/darker_gray"
android:dashWidth="5dp"
android:dashGap="5dp" />
</shape>
2.绘制圆角矩形
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<!-- 圆角-->
<corners android:radius="5dp" />
<!--描边-->
<stroke
android:width="1dp"
android:color="@android:color/holo_blue_light" />
</shape>
12. Drawable与 Bitmap 常用方法总结
由于涉及内容比较多,已经另起文章讲述。
至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!
Drawable 使用详解的更多相关文章
- Android自定义drawable(Shape)详解
在Android开发过程中,经常需要改变控件的默认样式, 那么通常会使用多个图片来解决.不过这种方式可能需要多个图片,比如一个按钮,需要点击时的式样图片,默认的式样图片. 这样就容易使apk变大. 那 ...
- Android Drawable - Shape Drawable使用详解(附图)
TIPS shape图形 –简单介绍 shape图形 –如何画? shape图形 –参数详细解析 shape图形 –如何用? shape图形 –实际开发应用场景 shape图形简单介绍 用xml实现一 ...
- Drawable实战解析:Android XML shape 标签使用详解(apk瘦身,减少内存好帮手)
Android XML shape 标签使用详解 一个android开发者肯定懂得使用 xml 定义一个 Drawable,比如定义一个 rect 或者 circle 作为一个 View 的背景. ...
- Selector、shape详解,注意这两种图像资源都以XML方式存放在drawable不带分辨率的文件夹中
Selector.shape详解(一) Selector的结构描述: <?xml version="1.0" encoding="utf-8"?> ...
- Xamarin.Android通知详解
一.发送通知的机制 在日常的app应用中经常需要使用通知,因为服务.广播后台活动如果有事件需要通知用户,则需要通过通知栏显示,而在Xamarin.Android下的通知需要获取Notification ...
- 详解Paint的setXfermode(Xfermode xfermode)
一.setXfermode(Xfermode xfermode) Xfermode国外有大神称之为过渡模式,这种翻译比较贴切但恐怕不易理解,大家也可以直接称之为图像混合模式,因为所谓的“过渡”其实就是 ...
- Android图片缓存之Bitmap详解
前言: 最近准备研究一下图片缓存框架,基于这个想法觉得还是先了解有关图片缓存的基础知识,今天重点学习一下Bitmap.BitmapFactory这两个类. 图片缓存相关博客地址: Android图片缓 ...
- Android之TextView的样式类Span的使用详解
Android中的TextView是个显示文字的的UI类,在现实中的需求中,文字有各式各样的样式,TextView本身没有属性去设置实现,我们可以通过Android提供的 Spannab ...
- Xamarin android 之Activity详解
序言: 上篇大概的讲解了新建一个android的流程.今天为大家带来的是Activity详解,因为自己在开发过程中就遇到 好几次坑,尴尬. 生命周期 和Java里头一样一样的,如图 图片来源于网上哈, ...
随机推荐
- MySQL数据库修改字段的长度
数据库版本:5.7.22 使用DDL语句:alter table 表名 modify 字段名 字符类型(长度) 例如: alter table db2.admin modify password );
- HTML5新增的表单验证功能
一.HTML5表单的特点: HTML5 表单增加了许多内置的控件和控件属性 XHTML 中需要放在 form 之中的诸如 input/button/select/textarea 等标签元素,在 HT ...
- ElasticSearch 7.1.1 集群环境搭建
1. 集群简介 三台机器,均用于保存数据且可被选为master节点 服务版本 服务 版本 elasticsearch 7.1.1 jdk 1.8 1. 创建elsearch用户 不建议直接使用root ...
- DataBinding的用法
一.基本介绍 DataBinding数据绑定库是一种支持库,借助该库,可以使用声明性格式(而非程序化地)将布局中的界面组件绑定到应用中的数据源.这是官方给出的介绍. 那么为什么要使用DataBindi ...
- 微服务-springboot热部署
spring为开发者提供了一个名为spring-boot-devtools的模块来使Spring Boot应用支持热部署,提高开发者的开发效率,无需手动重启Spring Boot应用. IDEA进行热 ...
- Codeforces Gym100502H:Clock Pictures(KMP算法)
http://codeforces.com/gym/100502/attachments 题意:有两个时钟上面有n个指针,给出的数字代表指针的角度.问能否在某一时刻使得两个时钟的指针重合. 思路:容易 ...
- 执行某个文件夹下面的所有.py文件
# 写一个函数,接受一个参数,如果是文件,就执行这个文件,如果是文件夹,就执行这个文件夹下所有的py文件 # 工作应用场景,假设一个文件夹下面有100个py文件,同步一些时间 # 例如抢票软件 10点 ...
- bzoj3316 JC loves Mkk题解
3316: JC loves Mkk Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 979 Solved: 316[Submit][Status][Di ...
- .Net微信网页开发之JSSDK使用步骤和配置信息timestamp(时间戳),nonceStr(随机串),signature(签名),access_token(接口调用凭据)的生成获取讲解
前言: 因为接下来会有几篇关于微信JS-SDK功能使用的文章,主要会对微信分享,获取设备信息,获取地理位置,微信扫一扫这几个功能进行讲解.而这几个功能都是围绕着微信JS-SDK实现的,首先使用微信JS ...
- Netty-新连接接入源码解读
本片博文来看Netty的服务端是如何处理新连接接入问题的 什么是新连接接入?以及新连接接入前,Netty处于什么状态 netty的服务端NioServerSocketChannel初始化,注册在Bos ...