zoukankan      html  css  js  c++  java
  • Android手机分辨率基础知识(DPI,DIP计算)

     

    1.术语和概念

    术语

    说明

    备注

    Screen size(屏幕尺寸)

    指的是手机实际的物理尺寸,比方经常使用的2.8英寸,3.2英寸,3.5英寸,3.7英寸

    摩托罗拉milestone手机是3.7英寸

    Aspect Ratio(宽高比率)

    指的是实际的物理尺寸宽高比率,分为longnolong

    Milestone169,属于long

    Resolution(分辨率)

    和电脑的分辨率概念一样,指手机屏幕纵、横方向像素个数

    Milestone854*480

    DPI(dot per inch)

    每英寸像素数,如120dpi,160dpi,如果QVGA(320*240)分辨率的屏幕物理尺寸是(2英寸*1.5英寸),dpi=160

    能够反映屏幕的清晰度,用于缩放UI

    Density(密度)

    屏幕里像素值浓度,resolution/Screen size能够反映出手机密度,

     

    Density-independent pixel (dip)

    指的是逻辑密度计算单位,dip和详细像素值的相应公式是dip/pixel=dpi/160,也就是px = dp * (dpi / 160)

     

     

    2. DPI值计算

    比方:计算WVGA800*480)分辨率,3.7英寸的密度DPI,如图1所看到的

     

                   1 

    Diagonal pixel表示对角线的像素值(=),DPI=933/3.7=252

     

     

     

    3.手机屏幕的分类

     

    3.1依据手机屏幕密度(DPI)或屏幕尺寸大小分为下面3类,如图2所看到的

     

     

                             

                              图2

     

    3. 2手机屏幕分类和像素密度的相应关系如表1所看到的:

     

    Low density (120), ldpi

    Medium density (160), mdpi

    High density (240), hdpi

    Small screen

    QVGA (240x320)

     

     

    Normal screen

    WQVGA400 (240x400)WQVGA432 (240x432)

    HVGA (320x480)

    WVGA800 (480x800)WVGA854 (480x854)

    Large screen

     

    WVGA800* (480x800)WVGA854* (480x854)

     

                                          1

    3.3手机尺寸分布情况(http://developer.android.com/resources/dashboard/screens.html)如图3所看到的,眼下主要是以分辨率为800*480854*480的手机用户居多


                                                            3

       从以上的屏幕尺寸分布情况上看,事实上手机仅仅要考虑3-4.5寸之间密度为1和1.5的手机

    4 UI设计

    从开发角度讲,应用程序会依据3Android手机屏幕提供3UI布局文件,可是对应界面图标也须要提供3套,如表2所看到的

    Icon Type

    Standard Asset Sizes (in Pixels), for Generalized Screen Densities

     

    Low density screen (ldpi)

    Medium density screen (mdpi)

    High density screen (hdpi)

    Launcher

    36 x 36 px

    48 x 48 px

    72 x 72 px

    Menu

    36 x 36 px

    48 x 48 px

    72 x 72 px

    Status Bar

    24 x 24 px

    32 x 32 px

    48 x 48 px

    Tab

    24 x 24 px

    32 x 32 px

    48 x 48 px

    Dialog

    24 x 24 px

    32 x 32 px

    48 x 48 px

    List View

    24 x 24 px

    32 x 32 px

    48 x 48 px

                                            2

    5 怎样做到自适应屏幕大小呢?

    1)界面布局方面 

       须要依据物理尺寸的大小准备5套布局,layout(放一些通用布局xml文件,比方界面中顶部和底部的布局,不会随着屏幕大小变化,类似windos窗体的title bar),layout-small(屏幕尺寸小于3英寸左右的布局),layout-normal(屏幕尺寸小于4.5英寸左右),layout-large(4英寸-7英寸之间),layout-xlarge(7-10英寸之间)

    2)图片资源方面 

      须要依据dpi值准备5套图片资源,drawable,drawalbe-ldpi,drawable-mdpi,drawable-hdpi,drawable-xhdpi

    Android有个自己主动匹配机制去选择相应的布局和图片资源


  • 相关阅读:
    # bootstrap Grid System 柵格系统中“移动优先”的一个小体现[bootstrap ]
    ENGLISH HANDWRITING
    #PHP 类的多继承实现之 traits.md
    #linux vscode 保存总提示“Retry as sudo”
    #【php留存问题-2020年6月19日】,手动为数组添加一个间隔元素,再遍历的时候,提示索引为空
    #Linux 下 Xampp的安装与Hello World
    # 详细了解HTML5中的form表单
    # Promise的简单理解和基本使用
    #简单理解回调函数
    Java中几种常见的设计模式--工厂设计模式
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4545781.html
Copyright © 2011-2022 走看看