浏海屏手机在部分页面通过[[UIApplication sharedApplication] delegate].window.safeAreaInsets.bottom得到底部安全区高度为0问题

简介: 浏海屏手机在部分页面通过[[UIApplication sharedApplication] delegate].window.safeAreaInsets.bottom得到底部安全区高度为0问题

UI

18 篇文章0 订阅

订阅专栏

浏海屏手机在部分页面通过[[UIApplication sharedApplication] delegate].window.safeAreaInsets.bottom得到底部安全区高度为0问题,如何解决?

出现该问题的页面一般是这样添加的控件:


    LCVideoCommentView *commentV = [[self alloc] initWith:commentId goodsId:goodsid home:ishome];
    commentV.hidden = YES;
//    [DYGetCurrentViewController().view addSubview:commentV];
    [UIApplication.sharedApplication.keyWindow addSubview:commentV];
    [commentV animationShow];

然后在LCVideoCommentView中使用[[UIApplication sharedApplication] delegate].window.safeAreaInsets.bottom获取的高度就是0了。

如我们在播放器SelVideoPlayer中获取到刘海屏手机底部安全区高度为0,我顶部安全区也是0。正如这这样下面的定义:

#define kMainTopHeight  ({ float space = 64.0; if (@available(iOS 11.0, *)) space = ([[UIApplication sharedApplication] delegate].window.safeAreaInsets.top+44); (space); })
#define kMainBottomHeight ({ float space = 49.0; if (@available(iOS 11.0, *)) space = ([[UIApplication sharedApplication] delegate].window.safeAreaInsets.bottom + 49); (space); })

分析原因应该是窗口的问题。那如何解决呢?

可以通过重新获取keyWindow来正确找到底部安全高度和顶部安全区高度。

#define Base_BottomHeight ([FMConfig config].safeBottomHeight)
// 底部安全区域高度
#define BR_BOTTOM_MARGIN \
({CGFloat safeBottomHeight = 0;\
if (@available(iOS 11.0, *)) {\
safeBottomHeight = BRGetKeyWindow().safeAreaInsets.bottom;\
}\
(safeBottomHeight);})


/** 获取 keyWindow */
static inline UIWindow *BRGetKeyWindow(void) {
    UIWindow *keyWindow = nil;
#if __IPHONE_OS_VERSION_MAX_ALLOWED >= 130000 // 编译时检查SDK版本:Xcode11+编译会调用(iOS SDK 13.0 以后版本的处理)
    if (@available(iOS 13.0, *)) {
        NSSet<UIScene *> *connectedScenes = [UIApplication sharedApplication].connectedScenes;
        for (UIScene *scene in connectedScenes) {
            if (scene.activationState == UISceneActivationStateForegroundActive && [scene isKindOfClass:[UIWindowScene class]]) {
                UIWindowScene *windowScene = (UIWindowScene *)scene;
                for (UIWindow *window in windowScene.windows) {
                    if (window.isKeyWindow) {
                        keyWindow = window;
                        break;
                    }
                }
            }
        }
    } else
#endif
    {
#if __IPHONE_OS_VERSION_MIN_REQUIRED < 130000
        return [UIApplication sharedApplication].keyWindow;
#endif
    }
    
    return keyWindow;
}

该方法绝大部份情况下可以,但是也有部份场景失效。如我在tabbar首页,隐藏状态栏,采用TXVodPlayer插入表格图层的页面,竟然也是算出的iPhone xr底部tabbar高度是49。

- (CGFloat)statusHeight{
    if (_statusHeight == 0) {
        if (@available(iOS 13.0, *)) {
            _statusHeight = self.windowScene.statusBarManager.statusBarFrame.size.height;
        } else {
            _statusHeight = [UIApplication sharedApplication].statusBarFrame.size.height;
        }
    }
    return _statusHeight;
}

- (BOOL)isIPhoneX{
    return self.statusHeight > 20;
}

- (CGFloat)safeBottomHeight{
    return self.isIPhoneX ? 34 : 0;
}

- (CGFloat)tabBarHeight{
    return self.isIPhoneX ? 83 : 49;
}

对于该种场景的解决方法:

#define kMainBottomHeight ({ float space = 49.0; if ([[UIApplication sharedApplication] statusBarFrame].size.height>20) space = 83.0; (space); })

当然这种方法也不是万能的方法,需要结合具体场景来使用。

目录
相关文章
|
6月前
|
JSON 安全 JavaScript
怎么保护苹果手机移动应用程序ipa中文件安全?
怎么保护苹果手机移动应用程序ipa中文件安全?
68 1
|
6月前
【实现手机端上滑滚动加载列表】判断页面是否滚动到底部或者指定元素位置
【实现手机端上滑滚动加载列表】判断页面是否滚动到底部或者指定元素位置
|
移动开发 小程序 Android开发
小程序webview组件嵌H5页面,安卓手机没有问题,苹果有部分页面不显示
小程序webview组件嵌H5页面,安卓手机没有问题,苹果有部分页面不显示
187 0
uniapp小程序单页面改变手机电量,头部通知的颜色效果demo(整理)
uniapp小程序单页面改变手机电量,头部通知的颜色效果demo(整理)
|
5月前
|
安全
手机kali终端,集成安全集成工具----使用arpspoof工具给电脑断网------断网,网络攻击手段
手机kali终端,集成安全集成工具----使用arpspoof工具给电脑断网------断网,网络攻击手段
|
4月前
|
前端开发 小程序
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
【微信小程序-原生开发】实用教程20 - 生成海报(实战范例为生成活动海报,内含生成指定页面的小程序二维码,保存图片到手机,canvas 系列教程)
408 0
|
4月前
|
Web App开发 编解码
软件开发常见流程之兼容性和手机屏页面设计,PC端和移动端常见浏览器,国内的UC都是根据Webkit修改过来的内核,开发重点关注尺寸,常见移动端尺寸汇总,移动端,理想视口根据你设别的样式进行修改
软件开发常见流程之兼容性和手机屏页面设计,PC端和移动端常见浏览器,国内的UC都是根据Webkit修改过来的内核,开发重点关注尺寸,常见移动端尺寸汇总,移动端,理想视口根据你设别的样式进行修改
|
4月前
|
前端开发 Windows
手机真机调试本地前端页面
手机真机调试本地前端页面
127 0
|
5月前
|
JavaScript
技术心得:根据不同访问设备跳转到PC页面或手机页面
技术心得:根据不同访问设备跳转到PC页面或手机页面
61 0
|
6月前
|
UED
禁止手机侧滑返回上一个页面的三种方法
禁止手机侧滑返回上一个页面的三种方法
373 0

热门文章

最新文章