由于測試手機(jī)的密度是屬于xxhdpi新荤,我們在drawable-xxhdpi里面的圖片基本都會按照原圖的大小展示盗迟。將drawable-xxhdpi里面的圖片移動到drawable-xhdpi或者drawable-hdpi目錄圆恤,會發(fā)現(xiàn)圖片明顯被放大了。
圖片為什么會放大呢?
當(dāng)我們使用資源id來去引用一張圖片時逝慧,Android會使用一些規(guī)則來去幫我們匹配最適合的圖片衬浑。什么叫最適合的圖片捌浩?比如我的手機(jī)屏幕密度是xxhdpi,那么drawable-xxhdpi文件夾下的圖片就是最適合的圖片工秩。在這種情況下尸饺,圖片是不會被縮放的进统。但是,如果drawable-xxhdpi文件夾下沒有這張圖時浪听,系統(tǒng)就會自動去其它文件夾下找這張圖了螟碎,優(yōu)先會去更高密度的文件夾下找這張圖片,我們當(dāng)前的場景就是drawable-xxxhdpi文件夾迹栓,然后發(fā)現(xiàn)這里也沒有這張圖掉分,接下來會嘗試再找更高密度的文件夾,發(fā)現(xiàn)沒有更高密度的了克伊,這個時候會去drawable-nodpi文件夾找這張圖酥郭,發(fā)現(xiàn)也沒有,那么就會去更低密度的文件夾下面找答毫,依次是drawable-xhdpi-> drawable-hdpi -> drawable-mdpi -> drawable-ldpi褥民。
總體匹配規(guī)則就是這樣,那么比如說現(xiàn)在終于在drawable-mdpi文件夾下面找到這張圖了洗搂,但是系統(tǒng)會認(rèn)為你這張圖是專門為低密度的設(shè)備所設(shè)計的消返,如果直接將這張圖在當(dāng)前的高密度設(shè)備上使用就有可能會出現(xiàn)像素過低的情況,于是系統(tǒng)自動幫我們做了這樣一個放大操作耘拇。那么同樣的道理撵颊,如果系統(tǒng)是在drawable-xxxhdpi文件夾下面找到這張圖的話,它會認(rèn)為這張圖是為更高密度的設(shè)備所設(shè)計的惫叛,如果直接將這張圖在當(dāng)前設(shè)備上使用就有可能會出現(xiàn)像素過高的情況倡勇,于是會自動幫我們做一個縮小的操作。
另外嘉涌,剛才在介紹規(guī)則的時候提到了一個drawable-nodpi文件夾妻熊,這個文件夾是一個密度無關(guān)的文件夾,放在這里的圖片系統(tǒng)就不會對它進(jìn)行自動縮放仑最,原圖片是多大就會實際展示多大扔役。但是要注意一個加載的順序,drawable-nodpi文件夾是在匹配密度文件夾和更高密度文件夾都找不到的情況下才會去這里查找圖片的警医,因此放在drawable-nodpi文件夾里的圖片通常情況下不建議再放到別的文件夾里面亿胸。
圖片被放大的原因現(xiàn)在我們已經(jīng)搞清楚了,那么接下來還有一個問題预皇,就是放大的倍數(shù)是怎么確定的呢侈玄?
每一種密度的dpi范圍都有一個最大值,這個最大值之間的比例就是圖片會被系統(tǒng)自動放大的比例吟温。
根據(jù)Android的開發(fā)建議序仙,我們在準(zhǔn)備圖片資源時盡量應(yīng)該給每種密度的設(shè)備都準(zhǔn)備一套,這樣程序的適配性就可以達(dá)到最好鲁豪。但實際情況是诱桂,公司的UI們通常就只會給一套圖片資源洋丐,想讓他們針對每種密度的設(shè)備都設(shè)計一套圖片資源呈昔,并且還是按照我們上面講的縮放比例規(guī)則來設(shè)計挥等,就有點想得太開心了。沒錯堤尾,這個就是現(xiàn)實情況肝劲,那么在這種情況下,我們應(yīng)該將僅有的這一套圖片資源放在哪個密度的文件夾下呢郭宝?
可以這樣來分析辞槐,根據(jù)我們剛才所學(xué)的內(nèi)容,如果將一張圖片放在低密度文件夾下粘室,那么在高密度設(shè)備上顯示圖片時就會被自動放大榄檬,而如果將一張圖片放在高密度文件夾下,那么在低密度設(shè)備上顯示圖片時就會被自動縮小衔统。那我們可以通過成本的方式來評估一下鹿榜,一張原圖片被縮小了之后顯示其實并沒有什么副作用,但是一張原圖片被放大了之后顯示就意味著要占用更多的內(nèi)存了锦爵。因為圖片被放大了舱殿,像素點也就變多了,而每個像素點都是要占用內(nèi)存的险掀。
那么經(jīng)過上面一系列的分析沪袭,答案自然也就出來了,圖片資源應(yīng)該盡量放在高密度文件夾下樟氢,這樣可以節(jié)省圖片的內(nèi)存開支冈绊,而UI在設(shè)計圖片的時候也應(yīng)該盡量面向高密度屏幕的設(shè)備來進(jìn)行設(shè)計。就目前來講埠啃,最佳放置圖片資源的文件夾就是drawable-xxhdpi死宣。可能會問了霸妹,不是還有更高密度的drawable-xxxhdpi嗎十电?干嗎不放在這里?這是因為叹螟,市面上480dpi到640dpi的設(shè)備實在是太少了鹃骂,如果針對這種級別的屏幕密度來設(shè)計圖片,圖片在不縮放的情況下本身就已經(jīng)很大了罢绽,基本也起不到節(jié)省內(nèi)存開支的作用了畏线。
圖片在內(nèi)存中占用的大小取決于以下三個因素
1.色彩格式,如果是 ARGB8888 那么就是一個像素4個字節(jié)良价,如果是 RGB565 那就是2個字節(jié)
2.原始文件存放的資源目錄(是 hdpi 還是 xxhdpi )
3.目標(biāo)屏幕的密度(所以同等條件下寝殴,紅米在資源方面消耗的內(nèi)存肯定是要小于三星S6的)