DCloud_UNI_GSQ
DCloud_UNI_GSQ
  • 发布:2019-01-29 16:14
  • 更新:2024-10-07 12:27
  • 阅读:132834

uni-app 全面屏、刘海屏适配(iphoneX适配)及安全区设置

分类:uni-app

方案一:使用原生占位(仅App端支持)

manifest.json 文件 app-plus 节点下配下 safearea

"safearea": {  
    "background": "#CCCCCC",  
    "bottom": {  
        "offset": "auto"  
    }  
}

方案二:不使用原生占位(非App端可以不配置manifest)

manifest.json 文件 app-plus 节点下配下 safearea

"safearea": {  
    "bottom": {  
        "offset": "none"  
    }  
}

然后在需要适配的页面内使用 css 常量 constant(safe-area-inset-bottom)、env(safe-area-inset-bottom) 来适配,参考:为iPhoneX设计网站。微信小程序模拟器不支持,以真机为准。

比如为列表底部添加内边距避开安全区,在 iPhoneX 上列表底部会有内边距,在其他设备上没有内边距:

<style>  
.list {  
  padding-bottom: 0;  
  padding-bottom: constant(safe-area-inset-bottom);  
  padding-bottom: env(safe-area-inset-bottom);  
}  
</style>

nvue 页面不支持 css 常量,可以使用 uni.getSystemInfo 获取 safeAreaInsets 动态设置到 style 属性。

注意:使用了pages.json里的原生tabbar,不管manifest里安全区设置如何,在tabbar下方都会留出空隙。

判断是否为刘海屏的方法

使用5+ API (plus.navigator.hasNotchInScreen)可查询当前设备是否为刘海屏。
详情参考:https://www.html5plus.org/doc/zh_cn/navigator.html#plus.navigator.hasNotchInScreen

安卓底部虚拟按键背景色修改方式

使用Native.js修改:

var Color = plus.android.importClass("android.graphics.Color");    
    plus.android.importClass("android.view.Window");    
    var mainActivity = plus.android.runtimeMainActivity();    
    var window_android = mainActivity.getWindow();    
    window_android.setNavigationBarColor(Color.GREEN);  
26 关注 分享
DCloud_IOS_XTY 今天回复我了吗 Trust h***@163.com 3***@qq.com 9***@qq.com wenju 5***@qq.com _1900 aliang888 C1oudust ttrr 1***@qq.com c***@qq.com LunaYJ d***@163.com MooGu 老醒 苏陌 1***@qq.com nininiccc 1***@qq.com 1***@qq.com HRK_01 笔袋App 8***@qq.com

要回复文章请先登录注册

8***@qq.com

8***@qq.com

nvue模式下,怎么设置安全区域?最主要是不同页面的安全区域的颜色都还不一样,这个怎么实现
2019-08-19 20:13
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 9***@qq.com :
有的,点开参考链接
2019-08-14 19:58
9***@qq.com

9***@qq.com

发个图 标注一下 不然就跟说天书一样
2019-08-14 19:41
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 5***@qq.com :
单独发帖说明,附上详细的问题截图,设备型号和系统等信息
2019-08-14 19:21
5***@qq.com

5***@qq.com

回复 5***@qq.com :
直接将bottom:0,但是底部的tabbar还是会被顶起
2019-08-14 15:14
5***@qq.com

5***@qq.com

回复 手写的从前 :
没有 按照第二种方法设置"不使用原生占位(非App端可以不配置mainfest)",没生效
2019-08-14 10:33
手写的从前

手写的从前

回复 5***@qq.com :
请问解决了吗
2019-08-14 09:41
5***@qq.com

5***@qq.com

按照 使用 css 常量 constant(safe-area-inset-bottom)、env(safe-area-inset-bottom) 来适配 没有效果啊
2019-08-07 17:25
5***@qq.com

5***@qq.com

在登录页面又需要全屏,这个咋弄啊?
2019-08-07 16:57
2***@qq.com

2***@qq.com

回复 草泥马二号 :
我的也是,如果是新打开的页面,就是无效,如果是tabBar页面跳转的就可以
2019-07-15 09:26