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

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

要回复文章请先登录注册

p***@163.com

p***@163.com

在mainfest文件中设置了并没有任何效果,目前APP切换到登录页时,没有tabbar,还是会出现底部一段空白颜色的情况
2019-09-16 11:33
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 1***@qq.com :
iOS13的问题处理中
2019-09-10 16:54
1***@qq.com

1***@qq.com

ios 13.1的iPhone X无法真机调试。
打开文件服务失败,请尝试拔掉数据线后重新连接手机,或重启手机再试
安装最新alpha版本的也不行
只有我一个人这样吗~~
2019-09-10 16:53
8***@qq.com

8***@qq.com

回复 DCloud_UNI_GSQ :
测试了,现在版本直接就可以用,万分感谢哦
2019-08-21 16:46
8***@qq.com

8***@qq.com

回复 DCloud_UNI_GSQ :
我能不能,直接的获取到这个区域大小以后,直接对我的view,设置padding,还是说我必须要在mainfest里边,设置safearea信息,才能用这个
2019-08-21 16:30
8***@qq.com

8***@qq.com

回复 DCloud_UNI_GSQ :
现在版本的hbuilderx已经可以用了吗?
2019-08-21 16:29
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 8***@qq.com :
http://www.html5plus.org/doc/zh_cn/navigator.html#plus.navigator.getSafeAreaInsets
2019-08-21 16:25
8***@qq.com

8***@qq.com

回复 DCloud_UNI_GSQ :
大概要什么时候可以OK哇?目前有什么办法,只要可以拿到安全区的高度即可?nvue下的
2019-08-20 16:21
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 8***@qq.com :
后期将补充API,在js获取安全区信息
2019-08-20 11:50
8***@qq.com

8***@qq.com

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