带有大标题的导航栏黑线

Posted

技术标签:

【中文标题】带有大标题的导航栏黑线【英文标题】:Navigation Bar black line with Large title 【发布时间】:2018-01-18 22:23:13 【问题描述】:

感谢您抽出宝贵时间阅读。

首先,让我说我已经尽我所能寻找解决问题的方法,但无济于事,这让我感到压力很大!所以,如果有人找到答案,请指点我的方向:)

我面临的问题与出现在导航栏下方的黑线有关。现在,我非常清楚设置导航栏的默认图像/阴影图像属性来纠正这个问题,因此,我创建了自己的扩展来实现它(如下所示)

    func hideHairline(_ state:Bool) 
    if state 
        self.shadowImage = UIImage()
        self.setBackgroundImage(UIImage(), for: .any, barMetrics: .default)
    else
        self.setBackgroundImage(UINavigationBar.appearance().backgroundImage(for: UIBarMetrics.default), for:UIBarMetrics.default)
        self.shadowImage = nil

    

但是,有些东西似乎行为不端,我的导航栏下方出现了一条黑线(见下文)

更奇怪的是,模拟器并没有在同一个屏幕上显示这一行。模拟器设置为像素精度。 (如下图)

我认为这可能与我从以前的 VC 改变的方式有关。我正在从隐藏导航栏更改为显示,并将其设置为prefersLargeTitles。现在,如果我设置导航栏,不使用大标题,黑线不会显示。另外,如果我推送到下一个视图控制器,然后弹回,则该行不存在(在推送的控制器上,或新呈现的弹出)

此时,我主要只是想知道为什么会这样?我的意思是,我一定做错了什么。我写了一个设置扩展,只是为了让代码远离 VC,可能不是最好的编码实践,但是嘿!

        self.hideHairline(true)
    self.titleTextAttributes =  [NSAttributedStringKey.foregroundColor : Constants.navigationBarTextColor]
    self.largeTitleTextAttributes = self.titleTextAttributes
    self.barTintColor = Constants.navigationBar
    self.tintColor = Constants.navigationBarTint
    self.isTranslucent = false
    self.backgroundColor = Constants.navigationBar
    self.prefersLargeTitles = true

Constants 是一个包含我的应用程序中所有静态变量的类,例如 colo(u)rs。我只是犯了一些愚蠢的错误,还是大标题有错误?

如果您需要任何进一步的信息,请尽管询问:)

谢谢

【问题讨论】:

【参考方案1】:

所以,在晚上休息后,我找到了解决办法。对于将来可能遇到类似问题的其他人,我将保留这篇文章。

这与UINavigationController 本身的视图有关。我找到了另一个回答它的堆栈溢出帖子 (link here)

我所要做的就是:

self.navigationController?.view.backgroundColor = .white

将 colo(u)r 更改为您需要的任何值。

简单的解决方案,我不敢相信我花了这么长时间才弄清楚。

一切顺利。

【讨论】:

以上是关于带有大标题的导航栏黑线的主要内容,如果未能解决你的问题,请参考以下文章

导航控制器转换上的iOS黑线

如何从自定义导航栏中删除这条黑线

iOS 导航栏黑线,UIImage 枚举处理方式

iOS 去除导航栏下的黑线

带有大标题的导航栏上的动画segue错误

取消iOS10和iOS9以下导航栏黑线