Android圖片性能優(yōu)化詳解
1. 圖片的格式
目前移動(dòng)端Android平臺(tái)原生支持的圖片格式主要有:JPEG、PNG、GIF、BMP、和WebP(自從Android 4.0開(kāi)始支持),但是在Android應(yīng)用開(kāi)發(fā)中能夠使用的編解碼格式只有三種:JPEG、PNG、WebP,圖片格式可以通過(guò)查看Bitmap類(lèi)的CompressFormat枚舉值來(lái)確定。
public static enum CompressFormat { JPEG、 PNG、 WebP; private CompressFormat() { } }
如果要在應(yīng)用層使用GIF格式圖片,那么需要自己引用第三方函數(shù)庫(kù)進(jìn)行支持。
1.1 JPEG
JPEG是一種廣泛使用的有損壓縮圖像標(biāo)準(zhǔn)格式,它不支持透明和多幀動(dòng)畫(huà),一般攝像類(lèi)作品最終都是以JPEG格式展示。通過(guò)控制壓縮比,可以調(diào)整圖片的大小。
1.2 PNG
PNG是一種無(wú)損壓縮圖片格式,它支持完整的透明通道,從圖像處理領(lǐng)域?qū)?,JPEG只有RGB三個(gè)通道,而PNG有ARGB四個(gè)通道。由于是無(wú)損壓縮,因此PNG圖片占用空間一般比較大,會(huì)無(wú)形中增加最終APP的大小,在做APP瘦身時(shí)一般都要對(duì)PNG圖片進(jìn)行處理以減小其占用的體積。
1.3 GIF
GIF是一種古老的圖片格式,它誕生于1987年,它的特點(diǎn)是支持多幀動(dòng)畫(huà)。
1.4 WebP
WebP由Google在2010年發(fā)布,它支持有損和無(wú)損壓縮、支持完整的透明通道、也支持多幀動(dòng)畫(huà),是一種比較理想的圖片格式。在既保證圖片質(zhì)量又要限制圖片大小的需求下,WebP應(yīng)該是首選。
2. 圖片的壓縮
目前大多數(shù)APP都是PNG格式圖片資源,我們可以通過(guò)幾個(gè)工具對(duì)PNG圖片進(jìn)行壓縮來(lái)達(dá)到瘦身的目的。
2.1 無(wú)損壓縮ImageOptim
ImageOptim是一個(gè)無(wú)損的壓縮工具,它通過(guò)優(yōu)化PNG壓縮參數(shù),移除冗余元數(shù)據(jù)以及非必需的顏色配置文件等方式,在不犧牲圖片質(zhì)量的前提下,既減少了PNG圖片占用的空間,又提高了加載的速度。
2.2 有損壓縮ImageAlpha
ImageAlpha是ImageOptim作者開(kāi)發(fā)的一個(gè)有損的PNG壓縮工具,相比較而言,圖片大小得到極大的降低,當(dāng)然圖片質(zhì)量同事也會(huì)受到一定程度的影響,經(jīng)過(guò)該工具壓縮的圖片,需要經(jīng)過(guò)設(shè)計(jì)師的確認(rèn)才能最終上線,否則可能回影響整個(gè)APP的視覺(jué)效果。
2.3 有損壓縮TinyPNG
TinyPNG也是比較知名的有損PNG壓縮工具,它以Web站點(diǎn)的形式提供,沒(méi)有獨(dú)立的APP安裝包,同所有的有損壓縮工具一樣,經(jīng)過(guò)壓縮的圖片,需要經(jīng)過(guò)設(shè)計(jì)師的確認(rèn)才能最終上線,否則可能回影響整個(gè)APP的視覺(jué)效果。
還有很多無(wú)損壓縮工具,例如JPEGMini、MozJPEG等,大家自行選擇適合自己項(xiàng)目的一個(gè)就行,主要是在圖片大小和圖片質(zhì)量之間找到一個(gè)折中點(diǎn)。
2.4 PNG/JPEG 轉(zhuǎn)換為WebP
如果你的APP最低支持到Android4.0,那么可以直接使用系統(tǒng)提供的能力來(lái)支持WebP,如果是4.0以下的系統(tǒng),也可以通過(guò)在APP中集成第三方函數(shù)庫(kù)例如webp-android-backport來(lái)實(shí)現(xiàn)對(duì)WebP的支持。根據(jù)Google測(cè)試,無(wú)損壓縮后的WebP比PNG文件少了45%的文件大小,即使這些PNG文件經(jīng)過(guò)其他壓縮工具例如ImageOptim壓縮后,WebP依然可以減少約28%的文件大小。
WebP轉(zhuǎn)換的工具可以選擇智圖和iSparta等
2.5 盡量使用NinePatch格式的PNG圖
.9.png圖片格式簡(jiǎn)稱(chēng)NinePatch圖,本質(zhì)上仍然是PNG格式圖片,它是針對(duì)Android平臺(tái)的一種特殊PNG格式圖片,可以在圖片指定位置拉伸或者填充內(nèi)容。NinePatch圖的優(yōu)點(diǎn)是體積小,拉伸不變形,能夠很好地適配Android各種機(jī)型。Android SDK自帶了NinePatch圖的編輯工具,位于sdk/tools/draw9patch,點(diǎn)擊即可啟動(dòng);當(dāng)然,Android Studio也集成了PNG轉(zhuǎn)NinePatch的功能,我們只需右鍵點(diǎn)擊某個(gè)需要轉(zhuǎn)換的PNG圖片,在彈出的對(duì)話框中選擇Create 9-Patch File…即可自動(dòng)完成轉(zhuǎn)換。
3. 圖片的緩存
圖片的緩存框架有很多,常見(jiàn)的有四種
- Android-Universal-Image-Loader
- Picasso
- Glide
- Fresco
這四種圖片加載框架的優(yōu)劣就不在一一說(shuō)明,因?yàn)殡S便一搜就可以知道答案,我們可以根據(jù)項(xiàng)目來(lái)權(quán)衡使用哪一個(gè)圖片加載框架。
相關(guān)文章
Android ProgressBar 模擬進(jìn)度條效果的實(shí)現(xiàn)
這篇文章主要介紹了Android ProgressBar 模擬進(jìn)度條效果的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04Android基于Flutter編寫(xiě)文件下載管理器
文件下載在很多類(lèi)型的應(yīng)用中會(huì)涉及,例如音樂(lè)、文檔、包括圖片(只是圖片可以使用一些組件完成無(wú)感知的下載)。本篇介紹使用Flutter中的Dio下載方法完成文件的下載,需要的可以參考一下2022-03-03Android自定義view仿IOS開(kāi)關(guān)效果
這篇文章主要為大家詳細(xì)介紹了Android自定義view仿IOS開(kāi)關(guān)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06android連續(xù)拖動(dòng)導(dǎo)致掛起的解決方法
本文給大家分享的是在安卓的項(xiàng)目開(kāi)發(fā)中遇到連續(xù)拖動(dòng)對(duì)象,導(dǎo)致掛起的問(wèn)題的解決方法,也是經(jīng)過(guò)很多網(wǎng)友的提示,最終才找到解決方法,這里記錄一下,分享給大家。2015-05-05Android開(kāi)發(fā)中的錯(cuò)誤及解決辦法總結(jié)
本文屬于個(gè)人平時(shí)項(xiàng)目開(kāi)發(fā)過(guò)程遇到的一些問(wèn)題,記錄下來(lái)并總結(jié)解決方案,希望能幫到大家解決問(wèn)題,需要的朋友可以參考下2022-02-02解決android studio引用遠(yuǎn)程倉(cāng)庫(kù)下載慢(JCenter下載慢)
這篇文章主要介紹了解決android studio引用遠(yuǎn)程倉(cāng)庫(kù)下載慢(JCenter下載慢),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Android Studio default not found錯(cuò)誤解決辦法
這篇文章主要介紹了Android Studio gradle 編譯提示‘default not found’ 解決辦法的相關(guān)資料,需要的朋友可以參考下2017-01-01Android中實(shí)現(xiàn)淘寶購(gòu)物車(chē)RecyclerView或LIstView的嵌套選擇的邏輯
這篇文章主要介紹了Android中實(shí)現(xiàn)淘寶購(gòu)物車(chē)RecyclerView或LIstView的嵌套選擇的邏輯,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12Android制作一個(gè)錨點(diǎn)定位的ScrollView
這篇文章主要介紹了Android制作一個(gè)錨點(diǎn)定位的ScrollView,幫助大家更好的理解和學(xué)習(xí)使用Android,感興趣的朋友可以了解下2021-04-04