基本概念
名詞概念
名稱 | 解釋 |
---|---|
px | 像素點(diǎn)堪置,一個(gè)像素點(diǎn)為1px |
dp | 即dip,像素密度 |
sp | 同dp弹灭,但是可以根據(jù)系統(tǒng)字體偏好縮放 |
dpi | 每英寸的像素?cái)?shù)毁靶,也叫做屏幕密度 |
換算關(guān)系
根據(jù)換算關(guān)系:
320 x 480分辨率,3.6寸的手機(jī):dpi為160蛮位,1dp=1px
dp解析
dp是比例嗎较沪?為什么要用dp?
實(shí)驗(yàn)一
相同分辨率失仁,不同大小的手機(jī)AB:
代號(hào) | 分辨率 | 尺寸 | dpi | dp |
---|---|---|---|---|
手機(jī)A | 320x480 | 3.6寸 | 160 | 1dp=1px |
手機(jī)B | 320x480 | 7.2寸 | 80 | 1dp=0.5px |
假如AB都設(shè)置一個(gè)寬度為100dp的TextView:
代號(hào) | TextView寬度 | 手機(jī)寬度 | 比例關(guān)系 |
---|---|---|---|
手機(jī)A | 100px | 320px | 10/32 |
手機(jī)B | 50px | 320px | 5/32 |
得出結(jié)論:
對(duì)于相同分辨率的手機(jī)尸曼,屏幕越大,同DP的組件占用屏幕比例越小萄焦。
如圖所示:
69F8518D-DB48-46FA-9692-1781D4BFCE96.png
C13B2003-1A88-4081-BF86-6369E78543A7.png
實(shí)驗(yàn)二
相同大小控轿,不同分辨率的手機(jī)AB:
代號(hào) | 分辨率 | 尺寸 | dpi | dp |
---|---|---|---|---|
手機(jī)A | 320x480 | 3.6寸 | 160 | 1dp=1px |
手機(jī)B | 640x960 | 3.6寸 | 320 | 1dp=2px |
假如AB都設(shè)置一個(gè)寬度為100dp的TextView:
代號(hào) | TextView寬度 | 手機(jī)寬度 | 比例關(guān)系 |
---|---|---|---|
手機(jī)A | 100px | 320px | 10/32 |
手機(jī)B | 200px | 640px | 10/32 |
得出結(jié)論:
對(duì)于相同尺寸的手機(jī),即使分辨率不同拂封,同DP的組件占用屏幕比例也相同茬射。
如圖:
519BBF6F-35CD-42FE-BBE2-906927DDDCDB.png
6D49FB83-DF00-4052-BDED-FB95D37ED32E.png
綜上:
dp的UI效果只在相同尺寸的屏幕上相同,如果屏幕尺寸差異過(guò)大冒签,則需要重做dp適配在抛。
這也是平板需要單獨(dú)做適配的原因,可見(jiàn)dp不是比例萧恕。
為什么不用比例
為什么Android要用dp刚梭,而不用比例以兼容不同大小的手機(jī)呢肠阱?
如果用dp,假設(shè)在手機(jī)A上設(shè)置一個(gè)寬度為屏幕一半寬dp值朴读,高度為屏幕一半高dp值的TextView屹徘。效果圖如下:
156F9450-7C1E-4A55-AE3B-0A3684563A6F.png
當(dāng)它橫屏?xí)r,顯示效果如下:
FF6FBC0E-570B-473A-BBBC-8ACE7A9DAFBC.png
但是衅金,如果Android沒(méi)有采用dp作為單位缘回,而選用比例作為單位,對(duì)于相同的TextView典挑,橫屏后的顯示效果如下:
8B5338FD-450D-4145-966F-1E2B20E98799.png
整個(gè)TextView組件都變形了酥宴!
所以:
dp可以維護(hù)Android組件自身的比例平衡,不至于在不同屏幕上變形您觉。這是比例做不到的拙寡。
總結(jié)
dp的意義在于:
- 同大小的手機(jī),使用dp做出的UI效果一定相同琳水。
- 不同大小的手機(jī)肆糕,使用dp做出的UI效果一定不同(這里不考慮weight等參數(shù))。但只是組件相對(duì)于屏幕的大小比例有所縮放在孝,組件自身的寬高比是不變的诚啃,即組件自身不會(huì)變形。