Android 9-patch 九图的制作与使用

  • Post author:
  • Post category:其他



一、9.PNG简介

九图(9.PNG)这种格式的图片是安卓开发里面的一种特殊的图片,在android 环境下具有自适应调节大小的能力:

(1)允许开发人员定义可扩展区域,当需要延伸图片以填充比图片本身更大区域时,可扩展区的内容被延展

(2)允许开发人员定义内容显示区,用于显示文字或其他内容

9.png图片与其它图片不同之处在于,它的四周与普通的png图片相比多了1个像素位的白色区域,因而真正显示的时候总像素会缩小2个像素(上下左右各1个像素),比如23×23像素的9.png图片真正显示的时候会变成21×21像素。所以我们在制作的时候要注意掌握尺寸。


二、如何制作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九图的四边都需要描点,如果有一条边没有描点,有可能会报这个错误。



版权声明:本文为wangbaochu原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。