美文网首页Android Techandroid屏幕适配搜集Android开发
Android手机 全面屏(18:9屏幕)适配指南

Android手机 全面屏(18:9屏幕)适配指南

作者: brucevanfdm | 来源:发表于2017-10-09 22:21 被阅读5705次

    前言

    从小米MIX 1发布以来,越来越多所谓“全面屏”手机发布,如三星S8,小米MIX2,VIVO X20,Google Pixel2等等...2017年下半年开始,“全面屏”将大范围覆盖,低至千元机水平,就像当年手机屏幕从720P到1080P过渡一样,历史车轮,滚滚向前,不可阻挡!

    暂且不论所谓全面屏如何定义,作为Android开发者更多关心的是屏幕适配的兼容性。全面屏刚出来的时候并不可怕,可怕的是后来出现了一些异形全面屏——把屏幕挖掉一块的那种异类!全面屏手机大致思路都是压缩额头与下巴,屏幕比例从传统的16:9变为18:9,提高屏占比以及屏幕内的虚拟导航键,本文将简要介绍全面屏适配中一些需要注意的东西以及解决方案。

    适配指南

    一、声明最大屏幕高宽比
    在应用配置文件AndroidManifest.xml中显式声明支持的最大屏幕高宽比(maximum aspect ratio)。其中 ratio_float 为高宽比:
    传统屏幕:ratio_float = 16/9 = 1.778 ;
    三星S8屏幕:ratio_float = 18.5/9 = 2.056。
    鉴于目前全面屏屏幕比例,将ratio_float设置为2.1即可适配一众全面屏手机。

    <meta-data 
      android:name="android.max_aspect"
      android:value="ratio_float" />
    

    然而有一点需要注意的是,在Android 7.0以上Google默认支持了分屏模式,即Manifest文件中配置Activity的android:resizeableActivity默认属性为true,在这种情况下并不需要配置Maximum Aspect Ratio即可自动适配全面屏。如果由于某些原因(UI适配等)禁止了分屏模式,这个时候就要注意了!负责将出现上下黑条的显示效果,奇丑无比!Screens Support 官方文档

    二、启动页适配
    在做启动优化,解决冷启动白屏的时候,我们往往会为要启动的Activity设置主题为一张背景图。那么问题就来了,以往16:9的的背景图在18:9的屏幕中会有什么表现呢?

    淘宝开屏拉伸变形,此图来自小米开发者中心

    这种情况下就尴尬了,我们知道很多启动页背景都是动态下发的(广告)内容丰富,即使是.9图在这种场景恐怕也难以解决。这点在金立手机上的做法值得一提,看图:


    金立全面屏启动页UI适配

    是好是坏不便多言,但是有兼容性方案总比莫名拉伸好吧!若Android阵营没有一个统一规范,恐怕又要难为开发者、UI设计师了吧!

    不能依赖单一厂商的解决方案,只能从Android系统属性出发。考虑到目前大部分全面屏手机只是在高度上拉长,且大多为6.0英寸左右,像素密度对比xxhdpi并没有多大区别,那我们可以在项目中增加一组资源drawable-xxhdpi-2160x1080 、drawable-long 这样解决图片的拉伸问题,当然最好的方法还是用相对布局采用XML的方式,或者.9图的解决方案。

    三、虚拟导航键(Navigation Bar)优化
    个人觉得虚拟导航键并不是一个好东西,依稀记得HTC被双下巴甚至四下巴支配的恐惧,虚拟导航键总让人出戏。可是全面屏风潮的到来,彻底将正面实体按键拍到了沙滩上。
    虚拟导航键系统,桌面美如画,进入到应用里就是傻大粗的黑条,几乎没有几个APP做虚拟导航键的适配,图就不上了,可以参考华为那些机子。。。

    虚拟键的样式,此图来自小米开发者中心

    总之,要达到一体化的沉浸体验,就应该尽量避免导航键出戏,选择合适的虚拟键样式,保证视觉的统一性。全面屏时代的到来,开发者总该好好管管这虚拟导航键了吧!

    虚拟导航键修改方法一: window.setNavigationBarColor (int color)
    注意在调用该接口时,需要立一些flag,该接口说明如下:

    /**
     * Sets the color of the navigation bar to {@param color}.
     *
     * For this to take effect,
     * the window must be drawing the system bar backgrounds with
     * {@link android.view.WindowManager.LayoutParams#FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS} and
     * {@link android.view.WindowManager.LayoutParams#FLAG_TRANSLUCENT_NAVIGATION} must not be set.
     *
     * If {@param color} is not opaque, consider setting
     * {@link android.view.View#SYSTEM_UI_FLAG_LAYOUT_STABLE} and
     * {@link android.view.View#SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION}.
     * <p>
     * The transitionName for the view background will be "android:navigation:background".
     * </p>
     */
    public abstract void setNavigationBarColor(@ColorInt int color);​
    

    虚拟导航键修改方法二:,在主题中添加以下设置项:

    <item name="android:navigationBarColor">要设置的颜色值</item>
    

    注意,该方法在Android5.0以上生效,什么!?都全面屏了肯定上7.0+了啊!推荐!

    结语

    总的来说,全面屏的到来为沉闷的手机ID设计带来了些惊喜,虽然不少开发者骂娘,但还是应当顺应历史潮流,况且很多情况Android系统早已有适配方案了不是?最后希望本文能为大家做全面屏适配带来些帮助!一起为Android软件生态改善而努力!有更多好用技巧欢迎评论交流!

    参考资料:
    小米全面屏及虚拟键适配说明
    金立18:9全面屏适配说明
    全面屏时代 | APP如何快速适配? 这4个关键点你要知道!

    相关文章

      网友评论

      • Tyhoo_Wu:8.0以后加的是这段话
        <activity android:maxAspectRatio="2.4" />
      • 你的理想型:至于添加一组资源drawable-xxhdpi-2160x1080 我这里全面屏的时候完全没有去使用这组资源
        brucevanfdm:@墨禾_9a50 这个限定符匹配优先级比较低罢了
        93cbf746be9a:我也是一样的,配置了没用到,是在和xxhdpi同一级别的目录。用darwable-long图片操作起来很卡,而且其他分辨率的手机也会用到这个目录里面的图片。
        写字的猴子:请问一下你适配全面屏的图片放在哪个文件夹下?
      • 贾大师:难道从来就没有 手机厂商愿意去联合行业内的其他人
        做出一些努力,去整合 和创建一系列的标准吗
        比如用户的操作习惯
        本机自带的系统软件
        以及手机的尺寸等
      • 工藤一号:感谢分享!

      本文标题:Android手机 全面屏(18:9屏幕)适配指南

      本文链接:https://www.haomeiwen.com/subject/tqopyxtx.html