iOS - iPhone手机刘海屏判断

本文介绍了如何在iOS中判断刘海屏,包括安全区底部边距法和屏幕宽高比判断法,并提供相关宏定义。适配刘海屏对于iPhone X之后的设备至关重要,确保UI布局正确。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2022.04.11 更新,修改获取 iPhone 状态栏、导航栏、TabBar高度等部分内容。


前言

最近写毕业设计的时候,发现 iPhoneX 之后的刘海屏手机顶部状态栏高度底部TabBar高度和原来不一样了,这就需要我们对刘海屏手机做单独的 UI 布局适配了。

刘海屏判断

适配的核心是要对刘海屏进行判断,以下针对刘海屏手机的特征,提供了两种判断方法。

1. 安全区底部边距判断法

在 iOS 11 之后,多了安全区(下图蓝色区域)的概念。刘海屏手机因为多了下方的小黑条,底部安全区存在距离屏幕底部的边距,而且这是非刘海屏所不具有的
safe_area
因此,我们可以将其作为判断刘海屏的依据。如果系统大于 iOS 11 且安全区底部到屏幕底部存在间距,就将其判断为刘海屏。代码如下:

// 刘海屏判断
#define iPhoneX ({
      \
    BOOL iPhoneX = NO; \
    if (@available(iOS 11.0, *)) {
      \
        if ([UIApplication sharedApplication].windows[0].safeAreaInsets.bottom > 0) {
      \
            iPhoneX = YES; \
        } \
    } \
    iPhoneX; \
})

2. 屏幕宽高比判断法

考虑到我不太喜欢写这种多行宏定义,据说会降低编译速度。我又继续寻找其他刘海屏的特征,终于在下面这一张图中找到了灵感。
在这里插入图片描述
由上图所示,但凡是刘海屏手机,屏幕的纵横比都是 19 : 9

设手机屏幕宽度为 W i d t h Width Width</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值