iOS15 坑!和适配

作者: 林希品 | 来源:发表于2021-10-21 14:05 被阅读0次
iOS15


UINavigationBar

用新 xcode13 编译工程后,导航栏的问题比较明显,调试之后发现是 UINavigationBar 部分属性的设置在 iOS15 上是无效的

查看导航栏特性 API:UINavigationBarAppearance 后发现,iOS15navigationBar 的相关属性设置要通过实例 UINavigationBarAppearance 来实现,UINavigationBarAppearance 是 iOS13 更新的 API,应该有人已经在用,我们的应用兼容 iOS10 以上,对于导航栏的设置还没有使用 UINavigationBarAppearance,如今在 iOS15 上失效,所以对于呈现的问题,做如下适配:

解决方法:主要是以下两个属性 (UINavigationController 的属性)

// 静止样式self.navigationBar.standardAppearance;

// 滚动样式self.navigationBar.scrollEdgeAppearance;

swift:

if #available(iOS 13.0, *) {

            let appearance = UINavigationBarAppearance()

              // 设置导航栏背景色

            appearance.backgroundColor = .white

              // 去除导航栏阴影(如果不设置clear,导航栏底下会有一条阴影线)

            appearance.shadowColor = UIColor.clear

              // 字体颜色、尺寸等

            appearance.titleTextAttributes = [NSAttributedString.Key.foregroundColor: UIColor.white]

            // 带scroll滑动的页面

            navigationController?.navigationBar.scrollEdgeAppearance = appearance

            // 常规页面

            navigationController?.navigationBar.standardAppearance = appearance

        }

OC:

if (@available(iOS 13.0, *)) {

        UINavigationBarAppearance * appearance = [[UINavigationBarAppearance alloc] init];

        // 背景色

        appearance.backgroundColor = [UIColor whiteColor];

        // 去除导航栏阴影(如果不设置clear,导航栏底下会有一条阴影线)

        appearance.shadowColor = [UIColor clearColor];

        // 字体颜色、尺寸等

        appearance.titleTextAttributes = @{NSForegroundColorAttributeName: [UIColor redColor]};

        // 带scroll滑动的页面

        self.navigationController.navigationBar.scrollEdgeAppearance = appearance;

        // 常规页面

        self.navigationController.navigationBar.standardAppearance = appearance;

    }

appdelegate全局设置

(代码大差不差,此处就只列出 oc 的代码)之前有人遇到导航栏隐藏的返回按钮失效问题,备注里面也已经解决,并做出说明

[[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(-200, 0) forBarMetrics:UIBarMetricsDefault];

    // iOS 15适配

    if (@available(iOS 13.0, *)) {

        UINavigationBarAppearance *appearance = [[UINavigationBarAppearance alloc] init];

        [appearance setBackgroundColor:[UIColor whiteColor]];

        // UINavigationBarAppearance 会覆盖原有的导航栏设置,这里需要重新设置返回按钮隐藏,不隐藏可注释或删掉

        appearance.backButtonAppearance.normal.titlePositionAdjustment = UIOffsetMake(-200, 0);

        [[UINavigationBar appearance] setScrollEdgeAppearance: appearance];

        [[UINavigationBar appearance] setStandardAppearance:appearance];

    }

UITabbar

tabbar 的问题和 navigationBar 的问题属于同一类,tabbar 背景颜色设置失效

swift

        if #available(iOS 13.0, *) {

            let appearance = UITabBarAppearance()

          // 背景色

            appearance.backgroundColor = .white

            tabBar.standardAppearance = appearance

            if #available(iOS 15.0, *) {

                tabBar.scrollEdgeAppearance = appearance

            }

        }

OC

    if (@available(iOS 13.0, *)) {

        UITabBarAppearance * appearance = [[UITabBarAppearance alloc] init];

        // 背景色

        appearance.backgroundColor = [UIColor whiteColor];

        self.tabBar.standardAppearance = appearance;

        if (@available(iOS 15.0, *)) {

            self.tabBar.scrollEdgeAppearance = appearance;

        }

    }

TableView

iOS 15 的 UITableView 新增了一条新属性:sectionHeaderTopPadding, 默认会给每一个 section header 增加一个高度,当我们使用 UITableViewStylePlain 初始化 UITableView 的时候,能发现 sectionHeader 增高了 22px。

swift

//为了配合以前的开发习惯,我们只需要在创建实例的时候进行对间距的设置即可

  if #available(iOS 15.0, *) {

      tableView.sectionHeaderTopPadding = 0

  }

//或者全局设置

  if #available(iOS 15.0, *) {

    UITableView.appearance().sectionHeaderTopPadding = 0

  }

OC

//为了配合以前的开发习惯,我们只需要在创建实例的时候进行对间距的设置即可

    if (@available(iOS 15.0, *)) {

        tableView.sectionHeaderTopPadding = 0;

    }

//或者全局设置

    if (@available(iOS 15.0, *)) {

        [UITableView appearance].sectionHeaderTopPadding = 0;

    }

相关文章

  • iOS15 坑!和适配

    UINavigationBar 用新 xcode13 编译工程后,导航栏的问题比较明显,调试之后发现是 UINav...

  • iOS15适配

    以iOS15和xcode13为环境基础,iOS15适配的一些更改和调整。 UINavigationBar UITa...

  • iOS15适配

    以iOS15和xcode13为环境基础,iOS15适配的一些更改和调整。 UINavigationBar UITa...

  • Xcode13踩坑,iOS15适配

    Xcode13踩坑,iOS15适配 1.升级完Xcode13之后遇到滚动tableView到底部时tabbar颜色...

  • html2canvas在ios15系统截图空白并刷新

    随着ios15系统的出现,项目适配ios15系统兼容性。 发现html2canvas在iOS15系统中截图空白并在...

  • iOS15 适配更新总结

    本文主要分享一下 iOS15 上适配方案,仅做开发记录使用,开发过程中通过使用陆续增加。 iOS15 的适配,很重...

  • iOS开发技巧之:iOS15 适配更新总结

    本文主要分享一下 iOS15 上适配方案,仅做开发记录使用,开发过程中通过使用陆续增加。 iOS15 的适配,很重...

  • iOS15适配

    iOS15适配主要是以下几点:UINavigationController、UITabBarController、...

  • iOS15适配

    对于iOS15适配汇总以及遇到的问题 注意:以下适配内容,必须适配的会以"必须"标出 UITableView Se...

  • iOS 15 适配笔记

    前言 环境 在 升级xcode 13.0 之后,正式开始支持 iOS15,就需要做适配 iOS15了,在 xcod...

网友评论

    本文标题:iOS15 坑!和适配

    本文链接:https://www.haomeiwen.com/subject/eemfaltx.html