I have discovered a strange phenomenon about iOS18.1.1. I set a logo as the titleView in my navigationBar, and then when I added a view to the navigationBar and pushed it to another page before popping it back up, I found that the view hierarchy of the navigationBar would change in a very short time. In this short time, the logo would cover the view. I did not find this phenomenon on devices below iOS18.1.1. I would like to know what changes have occurred in iOS18.1.1 that caused the view hierarchy to change during the pop process. I hope someone can help me. Thank you very much
Regarding the issue of navigation bar hierarchy in iOS 18
I suspect that iOS 18 may have some upgrades and optimizations for animations, which may result in some changes in the view hierarchy for view push or pop. Unfortunately, I did not get more information from the official documentation.
Specifics about the view hierarchy of the UINavigationBar
are undocumented and not to be relied upon. Specifically adding your own subviews directly to the UINavigationBar
is unsupported – UIKit manages the navigation bar's view hierarchy in order to ensure correct behavior of the navigation bar, and added subviews that it is not managing may interfere with that in ways that we cannot predict.
There may be supported ways to do what you want, but we'd need to understand what you are trying to implement first.
In order to describe the problem more clearly, I have uploaded some files and demo, hoping to understand my difficulties。
My first controller:
override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = UIColor.red
// Do any additional setup after loading the view.
let companyLogo = UIImageView(image:#imageLiteral(resourceName: "logo"))
navigationItem.titleView = companyLogo
let customView = UIView(frame: CGRect(x: 200, y: 5, width: 40, height: 20))
customView.backgroundColor = UIColor.blue
navigationController?.navigationBar.addSubview(customView)
let button = UIButton(type: .custom)
button.backgroundColor = UIColor.green
button.frame = CGRect(x: 100, y: 300, width: 100, height: 100)
self.view.addSubview(button)
button.addTarget(self, action: #selector(clickAction), for: .touchUpInside)
}
Button click event:
@objc private func clickAction() {
let second = SecondViewController()
navigationController?.pushViewController(second, animated: true)
}
When I execute a back in SecondViewController, during this animation process, customeview is briefly overwritten by navigationItem.titleView. I want to know why this is happening?