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

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

要回复文章请先登录注册

1***@qq.com

1***@qq.com

回复 [已删除] :
同问,楼主解决了吗
2021-05-07 22:25
1***@qq.com

1***@qq.com

回复 DCloud_UNI_GSQ :
我们想有的页面底部是白色、有的页面底部是黑色怎么设置呀?必须仿抖音视频滑动的底部就应该是黑色,其他页面是白色
2021-05-07 22:25
270315475

270315475

这个安全区可以设置个透明色吗 别带颜色就好了,又不能单独设置页面,能搞个透明色也能行呀
2021-02-25 14:31
[已删除]

[已删除]

回复 a***@ebao.vip :
我想某个单独的页面不需要底部安全距离,其他都要,我该怎么办呢?有解决方案了吗?我已经在manifest里面设置了全局的了
2021-02-21 20:17
wzsgjlzhy

wzsgjlzhy

如果不设置这个属性,默认值是auto吗?默认应该是有原生占位的吧
2021-01-16 16:24
DCloud_UNI_GSQ

DCloud_UNI_GSQ (作者)

回复 a***@ebao.vip :
不能,此为全局配置
2020-12-16 10:42
a***@ebao.vip

a***@ebao.vip

在manifest.json文件中配置了也生效了,但是会影响我写的其他界面,其他界面需要底部的显示,能不能只针对某一个页面单独取设置这个属性呢
"safearea": {
"bottom": {
"offset": "none"
}
}
2020-12-16 00:03
想得美

想得美

回复 救救孩子吧 :
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