DCloud_UNI_GSQ
DCloud_UNI_GSQ
  • 发布:2019-01-29 16:14
  • 更新:2023-09-09 01:41
  • 阅读:120059

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

分类:uni-app

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

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

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

iOS方案二:不使用原生占位(非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);  
24 关注 分享
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 DCloud_UNI_HRK

要回复文章请先登录注册

想得美

想得美

回复 救救孩子吧 :
uni.getsystemInfoSync().safeAreaInsets.bottom
我用这个来获取苹果虚拟home键高度解决的
2020-11-20 17:17
救救孩子吧

救救孩子吧

回复 想得美 :
我现在也是nvue 用的自己写的tabbar没用原生 小程序小程序出现同样的问题无法解决 有什么其他解决方法吗?
2020-11-20 15:13
想得美

想得美

nvue不支持constant(safe-area-inset-bottom); env(safe-area-inset-bottom); 怎么办
2020-11-05 14:01
飞翔的腿毛

飞翔的腿毛

回复 5***@qq.com :
兄弟 有解决办法吗?
2020-09-28 11:25
小李子啊

小李子啊

作者你好,我也是为了适配页面底部的一个盒子的,一开始是由效果的,弹出键盘再收回,这个适配就失效了是什么原因呢
2020-09-26 16:47
HyouteiTears

HyouteiTears

安卓手机的怎么办?比如华为P30pro的,我的项目中一部分页面用的uniapp自带的navbar,一部分用的是uni-nav-bar。框架自带的在手机端是没问题的,但是用了uni-nav-bar这个的就会被手机刘海挡住。我看了下自带的那个就是用的
height: calc(44px + constant(safe-area-inset-top)) !important;
height: calc(44px + env(safe-area-inset-top)) !important;
padding: 7px 3px;
padding-top: calc(7px + constant(safe-area-inset-top));
padding-top: calc(7px + env(safe-area-inset-top));
box-sizing: border-box;
这些。但是我用来改造uni-nav-bar的时候,就不生效了。请问有啥解决办法不?在线等
2020-06-02 16:51
C1oudust

C1oudust

小程序里的安全区没法设置颜色吗
2020-06-01 14:26
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 5***@qq.com :
用 getsysteminfo 获取
2020-05-29 10:41
5***@qq.com

5***@qq.com

.list {
padding-bottom: 0;
padding-bottom: constant(safe-area-inset-bottom);
padding-bottom: env(safe-area-inset-bottom);
}
nvue不支持怎么办?
2020-05-29 10:34
拾柒

拾柒

一般全面屏、刘海屏只会对是否遮挡有影响,对内容的显示是没有影响的吧,是吗?
2020-04-23 18:25