Android的單位以及屏幕分辨率詳解
一、常用的單位:相對單位主要有:px、sp、dp
絕對單位主要有:pt、in、mm
二、單位應(yīng)用總結(jié):一般用相對單位,而不是絕對單位
1、字體的大小一般使用SP,用此單位的字體能夠根據(jù)用戶設(shè)置字體的大小而自動縮放
2、空間等相對距離一般使用dp(dip),隨著密度變化,對應(yīng)的像素數(shù)量也變化,但并沒有直接的相對比例的變化。
3、px與實際像素有關(guān),及與密度有關(guān)!dp和sp和實際像素沒有關(guān)系,對于一定分辨率但不同密度的屏幕,px單位的應(yīng)用可能會導致長度的相對比例的變化。
三、密度與分辨率:
密度值表示每英寸有多少個顯示點,與分辨率是兩個概念。
其屏幕密度標準是:HVGA屏density=160;QVGA屏density=120;WVGA屏density=240;WQVGA屏density=120
具體的應(yīng)用運算關(guān)系:假設(shè)分辨率是 x*y, 密度為 d, 屏幕實際大小為 a*b那么關(guān)系為 x*y = d * a * b (約等于)
不同density下屏幕分辨率信息,以480dip*800dip的 WVGA(density=240)為例density=120時 屏幕實際分辨率為240px*400px (兩個點對應(yīng)一個分辨率)
四、對比總結(jié):
1、在相同密度(即同一實體屏幕)不同分辨率的情況下,與實體密度無關(guān)的相對單位sp和dp顯示正常
2、在相同分辨率不同密度的情況下,因為一般情況下,都用的標準密度,所以分析的意義不是很大
其他資料:
px:是屏幕的像素點
in:英寸
mm:毫米
pt:磅,1/72 英寸
dp:一個基于density的抽象單位,如果一個160dpi的屏幕,1dp=1px
dip:等同于dp
sp:同dp相似,但還會根據(jù)用戶的字體大小偏好來縮放。
建議使用sp作為文本的單位,其它用dip
針對dip和px 的關(guān)系,做以下概述:
HVGA屏density=160;QVGA屏density=120;WVGA屏density=240;WQVGA屏density=120
density值表示每英寸有多少個顯示點,與分辨率是兩個概念。
不同density下屏幕分辨率信息,以480dip*800dip的 WVGA(density=240)為例
density=120時 屏幕實際分辨率為240px*400px (兩個點對應(yīng)一個分辨率)
狀態(tài)欄和標題欄高各19px或者25dip
橫屏是屏幕寬度400px 或者800dip,工作區(qū)域高度211px或者480dip
豎屏時屏幕寬度240px或者480dip,工作區(qū)域高度381px或者775dip
density=160時 屏幕實際分辨率為320px*533px (3個點對應(yīng)兩個分辨率)
狀態(tài)欄和標題欄高個25px或者25dip
橫屏是屏幕寬度533px 或者800dip,工作區(qū)域高度295px或者480dip
豎屏時屏幕寬度320px或者480dip,工作區(qū)域高度508px或者775dip
density=240時 屏幕實際分辨率為480px*800px (一個點對于一個分辨率)
狀態(tài)欄和標題欄高個38px或者25dip
橫屏是屏幕寬度800px 或者800dip,工作區(qū)域高度442px或者480dip
豎屏時屏幕寬度480px或者480dip,工作區(qū)域高度762px或者775dip
apk的資源包中,當屏幕density=240時使用hdpi 標簽的資源
當屏幕density=160時,使用mdpi標簽的資源
當屏幕density=120時,使用ldpi標簽的資源。
不加任何標簽的資源是各種分辨率情況下共用的。
布局時盡量使用單位dip,少使用px
下面是幾種不同單位的相互轉(zhuǎn)換.
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);
}
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);
}
下面說下如何獲取分辨率:
在一個Activity的onCreate方法中,寫入如下代碼:
DisplayMetrics metric = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metric);
int width = metric.widthPixels; // 屏幕寬度(像素)
int height = metric.heightPixels; // 屏幕高度(像素)
float density = metric.density; // 屏幕密度(0.75 / 1.0 / 1.5)
int densityDpi = metric.densityDpi; // 屏幕密度DPI(120 / 160 / 240)
這還是挺簡單的, 可是你有沒有在800*480的機器上試過, 是不是得到的寬度是533 ? 因為android剛開始時默認的density是1.0 , 此時你可以再manifest.xml中加入
1.uses-sdk節(jié)點, <uses-sdk android:minSdkVersion="4" /> , 表示不sdk1.6以下的機器不能安裝你的apk了.
2.supports-screens 節(jié)點.
<supports-screens
android:smallScreens="true"
android:normalScreens="true"
android:largeScreens="true"
android:resizeable="true"
android:anyDensity="true" />
相關(guān)文章
Listview加載的性能優(yōu)化是如何實現(xiàn)的
在android開發(fā)中Listview是一個很重要的組件,它以列表的形式根據(jù)數(shù)據(jù)的長自適應(yīng)展示具體內(nèi)容,用戶可以自由的定義listview每一列的布局,接下來通過本文給大家介紹Listview加載的性能優(yōu)化是如何實現(xiàn)的,對listview性能優(yōu)化相關(guān)知識感興趣的朋友一起學習吧2016-01-01
Android設(shè)置TextView首行縮進示例代碼
使用過word的都會知道,在文字排版的時候經(jīng)常要設(shè)置首行縮進,這樣才會使排版更整齊,那么在Android中當需要設(shè)置首行縮進的時候該腫么辦呢,下面一起來看看。2016-08-08
解析Android 8.1平臺SystemUI 導航欄加載流程
這篇文章主要介紹了Android 8.1平臺SystemUI 導航欄加載流程,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11

