.9.png是一种能够自己定义拉伸特定区域的图片格式。

简书:Android设计中的.9.png图片

在Android的UI设计开发中,非常多控件须要适配不同的手机分辨率进行拉伸或者压缩,这样就出现了能够随意调整大小的一种图片格式“.9.png”。这样的图片是用于Android开发的一种特殊的图片格式,它能够指定特定的区域进行拉伸而不失真。同一时候能够指定前景内容的显示区域。即.9.png图片的用处能够概括为以下两点:

- .9.png图片在图片拉伸的时候特定的区域不会发生图片失真。

- .9.png图片作为背景图的时候能够指定内容显示区域;

一、.9.png图片与普通图片的对照

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="compare.jpg" title="">

通过上面的对照,我们能够发现,.9.png图片周围会有一条黑色的线条,这些黑色线条有什么作用呢?就是用于指定我们背景的拉伸区域或者前景内容的显示区域。

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="png9.png" title="">

- 左边黑线:纵向拉伸区域,必须要画的,控制纵向拉伸,如上图右側第一个小图。

- 上边黑线:横向拉伸区域,必须要画的。控制横向拉伸,如上图右側第二个小图。

- 右边黑线:可选,纵向内容显示区域

- 下边黑线:可选。横向内容显示区域

通过上面的的介绍。我们知道.9.png的四条边上的黑线有哪些用途。那么我们将介绍下关于拉伸区域的界定。

拉伸区域

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="拉伸区域.png" title="">

  • 红色框区域: 表示纵向拉伸区域,当控件背景图片须要进行纵向拉伸时,它仅仅会拉伸红色区域,其他区域不会拉伸。
  • 绿色框区域:表示横向拉伸区域。当控件背景图片须要进行横向拉伸时。它仅仅会拉伸绿色区域,其他区域不会拉伸。

  • 红绿相交区域:该段区域横向和纵向都会拉伸。
前景内容显示区域

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="" title="">

  • 红色框区域:指定横向文本显示的区域。限定文本左右能显示到的边界。
  • 蓝色框区域:指定纵向文本显示的取。限定文本上下能显示到的边界。

二、.9.png图片的制作

这么强大的一种图片,在我们android开发中的适配环节。起了非常大的作用。那么怎么制作这样的.9.png图片呢?在Android的工具中给我们提供了draw9patch.bat工具来制作.9文件。该工具文件夹在\android-sdk-windows\tools\draw9patch.bat

我们直接打开draw9path.bat二进制程序,将我们须要制作的图片导入进去。然后按住鼠标左键进行划黑边。假设画错了。通过Shift+鼠标左键进行拖动取消。

三、简单体验

首先,我们通过简单的布局文件看看普通图片的展示效果。

<?

xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main"
android:layout_width="match_parent" android:layout_height="match_parent"
tools:context="dsw.iflytek.com.pngdemo.MainActivity"> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@mipmap/back"
android:layout_centerInParent="true"
android:text="Hello World!" />
</RelativeLayout>

在上面的效果图没有进行自适应。两边的边框已经被文字嵌入进去。所以我们要对图片作例如以下改动:

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="进行拉伸处理.9资源.png" title="">

在我们的处理中。通过对图片加入纵横向的拉伸,来保持背景的自适应。

这里须要我们注意指定的拉伸区域。须要我们细致体会。

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="多行展示效果.png" title="">

在上面我们对横向拉伸区域有了一定认识。

以下看看内容拉伸区域:

imageMogr2/auto-orient/strip%7CimageView2/2/w/1240" alt="纵向显示区域.png" title="">

在上面的.9图中。我们将整个右边线作为内容纵向显示的区域,看看效果图:

我们能够看到,内容的显示是紧紧填满上下之间。

没有间隙。

在来看看效果图:

通过上面对照。我们能够发现右側变现控制着内容视图的显示区域的规律。

相同底部也是一样。在开发的过程中。合理的使用.9.png文件能够非常好的优化我们的资源文件,减小apk的包大小。

也能进行非常好的适配效果。

Android设计中的.9.png图片的更多相关文章

  1. 【转】Android设计中的.9.png

    来源:http://isux.tencent.com/android-ui-9-png.html Android设计中的.9.png 注意:当使用9.png做TextView背景时,一定要设置内容区域 ...

  2. Android设计中的尺寸问题

    Android把屏幕大小分成四种:small, normal, large, xlarge; 屏幕密度分成:low(ldpi), medium(mdpi), high(hdpi), extra hig ...

  3. Android 设计中的.9.png

    在 Android 的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压缩,这样就出现了可以任意调整大小的一种图片格式“.9.png”.这种图片是用于Android开发的一种特殊的图片格式, ...

  4. 【转载】Android设计中的.9.png

      转载自:腾讯ISUX (http://isux.tencent.com/android-ui-9-png.html) 在Android的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压 ...

  5. Android设计中的.9.png

    在Android的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压缩,这样就出现了可以任意调整大小的一种图片格式“.9.png”.这种图片是用于Android开发的一种特殊的图片格式,它的 ...

  6. Android设计中的.9.png与Android Studio中的设置

    在Android的设计过程中,为了适配不同的手机分辨率,图片大多需要拉伸或者压缩,这样就出现了可以任意调整大小的一种图片格式“.9.png”.这种图片是用于Android开发的一种特殊的图片格式,它的 ...

  7. 点9图 Android设计中如何切图.9.png

    转载自:http://blog.csdn.net/buaaroid/article/details/51499516 本文主要介绍如何制作 切图.9.png(点9图),另一篇姊妹篇文章Android屏 ...

  8. Android Studio中关于9-patch格式图片的编译错误

    最近在编译Android Studio开发的项目中在使用了9宫图后出现了编译错误,尝试了多种方法未能解决,最后仔细查看出错的日志发现,居然是图片的原因,图片中包含有alpah通道所以在执行app:me ...

  9. ionic ng-src 在网页显示,但是导出apk在android手机中运行不显示图片

    解决方法参照: http://stackoverflow.com/questions/29896158/load-image-using-ng-src-in-android-ionic-aplicat ...

随机推荐

  1. Android图片与缩略

    /** * 将图片文件原比例缩略.并使其不超过最大宽.高 * @param path : 图片文件 * @param requestW : 缩略后最大宽度 * @param requestH : 缩略 ...

  2. C语言及程序设计[套餐]课程主页

    课程链接:http://edu.csdn.net/combo/detail/30,提供全部的视频和课件下载. 三部分的课程主页.提供了为每一课时配套的自測.演示样例下载,以及程序阅读.程序填空.实践项 ...

  3. maven command to create your application

    How do I make my first Maven project? We are going to jump headlong into creating your first Maven p ...

  4. 【linux】重置fedora root密码

    I forget root password on fedora,debian.fedora 17 fedora 18 fedora 19 fedora 20 fedora 21 fedora .de ...

  5. FFmpeg源码结构图 - 编码

    ===================================================== FFmpeg的库函数源码分析文章列表: [架构图] FFmpeg源码结构图 - 解码 FFm ...

  6. jquery 圆形进度条

    最近手里面的项目需要完成这个对设备性能的检测显示功能,需要使用到圆形进度条这样的效果,网上找了一圈,有很多相当的插件,找到:circliful 插件,看了他的使用说明比较的方便,于是就下载了它并将自己 ...

  7. JVM:垃圾回收机制和调优手段

    转载请注明出处: jiq•钦's technical Blog - 季义钦 引言: 我们都知道JVM内存由几个部分组成:堆.方法区.栈.程序计数器.本地方法栈 JVM垃圾回收仅针对公共内存区域即:堆和 ...

  8. How to set up OpenERP for various timezone kindly follow the following steps to select timezone in OpenERP

        How to set up OpenERP for different Time Zones Click on the "Edit Preferences" wheel a ...

  9. OpenERP 的XML-RPC的轻度体验+many2many,one2many,many2one创建方式

    来自:http://cn.openerp.cn/openerp_import_image_by_xmlrpc/ 每当夏秋之交,我们都有展会,展会完后,都有很多的新的潜在客户要添加,我们收了一大堆名片, ...

  10. libevent个人理解

    1.利用了前置声明来在c语言的基础上进行封装操作.即在include目录下防止event.h等头文件,在这些头文件中只暴露struct的声明却不暴露其定义,对于如event_base等结构的操作均使用 ...