• Android


    Android - 适配不同分辨率的设备

    Android整体上按照两大类来分类设备屏幕:尺寸和分辨率。app在设备上运行应该考虑大小和分辨率。同样的,你应该包含不同的资源来让app适应不同的屏幕大小和分辨率。

    • 整体上有四种尺寸:小的,正常的,大的,超级大的

    • 和四种分辨率:低分辨率(ldpi),中分辨率(mdpi),高分辨率(hdpi),超高分辨率(xhdpi)

    为了声明不同屏幕的不同的布局和突变,你需要把不同的资源放在不同的文件夹下,和处理不同语言的方法一样。

    同样要注意到在考虑屏幕大小时也要考虑屏幕的方向(横竖屏),所以很多app需要在每个方向上调整布局来来优化用户体验。

    创建不同的布局

          为了在不同的屏幕尺寸上优化用户体验,你应该为每个你要支持的屏幕大小创建一个单独的xml文件。每个布局都应该被保存到对应的资源文件夹,命名以<screen_size>后缀结尾。例如,为大屏幕创建的布局文件应该存在res/layout-large

          注意:Android会自动拉伸布局来适应屏幕。对于不同屏幕的尺寸的布局,不需要考虑UI控件的绝对大小,可以把更多注意力放在影响用户体验的布局结构上(比如重要的view相对于它的子view的大小和位置)。

    例如,这个工程包含默认布局和大屏幕的布局

    MyProject/

            res/

                  layout/

                         main.xml

                  layout-large/

                         main.xml

          注:文件名必须完全一样,为了适应不同屏幕大小的不同UI,他们的内容是不同的。

    在app中和平常一样引用layout文件

    1 @Override
    2  protected void onCreate(Bundle savedInstanceState) {
    3      super.onCreate(savedInstanceState);
    4      setContentView(R.layout.main);
    5 }

    系统根据app运行的屏幕大小来从对应的布局文件夹中加载布局文件。更多Android如何选择合适资源的信息在Providing Resources中介绍。

    另外一个例子,这个工程是是如何选择横屏的布局资源。

    MyProject/

            res/

                  layout/

                         main.xml

                  layout-land/

                         main.xml

    默认情况下,layout/main.xml文件是用在竖屏上的。

    如果需要为横屏提供特殊的布局,也包括大屏幕,那么就需要用large和land标识:

    MyProject/

            res/

                  layout/                            #default(portrait)

                         main.xml

                  layout-land/                     #landscape

                         main.xml

                  layout-large/                     #large(portrait)

                         main.xml

                  layout-large-land/              #large landscape

                         main.xml

          注意:Android3.2及以上版本支持一些高级方法来定义屏幕大小,可以元素最小的高度来宽度来为屏幕大小定义资源。这里不会降到这个新技术。更多信息,查看Designing for Multiple Screens。另外,在帮助文档中指出,在androidmainfest.xml文件中必须进行如下代码的配置。如果没有这几行代码,不管你怎么调整layout中的控件,对应分辨率的手机是没有任何效果的。

    <supports-screens
    android:smallScreens="true"
    android:normalScreens="true"
    android:largeScreens="true"
    android:xlargeScreens="true"
    android:anyDensity="true" />

          注意:由于android版本的不同,有些版本不支持xlargeScreens,可以直接将android:xlargeScreens="true"去掉。

    创建不同的图片

    你应该为每个分辨率提供合适的可被拉伸的图片资源。这样可以在各种分辨率的屏幕上达到很好的绘图质量和效果。

    为了生成这些图片,应该提供矢量图并且为下面的每个分辨率提供图片:

    • xhdpi:2.0

    • hdpi:1.5

    • mdpi:1.0(baseline)

    • ldpi:0.75

    着就意味着如果为xhdpi设备提供一张200*200的图片,应该为其他分辨率提供同样的资源:150*150 for hdpi, 100 * 100 for mdpi, 75 * 75 for ldpi。

    然后,把这些文件当道对应的资源文件夹下:

    MyProject/

            res/

                  drawable-xhdpi/

                         awesomeimage.png

                  drawable-hdpi/

                         awesomeimage.png

                  drawable-mdpi/

                         awesomeimage.png

                  drawable-ldpi/

                         awesomeimage.png

    任何时候引用@drawable/awesomeimage,系统会根据屏幕分辨率选择合适的图片。

    注意:低分辨率(ldpi)的资源并不是总是需要,当提供了hdpi资源后,系统会把他们缩小一半来适应ldpi屏幕

  • 相关阅读:
    程序员们,让你的孩子当个网页工程师吧!
    罗永浩:锤子手机一共卖了12万部(但计划50万)……我已经交出微博密码……(老罗想通了:-))
    母婴市场两万亿,我独钟情于尿布?已获千万级天使的垂直电商“尿布师”,其商业逻辑是这样的
    梵高眼里的《星空》究竟有多美,利用机器学习和图像处理来扩展整幅画的全局景象~
    编程王道,唯“慢”不破
    BAT,你好!字幕组,再见!——也许要跟美剧说再见了~
    Google想出了一个决定人员晋升的算法,然后就没有然后了......
    程序员需要经纪人吗?10x 最好的程序员其生产力相当于同行的 10 倍~
    比特币 Bitcoin 是什么,我勒个去,哈耶克果然超前——货币的非国有化,容我思量一下【转载+整理】
    2014年10月底/终于/HTML5定稿……/技术从来不会成为发展的绝对瓶颈/反而商业成了无法逾越的鸿沟【转载+整理】
  • 原文地址:https://www.cnblogs.com/snow-flower/p/6082401.html
Copyright © 2020-2023  润新知