Android 9-patch 九图的制作与使用
2016-01-05 18:17
295 查看
一、9.PNG简介
九图(9.PNG)这种格式的图片是安卓开发里面的一种特殊的图片,在android 环境下具有自适应调节大小的能力:
(1)允许开发人员定义可扩展区域,当需要延伸图片以填充比图片本身更大区域时,可扩展区的内容被延展
(2)允许开发人员定义内容显示区,用于显示文字或其他内容
9.png图片与其它图片不同之处在于,它的四周与普通的png图片相比多了1个像素位的白色区域,因而真正显示的时候总像素会缩小2个像素(上下左右各1个像素),比如23x23像素的9.png图片真正显示的时候会变成21x21像素。所以我们在制作的时候要注意掌握尺寸。
二、如何制作9.png图片素材:
1、draw9patch工具,该工具在Android SDK中都有自带,在/sdk/tools/draw9patch目录下面
2、执行draw9patch,会出现如下图:
![](http://img.blog.csdn.net/20160105180337300?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
3.将你制作的图片拖到该窗口中,图片的边缘会增加1个像素白色透明框。将鼠标放在白色边框,点住左键不放拖动,会出现黑色点或线条,如下图:
![](http://img.blog.csdn.net/20160105181028227?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
4、四周的黑色线条解释如下:
(a)1号黑色条位置向下覆盖的区域表示图片横向拉伸时,只拉伸该区域
(b)2号黑色条位置向右覆盖的区域表示图片纵向拉伸时,只拉伸该区域
(c)3号黑色条位置向左覆盖的区域表示图片纵向显示内容的区域
(d)4号黑色条位置向上覆盖的区域表示图片横向显示内容的区域
右边3个图形区域为显示当前拉伸效果,没有黑色条的位置覆盖的区域是图片拉伸时保持不变(比如,如果图片的四角为弧形的时候,当图片被任意拉伸时,四角的弧形都不会发生改变)
5、如果失误多选了部分,可按住shift键,点击鼠标左键去掉黑色条
6、选择好区域后,点击左上file-> save,保存为PNG图片。保存完成后,后缀名自动为xxx.9.png。命名时只需要填写名称xxx,不需要写后缀.9.png,否则android编译的时候会报错。
三、常见错误:
1. “No resource found that matches the given name”
这是因为在保存为PNG图片,命名时带了后缀.9.png。一定要注意命名只需要填写图片名称,工具会自动加上后缀。
2. AAPT: ERROR: 9-patch image xxx.9.png malformed.
AAPT: Must have one-pixel frame that is either transparent or white.
这是因为9.png九图的四边都需要描点,如果有一条边没有描点,有可能会报这个错误。
九图(9.PNG)这种格式的图片是安卓开发里面的一种特殊的图片,在android 环境下具有自适应调节大小的能力:
(1)允许开发人员定义可扩展区域,当需要延伸图片以填充比图片本身更大区域时,可扩展区的内容被延展
(2)允许开发人员定义内容显示区,用于显示文字或其他内容
9.png图片与其它图片不同之处在于,它的四周与普通的png图片相比多了1个像素位的白色区域,因而真正显示的时候总像素会缩小2个像素(上下左右各1个像素),比如23x23像素的9.png图片真正显示的时候会变成21x21像素。所以我们在制作的时候要注意掌握尺寸。
二、如何制作9.png图片素材:
1、draw9patch工具,该工具在Android SDK中都有自带,在/sdk/tools/draw9patch目录下面
2、执行draw9patch,会出现如下图:
3.将你制作的图片拖到该窗口中,图片的边缘会增加1个像素白色透明框。将鼠标放在白色边框,点住左键不放拖动,会出现黑色点或线条,如下图:
4、四周的黑色线条解释如下:
(a)1号黑色条位置向下覆盖的区域表示图片横向拉伸时,只拉伸该区域
(b)2号黑色条位置向右覆盖的区域表示图片纵向拉伸时,只拉伸该区域
(c)3号黑色条位置向左覆盖的区域表示图片纵向显示内容的区域
(d)4号黑色条位置向上覆盖的区域表示图片横向显示内容的区域
右边3个图形区域为显示当前拉伸效果,没有黑色条的位置覆盖的区域是图片拉伸时保持不变(比如,如果图片的四角为弧形的时候,当图片被任意拉伸时,四角的弧形都不会发生改变)
5、如果失误多选了部分,可按住shift键,点击鼠标左键去掉黑色条
6、选择好区域后,点击左上file-> save,保存为PNG图片。保存完成后,后缀名自动为xxx.9.png。命名时只需要填写名称xxx,不需要写后缀.9.png,否则android编译的时候会报错。
三、常见错误:
1. “No resource found that matches the given name”
这是因为在保存为PNG图片,命名时带了后缀.9.png。一定要注意命名只需要填写图片名称,工具会自动加上后缀。
2. AAPT: ERROR: 9-patch image xxx.9.png malformed.
AAPT: Must have one-pixel frame that is either transparent or white.
这是因为9.png九图的四边都需要描点,如果有一条边没有描点,有可能会报这个错误。
相关文章推荐
- Android TextView前加图标垂直居中第一行(仿大众点评购买须知/提示语)
- Android 应用程序升级到 5.0 需要注意的问题
- android中的文件操作详解以及内部存储和外部存储
- Android 使用动态加载框架DL进行插件化开发
- 细说:AndroidStudio插件
- 在Android中 使用 java.net.URI 与 android.net.Uri 的区别
- android的TextView展示带格式文本、首行缩进、引入自定义字体
- Android5.0 与 4.x的不同
- AndroidStudio多渠道打包
- android按键事件和触屏事件(一)-几个重要方法的传递顺序
- 获取WiFi MAC地址总结
- 自定义控件Android圆环进度条
- 一套停车场管理软件附带源代码 J2EE服务端+android客户
- Android Studio 的初使用
- Android ScrollView嵌套ScrollView滚动的问题解决办法
- Android编译选项eng、user、userdebug的区别
- android wifi 调试
- Android实现UDP通信
- Android 实例:简单Menu和Item
- android的Service