跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
Objective-C大前端

iOS 26 开发兼容适配:UITabBar 液态玻璃效果与 WiFi SSID 获取

iOS 26 系统更新导致 UITabBar 液态玻璃效果引发布局异常、KVC 注入受限及相册权限收紧。解决方案包括 Info.plist 配置取消特效、调整 intrinsicContentSize 尺寸、视频文件拷贝至沙盒处理转码权限错误,以及使用 NEHotspotNetwork 替代 CNCopySupportedInterfaces 获取 WiFi SSID。

战神发布于 2026/3/29更新于 2026/6/1228 浏览

1. UITabBarButtonItem 液态玻璃效果

兼容处理:

第一种方式 (不推荐):把所有的 UITabBarButtonItem 关闭液态玻璃效果:

if (@available(iOS 26.0, *)) {
    self.navigationItem.rightBarButtonItem.hidesSharedBackground = YES;
    self.navigationItem.leftBarButtonItem.hidesSharedBackground = YES;
} else {
    // Fallback on earlier versions
}

第二种方式:所有导航栏按钮全部采用 UITabBarButtonItem,支持液态玻璃效果。

第三种方式:降低 Xcode 版本到 Xcode 25 及以下版本,然后再打包。

第四种方式:使用兼容模式显示传统 UI 风格,也就是取消 TabBar 液态玻璃效果:

打开 info.plist,添加一个 Boolean 键值对,取消液态玻璃效果,添加完成后重新运行,UITabBar 恢复旧的样式:

<key>UIDesignRequiresCompatibility</key>
<true/>

2. 自定义 navigationItem.titleView 尺寸问题

在 iOS 26 上,采用 UILayoutFittingExpandedSize 设置自定义的 navigationItem.titleView 内容尺寸时高度偏大,高度变为屏幕的高度,预期是高度应该为导航栏的高度。

原因:在 iOS 26 之前 UILayoutFittingExpandedSize 最大尺寸限制在导航栏范围内,而在 iOS 26 则允许充斥整个屏幕:

- (CGSize)intrinsicContentSize { return UILayoutFittingExpandedSize; }

兼容处理:

修改 intrinsicContentSize,指定 titleView 的尺寸大小为导航栏大小:

#define SCREEN_WIDTH ([[UIScreen mainScreen] respondsToSelector:@selector(nativeBounds)] ? [UIScreen mainScreen].nativeBounds.size.width / [UIScreen mainScreen].nativeScale : [UIScreen mainScreen].bounds.size.width)
- (CGSize)intrinsicContentSize { return CGSizeMake(SCREEN_WIDTH, 44); }

3. UITabBarController KVC 注入失效

UITabBarController 调用 self.setValue(yourTabBar, forKey: "tabBar") 自定义 tabBar 失效。

原因:iOS 26 之后对 UITabBarController 的 KVC 注入限制,导致无效,但不会 crash。

兼容处理:

方案 1:使用兼容模式显示传统 UI 风格,也就是取消 TabBar 液态玻璃效果:

打开 info.plist,添加一个 Boolean 键值对,取消液态玻璃效果,添加完成后重新运行,UITabBar 恢复旧的样式:

<key>UIDesignRequiresCompatibility</key>
<true/>

方案 2:改为使用系统的 UITabBarItem 组件,能够支持新系统的液态玻璃效果。

方案 3:降低 Xcode 版本到 Xcode 25 及以下版本,然后再打包。

4. AVAssetExportSession 转码失败

创建一个由 URL 标识的代表任何资源的 asset 对象时报错:

AVAssetExportSessionStatusFailed: Error Domain=AVFoundationErrorDomain Code=-11800 "这项操作无法完成" UserInfo={ NSUnderlyingError=0x1586626a0 { Error Domain=NSOSStatusErrorDomain Code=-16979 "(null)" }, NSLocalizedFailureReason=发生未知错误(-16979), NSURL=file:///var/mobile/Media/DCIM/100APPLE/IMG_0426.MOV, NSLocalizedDescription=这项操作无法完成 }

原因:AVAssetExportSession -11800 / -16979 转码失败,权限不足、文件不可读。创建一个由 URL 标识的代表任何资源的 asset 对象时,传入的 originFilePath 示例:file:///var/mobile/Media/DCIM/100APPLE/IMG_0426.MOV,没有读的权限,因为 iOS 26 对相册视频读取权限收紧。

代码示例:

// originFilePath 示例:file:///var/mobile/Media/DCIM/100APPLE/IMG_0426.MOV
AVURLAsset *asset = [AVURLAsset URLAssetWithURL:originFilePath options:nil]; 

兼容处理:先将相册的视频拷贝到 App 沙盒临时目录,然后再去创建资源对象 AVURLAsset。

[self copyVideoToSandbox:originFilePath completion:^(NSURL *localUrl) {
    AVURLAsset *asset = [AVURLAsset URLAssetWithURL:localUrl options:nil];
}];

- (void)copyVideoToSandbox:(NSURL *)originUrl completion:(void (^)(NSURL *localUrl))completion {
    NSString *temp = [NSTemporaryDirectory() stringByAppendingPathComponent:@"tempVideo.mov"];
    NSURL *localUrl = [NSURL fileURLWithPath:temp];
    NSFileManager *fm = [NSFileManager defaultManager];
    if ([fm fileExistsAtPath:temp]) {
        [fm removeItemAtPath:temp error:nil];
    }
    NSError *err = nil;
    BOOL ok = [fm copyItemAtURL:originUrl toURL:localUrl error:&err];
    if (!ok || err) {
        NSLog(@"拷贝失败:%@", err);
        completion(nil);
        return;
    }
    completion(localUrl);
}

5. WiFi SSID 获取失效

通过 CNCopySupportedInterfaces 获取 wifi ssid 的方式已失效:

class func getWifiSSID() -> String? {
    var wifiName: String?
    let wifiInterfaces = CNCopySupportedInterfaces()
    if wifiInterfaces != nil {
        let interfaceArr = CFBridgingRetain(wifiInterfaces) as! [String]
        if interfaceArr.count > 0 {
            let interfaceName = interfaceArr[0] as CFString
            let unsafeInterfaceData = CNCopyCurrentNetworkInfo(interfaceName)
            if unsafeInterfaceData != nil {
                let interfaceData = unsafeInterfaceData as! [String: Any]
                wifiName = interfaceData["SSID"] as? String ?? ""
            } else {
                return nil
            }
        }
    }
    return wifiName
}

原因:iOS 26 不再推荐使用 CNCopySupportedInterfaces,在 iOS 26 将返回空值。

兼容处理:Capabilities 添加 Access WiFi Information 权限;通过 CLLocationManager 确保有定位权限,然后使用 NEHotspotNetwork 获取 wifi ssid:

NEHotspotNetwork.fetchCurrent { curNetwork in
    block(curNetwork?.ssid ?? "")
}

目录

  1. 1. UITabBarButtonItem 液态玻璃效果
  2. 2. 自定义 navigationItem.titleView 尺寸问题
  3. 3. UITabBarController KVC 注入失效
  4. 4. AVAssetExportSession 转码失败
  5. 5. WiFi SSID 获取失效
  • 免费图片AI生成工具免费生成了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 免费图片视频在线生成30秒,将你的创意变成现实开始设计
  • X/Twitter免费视频下载器免登陆无限额度免费视频解析下载了解详情
  • 100+免费在线小游戏爽一把
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • iOS 26 系统兼容适配:UITabBar 液态玻璃效果与 WiFi SSID 获取
  • MCP Server 案例:Excel 表格一键生成可视化 HTML 报告
  • Minecraft 假面骑士 100 天整合包安装与环境配置指南
  • C++ 实现通用字符串分割 split 函数
  • OpenClaw 本地部署教程:环境配置、插件开发与常见问题排查
  • 豆包 AI 视频去水印:手机端几种高效处理方法
  • SpringBoot 原理:配置优先级、Bean 管理与自动配置
  • Dalvik 虚拟机核心架构与运行机制解析
  • VS Code 使用 Chrome DevTools MCP 实现浏览器自动化
  • GitHub Copilot 学生身份认证及激活教程
  • Spring Security 认证授权实战指南
  • Coze 低代码 AI 智能体平台全解析:100 个落地场景与发布指南
  • 基于 OpenClaw 与 Claude 的自动化写作工作流搭建实践
  • 基于 YOLOv11/v8 与 PaddleOCR 的车牌识别系统实战
  • Rust 异步编程:错误处理的艺术与实践
  • Python、PHP 与 JSP 支付页面开发实现对比
  • 嵌入式物联网设计通用方案:平台对比与 STM32 实战
  • C++ 原子操作 compare_exchange_weak 详解
  • 大模型分布式训练核心原理与高效调参实战
  • SAP 调用外部 Web Service 全流程详解

相关免费在线工具

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown转HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online

  • HTML转Markdown

    将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML转Markdown在线工具,online

  • JSON 压缩

    通过删除不必要的空白来缩小和压缩JSON。 在线工具,JSON 压缩在线工具,online

  • JSON美化和格式化

    将JSON字符串修饰为友好的可读格式。 在线工具,JSON美化和格式化在线工具,online