青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

Android App自適應draw9patch不失真背景圖

轉載自:http://www.cnblogs.com/qianxudetianxia/archive/2011/04/17/2017591.html

做人要大度,海納百川,做事要圓滑,左右逢源,這讓我想到了編程也是如此,代碼要擴展,界面也要考慮自適應。
這篇文章是android開發人員的必備知識,是我特別為大家整理和總結的,不求完美,但是有用。

1.背景自適應且不失真問題的存在
      制作自適應背景圖片是UI開發的一個廣泛問題,也是界面設計師渴望解決的問題,我相信我們彼此都深有體會。
      比如,列表的背景圖一定,但是列表的高度隨著列表數據項會發生變化;標題欄的背景,無論橫屏還是豎屏,高分辨率還是低分辨率,都能自動填充滿,而且不失真等等背景問題。
      根據以往的經驗,我們一般采用先切圖后拼湊的做法,這種做法本來我想在這里和大家介紹一下,其實有的時候還是很有用的,但是說起來會比較麻煩,就不說這個非重點了,略去,如果大家真的要介紹,在回復中說明,我再考慮一下。
     Android針對這種情況,專門制作了一種.9.PNG格式來解決這個問題。

2.9.PNG格式。
      我不想在這里過多的討論PNG格式的定義問題。但是.9.PNG確實是標準的PNG格式,只是在最外面一圈額外增加1px的邊框,這個1px的邊框就是用來定義圖片中可擴展的和靜態不變的區域。特別說明,left和top邊框中交叉部分是可拉伸部分,未選中部分是靜態區域部分。right和bottom邊框中交叉部分則是內容部分(變相的相當于定義看一個內邊距,神似padding功能,后面我會單獨介紹一下),這個參數是可選的, 如下圖。
     在Android中以9.PNG格式的圖片未背景,則能夠自定義拉伸而不失真,比如系統的Button就是一個典型的例子。 
     其實呢,無論是left和top,還是right和bottom都是把圖片分成9塊 (邊角四塊是不能縮放的,其他的四塊則是允許縮放的),所以叫做9.PNG。

3. 使用Draw9Patch.jar制作9.PNG圖片之定義拉伸區域。
      前面已經了解到9.PNG格式的工作方式,下面我們使用谷歌提供的Draw9Patch(運行android-sdk-windows\tools目錄下的Draw9Patch.bat)來制作.9.PNG圖片。
      第一步:準備要拉伸的圖片。
                                                           
      非常小的一張圖片,我希望以此為背景,中間部分填充文章內容。
      第二步:制作.9.PNG圖片
      打開Draw9Patch,把圖片拖進去,如下:

      默認的拉伸是整體拉伸,其實邊框部分我們并不想拉伸,好,我們自己來定義拉伸區域,如下圖:

       然后點擊File,導出為content.9.png。
       第三步:在layout文件中使用制作的 .9.PNG圖片.
       新建工程Draw9Patch,默認主Activity為Draw9PatchActivity.java:

1
2
3
4
5
6
@Override
public void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
}

      我們把content.9.png文件拷貝到/res/drawable文件夾下,打開/res/layout目錄下的main.xml,申明如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#777"
    android:padding="8dip"
    >
    <TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="正文:A NinePatchDrawable graphic is a stretchable bitmap image."
    android:background="@drawable/content"
    android:textColor="#000"
    />
</LinearLayout>

     如圖,

     我們修改text,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#777"
    android:padding="8dip"
    >
<TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="正文:A NinePatchDrawable graphic is a stretchable bitmap image, which Android will automatically resize to accommodate the contents of the View in which you have placed it as the background. A NinePatch drawable is a standard PNG image that includes an extra 1-pixel-wide border."
    android:background="@drawable/content"
    android:textColor="#000"
    />
</LinearLayout>

      如圖,

      可以看出,邊框非常的清晰。下圖是未使用.9.PNG的對比圖,而且也不是我們要的效果:

      到這里為止,我們已經基本會制作.9.PNG圖片了。為了知識體系的全面性和深入性,我們繼續。

4.使用Draw9Patch.jar制作9.PNG圖片之定義內容區域。
      是不是覺得文字和邊距挨的太近,好,我們使用right和bottom邊的線來定義內容區域,來達到增大內邊距的目的。

      我們定義了一個很小的內容區域,其他的地方則自動充當邊框,從而使內邊距顯的很大,如下圖,

      在這里,我要特別說明,一開始為了增大內邊距,很容易慣性思維,在<TextView>中申明android:padding="10dip" 之類的,我在這里勸告朋友們不要這么做,一是你將無法預知你的顯示,二是這比較混淆,因為設置內容區域就是確定padding,所以我在前面部分說他們是神似。我個人認為通過內容區域設定padding比在布局xml中定義padding更優雅,更簡潔!
      關于Draw9Patch工具的其他使用說明,我在次不再累述,因為要說的話太多,為了節省篇幅,請參考官方文檔。

5.制作.9.PNG的高級技巧。
       對于初學Draw9Patch的人來說,這可以算是高級技巧,那就是:拉伸區域,可以不是連續的,可以不止一塊,而且是和自定義的邊框線的長度成正比。
       直接上圖說明:
 

6.SDK中如何處理9.PNG圖片。
      SDK專門針對9.PNG做了定義和處理,這里我們只是做個簡單的流程分析,Bitmap在讀取圖像流數據的時候,會把判斷圖片的NinePatchChunk(9Patch數據塊),如果NinePatchChunk不為空,則是NinePatchDrawable,NinePatchDrawable則又會交給NinePatch處理:

1
2
3
setNinePatchState(new NinePatchState(
               new NinePatch(bitmap, bitmap.getNinePatchChunk(), "XML 9-patch"),
               padding, dither), r);

      NinePatch檢驗成功則調用本地方法,繪制出最終的圖片:

1
2
3
nativeDraw(canvas.mNativeCanvas, location,
                mBitmap.ni(), mChunk, paint != null ? paint.mNativePaint : 0,
                canvas.mDensity, mBitmap.mDensity);

7.android系統中大量應用了9.PNG圖片。
     通過解壓隨便一個rom,找到里面的framework_res.apk,里面有大量的9.PNG格式文件,被廣泛的應用起來,比如常見的有:
     按鈕:  
     解鎖:  
     下拉框:  
     標題欄:
     Toast:
      還有搜索,鍵盤,放大縮小控件,時間加減等等,我就不一一列舉。

8.最后送上一些圖例,以饗讀者,以做后鑒:
 
賞圖1 本人之作

 賞圖2 下拉按鈕
 
賞圖3 文章頭部背景 
 
賞圖4 系統頭部背景

賞圖5 再來一個頭部背景 
謝謝大家的支持。 

posted on 2015-06-12 15:30 楊粼波 閱讀(568) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品免费看片| 一区二区三区高清不卡| 亚洲国产精品久久久久婷婷老年 | 亚洲系列中文字幕| 99国产精品国产精品久久| 亚洲欧洲三级电影| 欧美xx69| 亚洲精品乱码久久久久久蜜桃91 | 欧美激情按摩| 亚洲第一中文字幕在线观看| 亚洲日本欧美在线| 亚洲深夜福利网站| 久久久999精品免费| 免费人成精品欧美精品| 欧美人与禽猛交乱配| 国产精品一卡| 亚洲国产精品成人综合色在线婷婷| 亚洲精选91| 欧美一区二区三区日韩视频| 美女精品国产| 亚洲色图自拍| 麻豆国产精品一区二区三区| 欧美日韩日韩| 亚洲电影网站| 午夜日本精品| 亚洲欧洲在线免费| 校园激情久久| 欧美黄色aaaa| 狠狠色综合一区二区| 亚洲视频二区| 亚洲福利视频一区| 欧美中在线观看| 国产精品av一区二区| 亚洲大胆视频| 久久精品国产第一区二区三区| 亚洲精品欧洲| 久久综合狠狠| 国产一区视频网站| 亚洲欧美日韩国产中文| 亚洲国产一区二区视频| 久久久www免费人成黑人精品| 欧美午夜精品电影| 99精品免费| 欧美丰满高潮xxxx喷水动漫| 欧美一区2区视频在线观看| 欧美日韩亚洲精品内裤| 亚洲日本免费电影| 男人的天堂亚洲| 欧美影院在线| 国内久久视频| 久久久人成影片一区二区三区观看| 亚洲少妇在线| 国产精品麻豆va在线播放| 一区二区日韩精品| 亚洲日本电影在线| 欧美激情精品久久久六区热门 | 欧美成人免费一级人片100| 国产综合亚洲精品一区二| 欧美一区国产二区| 亚洲免费中文| 国产午夜精品理论片a级大结局 | 艳妇臀荡乳欲伦亚洲一区| 久久综合伊人| 久久久国际精品| 伊人婷婷欧美激情| 免费成人小视频| 美女视频网站黄色亚洲| 亚洲国产婷婷综合在线精品| 欧美成人中文| 欧美精品福利| 9色国产精品| aa亚洲婷婷| 国产精品免费电影| 久久精品噜噜噜成人av农村| 午夜亚洲精品| 黑人巨大精品欧美黑白配亚洲| 久久久久久久性| 久久夜色精品国产欧美乱极品| 亚洲国产精品传媒在线观看| 亚洲国产综合视频在线观看| 欧美精品在线免费观看| 在线亚洲欧美专区二区| 亚洲欧美日韩国产精品| 狠狠综合久久| 99视频一区二区| 国产一区二区| 91久久国产自产拍夜夜嗨| 男人的天堂亚洲在线| 久久性色av| 亚洲小少妇裸体bbw| 午夜亚洲伦理| 日韩视频在线观看国产| 亚洲自拍偷拍网址| 亚洲国产高清一区| 亚洲小说区图片区| 亚洲国产精品电影在线观看| 日韩视频免费看| 国产在线高清精品| 亚洲精品一区二区三区蜜桃久| 国产女主播一区二区三区| 欧美刺激性大交免费视频| 欧美午夜精品久久久久久浪潮| 久久这里只有| 国产精品成人国产乱一区| 欧美成人精品福利| 国产精品免费在线 | 欧美激情亚洲视频| 国产精品视频免费观看| 亚洲国产另类 国产精品国产免费| 欧美午夜精品久久久久久久| 免费在线观看一区二区| 国产精品自拍三区| 亚洲精品网址在线观看| 好看的亚洲午夜视频在线| 99热精品在线观看| 午夜老司机精品| 亚洲综合社区| 欧美日韩三区| 亚洲大片免费看| 国产在线精品一区二区夜色| 久久精品综合网| 亚洲精品国久久99热| 黄色一区二区三区| 亚洲线精品一区二区三区八戒| 亚洲经典三级| 久久中文欧美| 久色婷婷小香蕉久久| 国产精品亚洲成人| 一区二区三区视频观看| 日韩午夜在线| 欧美国产日韩一区二区在线观看| 老司机一区二区| 国产真实精品久久二三区| 亚洲欧美国产另类| 午夜精品久久久久久久久久久久| 欧美三级电影一区| av成人免费在线观看| 一区二区三区欧美| 欧美日韩一区二区高清| 亚洲精品韩国| 亚洲午夜久久久| 国产精品国产三级国产aⅴ9色| 亚洲美女电影在线| 亚洲无线观看| 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲一区二区三区精品在线观看 | 欧美大片免费久久精品三p | 亚洲作爱视频| 欧美日韩福利| 亚洲视频自拍偷拍| 亚洲欧美日韩国产中文| 国产精品一区二区久久国产| 亚洲免费综合| 免费欧美日韩| 日韩一级片网址| 国产精品久久久爽爽爽麻豆色哟哟 | 国产婷婷色一区二区三区四区| 亚洲欧美日韩一区二区| 久久精品一区二区| **性色生活片久久毛片| 欧美大片在线观看一区二区| 日韩视频在线观看国产| 欧美一区免费视频| 伊人一区二区三区久久精品| 欧美成人精品一区二区| 一本久道久久综合狠狠爱| 性欧美大战久久久久久久久| 韩国欧美一区| 欧美日韩dvd在线观看| 亚洲一区日韩在线| 欧美成人中文字幕在线| 亚洲男人第一网站| 亚洲成人在线| 国产伦精品一区二区三区高清版| 久久久久久久久岛国免费| 日韩一级不卡| 免费欧美高清视频| 亚洲欧美日本国产有色| 亚洲国产精品一区二区尤物区| 亚洲与欧洲av电影| 最新日韩欧美| 国产精品观看| 美女图片一区二区| 亚洲欧美一区二区三区在线| 欧美国产日本| 欧美影院成人| 一区二区三区毛片| 亚洲人成网站777色婷婷| 国产女主播一区二区| 欧美日韩精品欧美日韩精品一| 欧美在线视频免费播放| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 毛片一区二区| 性久久久久久久久久久久| 亚洲人成亚洲人成在线观看图片 | 99成人精品| 亚洲二区精品| 你懂的成人av| 久久婷婷国产麻豆91天堂| 欧美一级久久|