使用Xcode16打包后,App在暗夜模式下,iOS18 切换Tabbar的item,会有一根白色线条闪过。

一. 背景

使用Xcode16打包后,App在暗夜模式下,切换Tabbaritem,会有一根白色线条闪过。

二. 分析

因为之前版本一直没有这个问题,是使用了Xcode16打包后,然后在iOS18系统上才会出现,一开始以为是UITabbar顶部的分割线导致的,但查看代码UITabbar顶部的分割线已经移除,查看图层,由于闪现也看不到任何东西。

因此通过代码逐步屏蔽并设置各个图层颜色为红色的的方式,逐步排查,最终确定了,这根白线是由UINavigationController引起的,因此查阅资料了解到:

iOS18 引入了新的 UITabBarController 切换动画(如缩放效果),可能在动画过程中短暂暴露底层视图(如 UINavigationController 的根视图背景色)。若 UINavigationController 的背景色与 UITabBar 差异较大,则会出现"闪现"现象。

而我们项目设置的UINavigationControllerview的背景颜色固定是白色,当处于暗夜模式的时候,也没有将UINavigationControllerview的背景颜色改为黑色,因此导致了暗夜模式下,iOS18系统上UITabbar切换出现白色线闪现问题。

三. 治理

该问题的治理有两种方案:

方案一

  • 在暗夜模式想将UINavigationControllerview的背景色也改为暗夜模式下的颜色,这样颜色一致,切换的时候,就不会出现白色线闪现问题。

方案二

  • 如果禁用UITabbar点击的切换动画,来禁止掉iOS18系统UITabBarController的切换动画
ini 复制代码
 // 方法1:包裹切换操作以禁用动画
UIView.performWithoutAnimation {
    tabBarController.selectedIndex = targetIndex
}
相关推荐
天桥吴彦祖2 天前
判断iOS如何监听手机屏幕是否锁屏
ios
敲代码的鱼3 天前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
时光足迹3 天前
uni-app 视频通话实战:康复师与患者视频问诊的 6 个致命 Bug 与解决方案
android·ios·uni-app
时光足迹3 天前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹3 天前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app
时光足迹3 天前
极光推送全攻略(上):被iOS证书折磨了三天,我写了一份前端也能看懂的避坑指南
前端·ios·uni-app
编程范式4 天前
SwiftUI 中图片如何适配可用空间
ios
songgeb6 天前
启发式 UI 自动化:从线性剧本到每步读屏决策
ios·测试
壹方秘境10 天前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios
初级代码游戏15 天前
easy Photo Clean公测版:快速清理iPhone照片 邀请公测
ios·iphone