在调试产品的时候经常会遇到因为LCD屏分辨率不一样而导致UI显示过大或过小的情况,修改了属性系统中的变量ro.sf.lcd_density(device_base.mk),根据对应的屏幕增大或减小对应的值,问题一般都能解决。
在frameworks/base/core/java/android/util/DisplayMetrics.java文件中会去获取这个属性的值
public static final int DENSITY_DEVICE = getDeviceDensity();
private static int getDeviceDensity() { // qemu.sf.lcd_density can be used to override ro.sf.lcd_density // when running in the emulator, allowing for dynamic configurations. // The reason for this is that ro.sf.lcd_density is write-once and is // set by the init process when it parses build.prop before anything else. return SystemProperties.getInt("qemu.sf.lcd_density", SystemProperties.getInt("ro.sf.lcd_density", DENSITY_DEFAULT)); }
density表示显示密度,表示每英寸有多少个显示点,但是这个显示点与分辨率中的像素点是不一样的。
QVGA屏的density=120(两个点对应一个分辨率),使用res/xxx-ldpi目录下的资源
HGVA屏的density=160(三个点对应两个分辨率),使用res/xxx-mdpi目录下的资源(默认采用此目录)
WVGA(800x480)屏的density=240(一个点对应一个分辨率),使用res/xxx-hdpi目录下的资源
在应用程序界面设计时会用到这些概念
dip: device independent pixels(设备独立像素). 不同设备不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。
px: pixels(像素) 屏幕上的点,不同设备不同的显示屏显示效果相同,这是绝对像素,是多少就永远是多少不会改变。
根据不同的手机屏幕,UI实际占据的像素计算公式 pixs = dips * (density/160)。这样能解决UI适应手机屏幕大小的问题
所以根据google的推荐,像素统一使用dip,字体统一使用sp
sp:scaled pixels — best for text size (放大像素)(与刻度无关的像素):主要处理字体的大小。与dip类似,但是可以根据用户的字体大小首选项进行缩放。