zoukankan      html  css  js  c++  java
  • 关于android分辨率兼容问题

    关于手机分辨率相关术语和概念

           屏幕尺寸:实际的物理尺寸,屏幕的对角线测量。为了方便,android把所有的屏幕尺寸分为了4个广义的大小:小,正常,大,特大。

                屏幕密度:屏幕的物理面积内像素的数量,通常称为DPI(每英寸点数)。为了方便,android把所有的实际屏幕密度分为:低,中,高,特高。

               方向:从用户的角度来看,就是屏幕的方向,就是横向或者纵向的意义。

       分辨率:屏幕上面的物理像素总数。(官方说法,应用程序应该只关注屏幕大小和密度)

              密度无关像素: 一个虚拟像素单元(官方说法,你应该使用密度无关像素定义UI的布局,来表达布局尺寸或位置,系统默认假设“中等”的密度屏幕为基准,其屏幕密度相当于一个160dpi的屏幕。在运行时,系统根据实际中的屏幕密度对DP单位进行缩放。DP单位转换为屏幕像素可用PX = DP *(DPI / 160)这个方法。那么在一个160dpi屏幕上,1DP==1PX。在一个240 dpi屏幕上,1 DP==1.5PX。那么在定义布局时,应该使用DP单位,以确保不同密度的屏幕上合理的显示用户界面)

    关于支持屏幕的范围

             官方定义4种广义尺寸:小,正常, 大,更大。四种密度:低,中型, 高,特高。广义尺寸和密度都可以跨越一系列的尺寸和密度(官方截图上传不了权限不够一周委屈

    关于密度的独立性

              官方说法保证密度的独立性是非常重要的,如果没有它,你应用程序中的系统控件可能会在物理尺寸相同,密度不同的屏幕上面显示异常。

        Android系统帮助密度独立有两种方式:

       1.使用DP单位。

       2.位图资源缩放,可以导致像素模糊的位图,可以根据当前屏幕密度,提供不同分辨率的位图。官方提示,如果提供一套图至少提供更高分辨率高密度的位图而不是提供哪些中等密度设计的位图。

    关于如何支持多个屏幕

          官方说法确保系统在适配多个屏幕做了很多工作,但是为了更妥善处理不同的屏幕配置,我们也需要做些工作:

        1.在程序中显示声明你的应用程序支持屏幕尺寸的清单。

    1. <span style="font-family:KaiTi_GB2312;font-size:16px;">     <supports-screens   
    2.      android:resizeable=[“true”|”false”]  
    3.      android:smallScreens=[“true”|”false”]  
    4.      android:normalScreens=[“true”|”false”]  
    5.      android:largeScreens=[“true”|”false”]  
    6.      android:xlargeScreens=[“true”|”false”]  
    7.      android:anyDensity=[“true”|”false”]/></span>  

                 2.根据不同屏幕尺寸,提供不同布局

        默认情况下面,android会自动调整应用程序的布局,但是大多数情况下面,根据广义尺寸,小,正常,大,更大去增加不同的布局资源。比如,如果需要对大小为large的屏幕提供支持,需要在res目录下新建一个文件夹layout-large/并提供layout。当然,也可以在res目录下建立layout-port和layout-land两个目录,里面分别放置竖屏和横屏两种布局文件,以适应对横屏竖屏自动切换。

                3.提供不同的屏幕密度和不同的位图drawables

        默认情况下面系统会自动调整和缩放位图,但是难免拉伸位图,为了保证你的位图是最好看的,根据广义密度,低,中型, 高,特高去添加不同的位图资源。比如,如需对密度为low的屏幕提供合适的图片,需新建文件夹drawable-ldpi/。应尽量使用点9格式的图片,图片大小的确定:low:medium:high:extra high比例为3:4:6:8。举例来说,对于中等密度(medium)的屏幕你的图片像素大小为48×48,那么低密度(low)屏幕的图片大小应为36×36,高(high)的为72×72,extra high为96×96。

    关于系统怎么动态的寻找替代资源?

             1.系统根据当前的屏幕大小和密度,然后动态的采用程序中提供特定的资源。

       2.如果没有匹配的资源,系统会使用默认的资源进行缩放从而符合当前屏幕的资源,“默认”的资源是那些没有标签配置限定符。

    (这块只是简单的说法,详细关于介绍寻找替代资源下章在说吧)

    关于系统的资源配置的目录(我只列出一些大概,默认项目会有一些资源配置目录)

    Android系统支持多配置资源文件,我们可以追加新的资源目录到你的Android项目中。命名规范: 资源名字-限制符

    layout

    默认中等屏幕

    layout-small

    小屏幕

    layout-large

    大屏幕

    layout-xlarge

    特大屏幕

    layout-land

    横屏

    layout-port

    竖屏

    drawable

    默认中等密度

    drawable-hdpi

    高密度 ~240dpi

    drawable-mdpi

    中等密度 160dpi

    drawable-xhdpi

    更高密度 ~320dpi

    drawable-nodpi

    所有密度资源,无论什么密度屏幕都会适配。

    drawable-tvdpi

    介于mdpi~hdpi 约213dpi 主要应用在电视。

    注:如果没有指定横屏或竖屏,则上面的布局和位图都适配横竖屏。如果要指定横屏,例如:drawable-land-hdpi竖屏drawable-port-hdpi,还有关键是drawable-xlarge和layout-xlarge,对api level都要求在9之上,等于说,你用android2.2系统的平板或者手机根本不匹配layout-xlarge。因为api level是8。drawable-tvadpi这个api等级需要13以上。

    其实上面的layout-large这个目录其实是个范围。当系统根据当前屏幕的大小和密度,决定程序应该匹配那个目录。你也可以单独定制某些不符合谷歌标准的山寨版layout-l024x600(中间的符合是英文下的x字母),其中1024和600的单位是dp。你可以根据你设备的分辨率和密度,来判断你的设备需要定义那个文件。

    但是,官方推荐使用尺寸来表示资源layout-large,不推荐使用分辨率layout-1024*600。

    建议大家多看文档,官方说明:

    xlarge screens are at least 960dp x 720dp

    large screens are at least 640dp x 480dp

    normal screens are at least 470dp x 320dp

    small screens are at least 426dp x 320dp

    上面是定义广义大小布局资源适配的一个范围,大家可以根据自己的设备知道系统会匹配那个文件的布局。

    如果手上有个山寨华为的卖的比较火的mediapad,大家知道分辨率1280*800 密度尺寸7寸

    通过勾股定了和分辨率可以得出其密度为215.69。然后根据dp=px/(dpi/160),可以得出个范围593.471。所以这个设备系统会匹配layout-large这个资源布局文件。

    上面定义命名在android3.2后不推荐。下章再介绍关于android3.2以上的系统命名规范。

  • 相关阅读:
    mysql数据库常用指令
    解决windows的mysql无法启动 服务没有报告任何错误的经验。
    “Can't open file for writing”或“operation not permitted”的解决办法
    启动Apache出现错误Port 80 in use by "Unable to open process" with PID 4!
    如何打开windows的服务services.msc
    常见的HTTP状态码 404 500 301 200
    linux系统常用的重启、关机指令
    (wifi)wifi移植之命令行调试driver和supplicant
    linux(debian)安装USB无线网卡(tp-link TL-WN725N rtl8188eu )
    alloc_chrdev_region申请一个动态主设备号,并申请一系列次设备号
  • 原文地址:https://www.cnblogs.com/wangxingliu/p/3489896.html
Copyright © 2011-2022 走看看