• <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>

            逛奔的蝸牛

            我不聰明,但我會(huì)很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::

            “點(diǎn)九”是andriod平臺(tái)的應(yīng)用軟件開(kāi)發(fā)里的一種特殊的圖片形式,文件擴(kuò)展名為:.9.png

              智能手機(jī)中有自動(dòng)橫屏的功能,同一幅界面會(huì)在隨著手機(jī)(或平板電腦)中的方向傳感器的參數(shù)不同而改變顯示的方向,在界面改變方向后,界面上的圖形會(huì)因?yàn)殚L(zhǎng)寬的變化而產(chǎn)生拉伸,造成圖形的失真變形。

              我們都知道android平臺(tái)有多種不同的分辨率,很多控件的切圖文件在被放大拉伸后,邊角會(huì)模糊失真。

              OK,在android平臺(tái)下使用點(diǎn)九PNG技術(shù),可以將圖片橫向和縱向同時(shí)進(jìn)行拉伸,以實(shí)現(xiàn)在多分辨率下的完美顯示效果。

              【普通拉伸和點(diǎn)九拉伸效果對(duì)比】

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              對(duì)比很明顯,使用點(diǎn)九后,仍能保留圖像的漸變質(zhì)感,和圓角的精細(xì)度。

              從中我們也可以理解為什么叫“點(diǎn)九PNG”,其實(shí)相當(dāng)于把一張png圖分成了9個(gè)部分(九宮格),分別為4個(gè)角,4條邊,以及一個(gè)中間區(qū)域,4個(gè)角是不做拉升的,所以還能一直保持圓角的清晰狀態(tài),而2條水 平邊和垂直邊分別只做水平和垂直拉伸,所以不會(huì)出現(xiàn)邊會(huì)被拉粗的情況,只有中間用黑線指定的區(qū)域做拉伸。結(jié)果是圖片不會(huì)走樣

              二.“點(diǎn)九”的制作方法

              方法1:使用 “draw9patch”工具繪制,流程如下

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              1. 安裝工具

              首先你需要給自己的電腦安裝上java于系統(tǒng)的默認(rèn)目錄下。沒(méi)有安裝java的同學(xué)可以在百度搜索:jdk-6u20-windows-i586,安裝包大小80M左右。

              然后使用andriod模擬器—android-sdk-windows,打開(kāi)SDK/tools目錄下的“draw9patch.bat”文件,出現(xiàn)載入窗口:

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              2.導(dǎo)入并編輯

              將png圖片拖拽到該窗口中

              如下圖,自動(dòng)進(jìn)入編輯界面。圖中介紹了每個(gè)區(qū)域的內(nèi)容及功能注釋。

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              預(yù)覽右側(cè)的視圖發(fā)現(xiàn),圖片的邊緣處于普通拉伸狀態(tài)。

              現(xiàn)在我們?cè)趫D片邊緣點(diǎn)擊左鍵,繪制出黑線,即圖片需要被拉伸的部分。如下圖,對(duì)4條黑線做了注釋。

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              如果失誤多繪的部分,可按住shift鍵的同時(shí)點(diǎn)擊鼠標(biāo)左鍵擦除)。

              如圖所見(jiàn),三種拉伸結(jié)果均已完美顯示,已實(shí)現(xiàn)我們想要的拉伸效果,假設(shè)這是一個(gè)有顯示文字的窗體,那么文字顯示的區(qū)域,程序也會(huì)控制在黑線對(duì)應(yīng)范圍。

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              以下這些圖片,包括異性(非規(guī)則圖形)圖片,也可以通過(guò)點(diǎn)九PNG實(shí)現(xiàn)橫縱向的自然拉伸。

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事
            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              【draw9patch.bat其他功能說(shuō)明】

              ② Show lock:顯示不可繪區(qū)域

              ② Show patches:預(yù)覽這個(gè)繪圖區(qū)中的可延伸宮格(粉紅色代表一個(gè)可延伸區(qū)域)

              ③ Show patches:預(yù)覽視圖中的高亮區(qū)域(紫色區(qū)域)

              ④ Show bad patches:在宮格區(qū)域四周增加一個(gè)紅色邊界,這可能會(huì)在圖像被延伸時(shí)產(chǎn)生人工痕跡。如果你消除所有的壞宮格,延伸視圖的視覺(jué)一致性將得到維護(hù)。

              3.保存和輸出

              點(diǎn)擊左上file- save,保存文件,自動(dòng)生成一張后綴名為“*.9.png”格式的圖片,圖片上下左右各增加了1px的黑線。

              方法2:直接使用 PS等平面工具繪制,流程圖如下

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              如流程圖所示,相對(duì)與方法1,只需2個(gè)步驟就可得到.9.png圖片,具體步驟為:

              1. 確定切圖后直接改變圖片的畫(huà)布大小,

              2. 手動(dòng)將上下左右各增加1px

              3. 使用鉛筆工具,手動(dòng)繪制拉伸區(qū)域,色值必須為黑色(#000000)。

              4. 存儲(chǔ)為web所用格式,選擇png-24,儲(chǔ)存時(shí)手動(dòng)將后綴名改為.9.png

              不過(guò)這種方法的缺點(diǎn)是不能實(shí)時(shí)預(yù)覽,判斷并測(cè)試?yán)靺^(qū)域的準(zhǔn)確性。

              使用此方法需要注意以下2點(diǎn):

              1. 手繪的黑線拉伸區(qū)必須是#000000,透明度100%,并且圖像四邊不能出現(xiàn)半透明像素;

              2. 你的.9.png必須繪有拉伸區(qū)域的黑線;

              否則,圖片不會(huì)通過(guò)android系統(tǒng)編譯,導(dǎo)致程序報(bào)錯(cuò)。還有,有同學(xué)疑惑解壓縮apk文件后,.9.png圖片里的黑線怎么沒(méi)了?

              那是因?yàn)閍ndriod程序在把文件打包成apk的時(shí)候,程序會(huì)自動(dòng)把*.9.png圖片邊緣的黑線去掉,所以解壓縮apk后看到的.9.png文件是沒(méi)有黑線的。

              三.使用“點(diǎn)九”的意義

              關(guān)于下圖,經(jīng)過(guò)測(cè)試發(fā)現(xiàn)使用普通png的顯示效果出現(xiàn)明顯的變色橫紋。而.9.png圖片的顯示效果明顯優(yōu)于普通png。

            android平臺(tái)下使用點(diǎn)九PNG技術(shù),互聯(lián)網(wǎng)的一些事

              使用.9.png格式后,橫紋問(wèn)題基本已解決。因?yàn)閷?duì)于.9.png圖片,android系統(tǒng)程序有對(duì)其優(yōu)化的算法。

              由于android手機(jī)屏幕的材質(zhì)質(zhì)量差距大。很多屏幕不支持16位以上的顏色顯示。

              所以渲染后結(jié)果出現(xiàn)丟失顏色,故造成橫紋顯示。

              經(jīng)與多款android手機(jī)對(duì)比后發(fā)現(xiàn),屏幕越次的手機(jī)橫紋越明顯。

              而使用了*.9.png圖片技術(shù)后,只需要采用一套界面切圖去適配不同的分辨率,而且大幅減少安裝包的大小。而且這樣程序不需要專(zhuān)門(mén)做處理的就可以實(shí)現(xiàn)其拉伸,也減少了代碼量和開(kāi)發(fā)工作量。

              相信每個(gè)人android平臺(tái)的切圖工作,會(huì)有不同的技巧和心得,非常歡迎大家能在評(píng)論中留下自己的個(gè)人經(jīng)驗(yàn)及心得。相互交流會(huì)讓我們的工作模式更靈活,更高效,同時(shí)帶給大家更多優(yōu)質(zhì)的移動(dòng)端應(yīng)用:)

              轉(zhuǎn)載請(qǐng)注明出自”百度MUX”

            @import url(http://www.shnenglu.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
            posted on 2013-06-05 08:05 逛奔的蝸牛 閱讀(554) 評(píng)論(1)  編輯 收藏 引用 所屬分類(lèi): Java

            評(píng)論

            # re: Java: android平臺(tái)下使用點(diǎn)九PNG技術(shù) 2014-07-19 11:52 Friv 4
            感謝您的教程。完美定時(shí),以及!偉大的工程,很容易調(diào)整。  回復(fù)  更多評(píng)論
              

            久久青草国产精品一区| 精品久久一区二区| 久久久SS麻豆欧美国产日韩| 无码人妻精品一区二区三区久久 | 精产国品久久一二三产区区别| 久久精品亚洲精品国产欧美| 日韩美女18网站久久精品| 日韩一区二区三区视频久久| 久久久精品人妻一区二区三区蜜桃| 久久精品国产99久久无毒不卡 | 综合网日日天干夜夜久久| 国产精品久久一区二区三区| 亚洲欧洲精品成人久久奇米网| 久久精品国产亚洲av高清漫画| 久久亚洲av无码精品浪潮| 久久偷看各类wc女厕嘘嘘| 日韩影院久久| 99久久伊人精品综合观看| 久久久无码一区二区三区| 亚洲国产高清精品线久久| 99久久成人18免费网站| 久久久久久九九99精品| 精品国产乱码久久久久软件| 久久精品国产精品亚洲人人| 国产99精品久久| 新狼窝色AV性久久久久久| 一极黄色视频久久网站| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久91精品国产91久久小草| 久久久久亚洲AV成人网人人网站| 九九精品99久久久香蕉| 久久久亚洲裙底偷窥综合| 亚洲国产成人久久综合一区77| 久久国产精品偷99| 久久91精品综合国产首页| 久久青草国产精品一区| 久久综合丝袜日本网| 久久不射电影网| 婷婷综合久久中文字幕| 精品无码人妻久久久久久| 久久久久99精品成人片|