这个一般开发人员很难搞明白

最近正在做Android的UI设计,故搜集了一些Android上进行UI设计的一些资料,现和各位分享下。

首先说说density,density值表示每英寸有多少个显示点,与分辨率是两个不同的概念。

Android主要有以下几种屏:

QVGA和WQVGA屏density=120;

HVGA屏density=160;

WVGA屏density=240;

下面以480dip*800dip的WVGA(density=240)为例,详细列出不同density下屏幕分辨率信息:

当density=120时 屏幕实际分辨率为240px*400px (两个点对应一个分辨率)
状态栏和标题栏高各19px或者25dip
横屏是屏幕宽度400px 或者800dip,工作区域高度211px或者480dip
竖屏时屏幕宽度240px或者480dip,工作区域高度381px或者775dip

density=160时 屏幕实际分辨率为320px*533px (3个点对应两个分辨率)
状态栏和标题栏高个25px或者25dip
横屏是屏幕宽度533px 或者800dip,工作区域高度295px或者480dip
竖屏时屏幕宽度320px或者480dip,工作区域高度508px或者775dip

density=240时 屏幕实际分辨率为480px*800px (一个点对于一个分辨率)
状态栏和标题栏高个38px或者25dip
横屏是屏幕宽度800px 或者800dip,工作区域高度442px或者480dip
竖屏时屏幕宽度480px或者480dip,工作区域高度762px或者775dip

apk的资源包中,当屏幕density=240时使用hdpi标签的资源
当屏幕density=160时,使用mdpi标签的资源
当屏幕density=120时,使用ldpi标签的资源。
不加任何标签的资源是各种分辨率情况下共用的。
建议:布局时尽量使用单位dip,少使用px。

device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA、HVGA和QVGA 推荐使用这个,不依赖像素。


[html] view plain copy
  1. importandroid.content.Context;
  2. importandroid.util.DisplayMetrics;
  3. /**
  4. *计算公式pixels=dips*(density/160)
  5. *
  6. *@version1.0.12010-12-11
  7. *
  8. *@author
  9. */
  10. publicclassDensityUtil{
  11. privatestaticfinalStringTAG=DensityUtil.class.getSimpleName();
  12. //当前屏幕的densityDpi
  13. privatestaticfloatdmDensityDpi=0.0f;
  14. privatestaticDisplayMetricsdm;
  15. privatestaticfloatscale=0.0f;
  16. /**
  17. *
  18. *根据构造函数获得当前手机的屏幕系数
  19. *
  20. **/
  21. publicDensityUtil(Contextcontext){
  22. //获取当前屏幕
  23. dm=newDisplayMetrics();
  24. dm=context.getApplicationContext().getResources().getDisplayMetrics();
  25. //设置DensityDpi
  26. setDmDensityDpi(dm.densityDpi);
  27. //密度因子
  28. scale=getDmDensityDpi()/160;
  29. Logger.i(TAG,toString());
  30. }
  31. /**
  32. *当前屏幕的density因子
  33. *
  34. *@paramDmDensity
  35. *@retrunDmDensityGetter
  36. **/
  37. publicstaticfloatgetDmDensityDpi(){
  38. returndmDensityDpi;
  39. }
  40. /**
  41. *当前屏幕的density因子
  42. *
  43. *@paramDmDensity
  44. *@retrunDmDensitySetter
  45. **/
  46. publicstaticvoidsetDmDensityDpi(floatdmDensityDpi){
  47. DensityUtil.dmDensityDpi=dmDensityDpi;
  48. }
  49. /**
  50. *密度转换像素
  51. **/
  52. publicstaticintdip2px(floatdipValue){
  53. return(int)(dipValue*scale+0.5f);
  54. }
  55. /**
  56. *像素转换密度
  57. **/
  58. publicintpx2dip(floatpxValue){
  59. return(int)(pxValue/scale+0.5f);
  60. }
  61. @Override
  62. publicStringtoString(){
  63. return"dmDensityDpi:"+dmDensityDpi;
  64. }
  65. }

更多相关文章

  1. Android屏幕密度(Density)和分辨率的关系
  2. Android(安卓)简单快捷高效的屏幕适配
  3. Android屏幕密度(Density)和分辨率的关系
  4. Android_TextView属性XML详解
  5. Android屏幕适配总结终极方案
  6. android游戏开发(三)触屏事件处理_手势识别
  7. Android多分辨率和多屏幕的布局适配详解
  8. Shape画圆环的注意点
  9. android根据屏幕尺寸区分设备类型,phone或者pad

随机推荐

  1. CSS伪类选择器和CSS盒模型常用属性
  2. 伪类选择器的应用/盒模型的分析
  3. 【Linux学习】OpenCV+ROS 实现人脸识别(Ub
  4. 常用的两种伪类选择器
  5. 伪类和伪元素和盒模型
  6. Ubuntu软件更新更换源
  7. CSS常用伪类选择器的总结与盒子模型的简
  8. 0707伪类选择器/盒模型
  9. html基础:css伪类选择器的使用和盒模型的
  10. 选择器和盒模型