Android .9.png图片的制作与使用

    .9.png图片其实就是png格式图片,不过它比普通的png图片外围多了1px(像素)的边框,另外就是使用这种格式的图片可以实现背景自适应大小且不失真的效果。比如某些控件横竖屏切换后控件的样子就变形了,或者某些图片作为控件背景也变形,这会让人很郁闷。幸好.9.png图片可以提供这些需要的功能。


制作使用步骤:

    1、制作属于你自己的png图片,一定要是png图片。可以自己PS制作,也可以解压其他应用的apk文件,用里面的图片资源,Android系统也有图片资源可以使用。
    2、在android-sdk-windows\tools目录下找到draw9patch.bat文件,然后将其打开,将你要处理的png图片拖入即可。或者File --> Open 9 patch。




    上边黑线:横向拉伸区域,必须要画的,拉伸是横向拉伸,如右边的区域第二个拉伸的就是横向拉伸的效果
    左边黑线:纵向拉伸区域,必须要画的,拉伸是纵向拉伸,如右边的区域第一个拉伸的就是纵向拉伸的效果
    下边黑线:可选,横向内容显示区域
    右边黑线:可选,纵向内容显示区域

    3、注意,黑线必须是连续的,如果你感觉画的不好,按shift+鼠标左键将其擦出,然后从新画。画完后点击File-->save 9-patch保存即可,效果如下图

    
    4、接下来需要在程序中使用了,将这个图片放到drawable中即可,跟其他的图片使用没什么区别了,唯一神奇的就是可以自适应,不失真。


    比如我们用这个图片定义一个Button,另外加个TextView的背景图,也是.9.png图片。

[html]  view plain copy print ?
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:padding="6dp"  
  6.     android:orientation="vertical" >  
  7.   
  8.     <TextView  
  9.         android:layout_gravity="right"  
  10.         android:layout_width="wrap_content"  
  11.         android:layout_height="wrap_content"  
  12.            android:padding="5dp"  
  13.         android:background="@drawable/sms_out_normal_bg"  
  14.         android:text="http://www.cnblogs.com/loulijun/\n -- 花郎" />  
  15.       
  16.     <Button   
  17.         android:id="@+id/sendMsg"  
  18.         android:layout_width="wrap_content"  
  19.         android:layout_height="wrap_content"  
  20.         android:layout_gravity="center"  
  21.         android:padding="10dp"  
  22.         android:background="@drawable/test"  
  23.         android:text="发送消息给允儿"  
  24.         />  
  25. </LinearLayout>  

运行效果如下:

     



转自:http://www.cnblogs.com/loulijun/archive/2011/12/22/2298087.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值