https://www.cnblogs.com/popfisher/p/6959106.html
https://www.cnblogs.com/dasusu/p/9789389.html
? ? ? ? ? ? (以上兩篇博客很不錯)
我們先假設(shè)我們有一張圖片時(shí) 600 * 800 的败去,圖片占用空間大小假設(shè)是 100KB。
圖片內(nèi)存大小跟占用空間大小有什么關(guān)系?
占用空間的大小不是圖片占用內(nèi)存的大小,一些初學(xué)者可能會誤解一下。占用空間是在磁盤上占用的空間颅筋,內(nèi)存大小是加載到內(nèi)存中占用的內(nèi)存大小。兩個(gè)只是單位是一樣的,本質(zhì)不是一個(gè)概念竭缝。
一張圖片到底占用多少內(nèi)存呢?
1. 圖片占用內(nèi)存的計(jì)算公式:圖片高度 * 圖片寬度 * 一個(gè)像素占用的內(nèi)存大小
2. 所以上面的圖片占用內(nèi)存是:800 * 600 * 4 byte = 1875KB = 1.83M?
當(dāng)圖片放在 res 內(nèi)的不同目錄中時(shí)沼瘫,為什么最終圖片加載進(jìn)內(nèi)存所占據(jù)的大小會不一樣呢抬纸?
如果你們?nèi)タ聪翨itmap.decodeResource()源碼,你們會發(fā)現(xiàn)耿戚,系統(tǒng)在加載 res 目錄下的資源圖片時(shí)湿故,會根據(jù)圖片存放的不同目錄做一次分辨率的轉(zhuǎn)換,而轉(zhuǎn)換的規(guī)則是:
新圖的高度 = 原圖高度 * (設(shè)備的 dpi / 目錄對應(yīng)的 dpi )
新圖的寬度 = 原圖寬度 * (設(shè)備的 dpi / 目錄對應(yīng)的 dpi )
目錄名稱與 dpi 的對應(yīng)關(guān)系如下膜蛔,drawable 沒帶后綴對應(yīng) 160 dpi:
所以坛猪,我們來看下序號 2 的實(shí)驗(yàn),按照上述理論的話皂股,我們來計(jì)算看看這張圖片的內(nèi)存大惺浴:
轉(zhuǎn)換后的分辨率:1080 * (240/160) * 452 * (240/160) = 1620 * 678
同一圖片,在同一臺設(shè)備中呜呐,如果圖片放在 res 內(nèi)的不同資源目錄下就斤,那么圖片占用的內(nèi)存空間是會不一樣的
同一圖片,放在 res 內(nèi)相同的資源目錄下卵史,但在不同 dpi 的設(shè)備中战转,圖片占用的內(nèi)存空間也是會不一樣的
圖片優(yōu)化
所以,如果單從圖片本身考慮優(yōu)化的話以躯,也就只有兩個(gè)方向:
降低分辨率
減少每個(gè)像素點(diǎn)大小
總結(jié)
最后槐秧,來稍微總結(jié)一下:
一張圖片占用的內(nèi)存大小的計(jì)算公式:分辨率 * 像素點(diǎn)大小忧设;但分辨率不一定是原圖的分辨率刁标,需要結(jié)合一些場景來討論,像素點(diǎn)大小就幾種情況:ARGB_8888(4B)址晕、RGB_565(2B) 等等膀懈。
如果不對圖片進(jìn)行優(yōu)化處理,如壓縮谨垃、裁剪之類的操作启搂,那么 Android 系統(tǒng)會根據(jù)圖片的不同來源決定是否需要對原圖的分辨率進(jìn)行轉(zhuǎn)換后再加載進(jìn)內(nèi)存硼控。
圖片來源是 res 內(nèi)的不同資源目錄時(shí),系統(tǒng)會根據(jù)設(shè)備當(dāng)前的 dpi 值以及資源目錄所對應(yīng)的 dpi 值胳赌,做一次分辨率轉(zhuǎn)換牢撼,規(guī)則如下:新分辨率 = 原圖橫向分辨率 * (設(shè)備的 dpi / 目錄對應(yīng)的 dpi ) * 原圖縱向分辨率 * (設(shè)備的 dpi / 目錄對應(yīng)的 dpi )。
其他圖片的來源疑苫,如磁盤熏版,文件,流等捍掺,均按照原圖的分辨率來進(jìn)行計(jì)算圖片的內(nèi)存大小撼短。
jpg、png 只是圖片的容器挺勿,圖片文件本身的大小與它所占用的內(nèi)存大小沒有什么關(guān)系曲横。
基于以上理論,以下場景的出現(xiàn)是合理的:
同個(gè) app满钟,在不同 dpi 設(shè)備中胜榔,同個(gè)界面的相同圖片所占的內(nèi)存大小有可能不一樣胳喷。
同個(gè) app湃番,同一張圖片,但圖片放于不同的 res 內(nèi)的資源目錄里時(shí)吭露,所占的內(nèi)存大小有可能不一樣吠撮。
以上場景之所說有可能,是因?yàn)榻哺停坏┦褂媚硞€(gè)熱門的圖片開源庫泥兰,那么,以上理論基本就不適用了题禀。
因?yàn)橄到y(tǒng)支持對圖片進(jìn)行優(yōu)化處理鞋诗,允許先將圖片壓縮,降低分辨率后再加載進(jìn)內(nèi)存迈嘹,以達(dá)到降低占用內(nèi)存大小的目的
而熱門的開源圖片庫削彬,內(nèi)部基本都會有一些圖片的優(yōu)化處理操作:
當(dāng)使用 fresco 時(shí),不管圖片來源是哪里秀仲,即使是 res融痛,圖片占用的內(nèi)存大小仍舊以原圖的分辨率計(jì)算。
當(dāng)使用 Glide 時(shí)神僵,如果有設(shè)置圖片顯示的控件雁刷,那么會自動按照控件的大小,降低圖片的分辨率加載保礼。圖片來源是 res 的分辨率轉(zhuǎn)換規(guī)則對它也無效沛励。
的