Android的計量單位px,in,mm,pt,dp,dip,sp

px   :是屏幕的像素點
in    :英寸
mm :毫米
pt    :磅,1/72 英寸
dp   :一個基於density的抽象單位,如果一個160dpi的屏幕,1dp=1px
dip  :等同於dp
sp   :同dp相似,但還會根據用戶的字體大小偏好來縮放。
建議使用sp作爲文本的單位,其它用dip


dip和px 的關係:
QVGA:    density=0.75;      densityDpi=120;     QVGA(240*320)

HVGA:    density=1.0;        densityDpi=160;     HVGA(320*480)

VGA:       density=1.0;        densityDpi=160;     VGA(480*640)   

WVGA:   density=1.5;        densityDpi=240;     WVGA(480*800)

WQVGA:density=2.0;        densityDpi=120;     WQVGA(240*400)

densityDip值表示每英寸有多少個顯示點,與分辨率是兩個概念


不同densityDpi下屏幕分辨率信息,以480dip*800dip的 WVGA(density=240)爲例

densityDpi=120時 

屏幕實際分辨率爲240px*400px (兩個點對應一個分辨率)

狀態欄和標題欄高各19px或者25dip 

橫屏是屏幕寬度400px 或者800dip,工作區域高度211px或者480dip

豎屏時屏幕寬度240px或者480dip,工作區域高度381px或者775dip

densityDpi=160時 

屏幕實際分辨率爲320px*533px (3個點對應兩個分辨率)

狀態欄和標題欄高個25px或者25dip 

橫屏是屏幕寬度533px 或者800dip,工作區域高度295px或者480dip

豎屏時屏幕寬度320px或者480dip,工作區域高度508px或者775dip

densityDpi=240時 

屏幕實際分辨率爲480px*800px (一個點對於一個分辨率)
狀態欄和標題欄高個38px或者25dip 
橫屏是屏幕寬度800px 或者800dip,工作區域高度442px或者480dip
豎屏時屏幕寬度480px或者480dip,工作區域高度762px或者775dip

apk的資源包中

當屏幕densityDpi=240時,使用hdpi 標籤的資源

當屏幕densityDpi=160時,使用mdpi標籤的資源

當屏幕densityDpi=120時,使用ldpi標籤的資源

不加任何標籤的資源是各種分辨率情況下共用的

佈局時儘量使用單位dip,少使用px


dp與px換算公式:

pixs =dips * (densityDpi/160)

dips=(pixs*160)/densityDpi

dp與px轉換的方法:

public static int dip2px(Context context, float dipValue){
  final float scale = context.getResources().getDisplayMetrics().density;
  return (int)(dipValue * scale +0.5f);
}

public static int px2dip(Context context, float pxValue){
  final float scale = context.getResource().getDisplayMetrics().density;
  return (int)(pxValue / scale +0.5f);
}


VGA        :   640*480

QVGA     :   320*240

HVGA     :   320*480

WVGA    :   800*480

WQVGA :   480X272或400X240


分辨率(水平數×垂直數) 類型 比例 
88×72 QQCIF 11:9 
128×96 SUB-QCIF 4:3 
128×128 知道的補上 1:1 
160×120 QQVGA 4:3 
176×144 QCIF 11:9 
208×176 Sub-QVGA- 13:11 
220×176 Sub-QVGA 5:4 
240×176 Sub-QVGA+ 15:11 
320×200 CGA 16:10 
<span style="color: rgb(51, 51, 255);">320×240 QVGA 4:3 </span>
352×288 CIF 11:9 
640×360 nHD 4:3 
400×240 WQVGA 5:3 
400×320 WQVGA 5:4 
480×240 WQVGA 2:1 
480×272 WQVGA 16:9 
480×320 HQVGA 3:2 
<span style="color: rgb(51, 51, 255);">640×480 VGA 4:3 </span>
640×350 EGA 64:35 
720×480 VGA+ 3:2 
768×576 PAL   
<span style="color: rgb(51, 51, 255);">800×480 WVGA 5:3 </span>
854×480 FWVGA 16:9 
800×600 SVGA 4:3 
<span style="color: rgb(51, 51, 255);">960×540 QHD 16:9 </span>
960×640 DVGA 3:2 
1024×600 WSVGA 128:75 
<span style="color: rgb(51, 51, 255);">1024×768 XGA 4:3 </span>
1280×768 WXGA 15:9 
1280×800 WXGA 16:10 
1280×960 UxGA/XVGA 4:3 
1280×1024 SXGA 25:16 
1400×1050 SXGA+ 4:3 
1440×900 WXGA+ 16:10 
1600×1024 WSXGA 25:16 
1600×1050 WSXGA 32:21 
1600×1200 USVGA/UXGA/UGA 4:3 
1680×1050 WSXGA+ 16:10 
1900×1200 UXGA 19:12 
1920×1080 WSUVGA+(WSUGA/HDTV) 4:3 
1920×1200 WUXGA 16:10 
2048×1536 SUVGA(QXGA) 4:3 
2560×1600 UWXGA 16:10 
2560×2048 USXGA 5:4 
3200×2400 QUXGA 4:3 
3840×2400 WQUXGA 16:10 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章