本文主要是介绍Android 9-patch 九图的制作与使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
惯例:先上图后说话,谢谢各位伙伴的支持! 有你们是我的福分!
每日一言:人生没有太晚的开始,一切还来得急。
一、9.PNG使用背景
在Android的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压缩,这样就出现了可以任意调整大小的一种图片格式“.9.png”。
二、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.
这篇关于Android 9-patch 九图的制作与使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!