android 9patch超詳細教程

來源:互聯網
上載者:User

這篇文章是android開發人員的必備知識,內容摘選自網路,不求完美,但是有用。

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

2.9.PNG格式。
      *.9.PNG就標準的PNG格式,只是在最外面一圈額外增加1px的邊框,這個1px的邊框就是用來定義圖片中可擴充的和靜態不變的地區。特別說明,left(左)和top(上)邊框中交叉部分是可展開部分,未選中部分是靜態地區部分。right和bottom(下和右)邊框中交叉部分則是內容部分。
 
如《也就是說,在手機裡。無論上面那張圖怎麼放大,四周的圓角都是不會被放大的!只有left(左)和top(上)邊框內才會伸縮!

在Android中以9.PNG格式的圖片未背景,則能夠自訂展開而不失真,比如系統的Button就是一個典型的例子。
     其實呢,無論是left和top,還是right和bottom都是把圖片分成9塊 (邊角四塊是不能縮放的,其他的四塊則是允許縮放的),所以叫做9.PNG。

3.
使用Draw9Patch.jar製作9.PNG圖片之定義展開地區。


      前面已經瞭解到9.PNG格式的工作方式,下面我們使用工具Draw9Patch(ADK內建)來製作.9.PNG圖片。
      
第一步:準備要展開的圖片。


預設的展開是整體展開,其實邊框部分我們並不想展開,好,我們自己來定義展開地區,如

 

然後點擊File,匯出為content.9.png。

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

 

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

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

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

呵呵!ok了!

5.製作.9.PNG的進階技巧。
       對於初學Draw9Patch的人來說,這可以算是進階技巧,那就是:展開地區,可以不是連續的,可以不止一塊,而且是和自訂的邊框線的長度成正比。
       直接說明:

........ 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.