Android全面的屏幕適配方案解析(一)
自Android系統(tǒng)發(fā)布以來,似乎一直繞不開屏幕適配這個話題。毫無疑問,Android系統(tǒng)能發(fā)展到今天,離不開其開放性,而隨著國內(nèi)手機(jī)廠商的崛起,任何用戶、開發(fā)者、OEM廠商、運營商都可以對Android進(jìn)行定制,于是導(dǎo)致長期以來一直詬病的碎片化嚴(yán)重的問題。
例如:
Android系統(tǒng)碎片化,比如基于Google原生系統(tǒng)定制:小米的MIUI系統(tǒng)、魅族的Flyme系統(tǒng)等等。
Android屏幕尺寸碎片化,比如5寸、5.99寸、6寸等等。
Android屏幕分辨率碎片化,比如320x480、480x800、720x1280、1080x1920等等。
而當(dāng)Android系統(tǒng)、屏幕尺寸、屏幕密度出現(xiàn)碎片化的時候,就很容易出現(xiàn)同一元素在不同手機(jī)上顯示不同的問題,為了保證某一元素在Android不同尺寸、不同分辨率的手機(jī)上具備相同的顯示效果,這個時候就需要對屏幕進(jìn)行適配啦。
屏幕適配相關(guān)概念:
屏幕尺寸
屏幕尺寸指屏幕的對角線的物理長度,單位是英寸,1英寸=2.54厘米。
比如常見的屏幕尺寸:5.0、5.99、6.0等等
屏幕分辨率
屏幕分辨率是指手機(jī)在橫向、縱向上的像素點數(shù)總和,單位是px,1px=1個像素點,一般以縱向像素*橫向像素。
比如分辨率2160x1080的手機(jī),表示高度上有2160個像素點,而寬度上有1080個像素點,屏幕分辨率為:2160*1080。
Android手機(jī)比較常見的分辨率為:320x480、480x800、720x1280、1080x1920。
屏幕像素密度
屏幕像素密度是指每英寸上的像素點數(shù),單位是dpi,即“dot per inch”的縮寫。
比如設(shè)備內(nèi)每英寸有320個像素,那么該設(shè)備的屏幕像素密度=320dpi。
屏幕尺寸、分辨率、像素密度三者關(guān)系
屏幕像素密度與屏幕尺寸和屏幕分辨率有關(guān),在單一變化條件下,屏幕尺寸越小、分辨率越高,像素密度越大,反之越小。
手機(jī)的屏幕分辨率是寬x高,屏幕大小是以寸為單位,那么三者的關(guān)系是:

這里舉個例子:假如手機(jī)的屏幕分辨率是2160x1080,屏幕大小是5.99英寸,對于一部手機(jī)來說這些都是已知的,求這手機(jī)的像素密度是多少?

即該手機(jī)每英寸有403個像素。
px
px即像素,是屏幕上顯示數(shù)據(jù)的最基本的點,上面介紹屏幕分辨率的單位就是px,包括UI設(shè)計圖、Android原生API都會以px作為統(tǒng)一的計量單位。
dpi
dpi即屏幕像素密度,每英寸上的像素點數(shù),計算方式上面已經(jīng)介紹過了,這里就不重復(fù)啦。
dp、dip
dp應(yīng)該比較熟悉,我們設(shè)置固定數(shù)值的時候都是以dp為單位,而dp和dip是一個意思,都是Density Independent Pixels的縮寫,即密度無關(guān)像素,與終端上的實際物理像素點無關(guān),可以保證在不同屏幕像素密度的設(shè)備上顯示相同的效果。
舉個例子:比如我們想設(shè)置一張圖片的寬度為屏幕的一半,那么
如果以像素px為單位,那么我們需要在320x480分辨率的手機(jī)上設(shè)置寬度為160px,而在480x800分辨率的手機(jī)上設(shè)置寬度為240px,兩者的設(shè)置寬度就不一樣了。
而如果以dp為單位,在這兩種分辨率下,設(shè)置寬度為160dp都顯示為屏幕的一半。
sp
sp即scale-independent pixels,與dp類似,通常用于指定字體的大小,當(dāng)用戶修改手機(jī)顯示的字體時,字體大小會隨之改變。
dp與px的轉(zhuǎn)換
通常UI設(shè)計師給的設(shè)計圖是以px為單位的,Android開發(fā)則是使用dp作為單位的,那么我們需要進(jìn)行轉(zhuǎn)換,換算關(guān)系為:
px = dp * (dpi / 160)| 密度類型 | 代表的分辨率(px) | 屏幕密度(dpi) | 換算(px/dp) | 比例 |
|---|---|---|---|---|
| 低密度(ldpi) | 240x320 | 120 | 1dp=0.75px | 3 |
| 中密度(mdpi) | 320x480 | 160 | 1dp=1px | 4 |
| 高密度(hdpi) | 480x800 | 240 | 1dp=1.5px | 6 |
| 超高密度(xhdpi) | 720x1280 | 320 | 1dp=2px | 8 |
| 超超高密度(xxhdpi) | 1080x1920 | 480 | 1dp=3px | 12 |
在Android中,規(guī)定以160dpi(即屏幕分辨率為320x480)為基準(zhǔn):1dp=1px
以上的概念梳理一遍過后,下面就要開始講解適配方案啦,由于篇幅過長,就分開幾篇更新,敬請期待。
