Swift - заголовок не отображается для контроллера навигации
У меня есть контроллер представления навигации, который после действия отправляет переход к контроллеру панели вкладок. По этой причине контроллер представления с вкладками наследует панель навигации. Я пытаюсь применить заголовок к одному из моих контроллеров представления, прикрепленных к контроллеру панели вкладок, но настройка заголовка с помощью кода не работает для меня. Кто-нибудь знает причину, почему это может быть?
Вот изображение моей раскадровки:
В контроллере вида с кнопкой выхода я пытаюсь установить заголовок в навигационной панели (код):
import UIKit
class ProfileSettingsViewController: UIViewController {
override func viewWillAppear(animated: Bool) {
self.navigationItem.title = "Profile Settings"
}
override func viewDidLoad() {
super.viewDidLoad()
self.navigationItem.leftBarButtonItem = nil
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
@IBAction func logoutButton(sender: AnyObject) {
PFUser.logOut()
var currentUser = PFUser.currentUser()
self.performSegueWithIdentifier("userLoggedOut", sender: self)
self.navigationController?.setNavigationBarHidden(self.navigationController?.navigationBarHidden == false, animated: true)
}
}
Просмотр контроллера, встроенного в контроллер навигации, запускающий переход к контроллеру панели вкладок:
import UIKit
class UserRegistrationViewController: UIViewController {
func displayAlert(title:String, error:String) {
var alert = UIAlertController(title: title, message: error, preferredStyle: UIAlertControllerStyle.Alert)
alert.addAction(UIAlertAction(title: "OK", style: .Default, handler: {
action in
}))
self.presentViewController(alert, animated: true, completion: nil)
}
@IBOutlet var usernameTextField: UITextField!
@IBOutlet var emailTextField: UITextField!
@IBOutlet var passwordTextField: UITextField!
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
@IBAction func registerUser(sender: AnyObject) {
var error = ""
if usernameTextField.text == nil || emailTextField.text == nil || passwordTextField.text == nil {
error = "Please enter a username, email and password"
}
if error != "" {
displayAlert("Error In Form", error: error)
} else {
var user = PFUser.currentUser()
user.username = usernameTextField.text
user.password = passwordTextField.text
user.email = emailTextField.text
user.saveInBackgroundWithBlock {
(succeeded: Bool!, signupError: NSError!) -> Void in
if signupError == nil {
println(user.username)
println(user.password)
println(user.email)
self.performSegueWithIdentifier("successfulRegistration", sender: self)
self.navigationController?.setNavigationBarHidden(self.navigationController?.navigationBarHidden == false, animated: true)
// Hooray! Let them use the app now.
} else {
if let errorString = signupError.userInfo?["error"] as? NSString {
error = errorString
} else {
error = "Please try again later."
}
self.displayAlert("Could Not Sign Up", error: error)
}
}
}
}
}
8 ответов
Это сработало для меня: self.parent?.title = "nav bar title"
В иерархии контроллера вашего представления на панели навигации отображается заголовок UITabBarController
, а не просматривать контроллеры внутри UITabBarController
,
Самый простой способ получить заголовок, показанный на панели навигации, будет
override func viewWillAppear(animated: Bool) {
self.tabBarController?.navigationItem.title = "Profile Settings"
}
Попробуй это:
self.navigationController?.navigationBar.topItem?.title = "Profile Settings"
SWIFT 3
Если он встроен в UINavigationController, вы можете установить заголовок следующим образом из метода viewDidLoad () вашего ViewController.
override func viewDidLoad() {
super.viewDidLoad()
/* If view controller is a direct child of UINavigationController */
self.title = "Title Here"
/* If view controller's parent is a direct child of UINavigationController e.g. a child of embedded tab view controller */
self.parent?.title = "Title Here"
}
В контроллере экрана выхода из системы добавьте это -
self.tabBarController?.navigationItem.title="Profile Settings"
Swift 5 Простой ответ, пожалуйста, следуйте этому
self.title = "Your Title"
or
DispatchQueue.main.async {
self.title = "Your Title"
}
Проверить прокомментированные строки на удобство использования ViewController с Tabbarcontroller и без него
override func viewDidAppear(_ animated: Bool) {
addNavBarImage()
}
func addNavBarImage() {
let navController = self.navigationController!
let image = #imageLiteral(resourceName: "navview") //Your logo url here
let imageView = UIImageView(image: image)
let bannerWidth = navController.navigationBar.frame.size.width
let bannerHeight = navController.navigationBar.frame.size.height
let bannerX = bannerWidth / 2 - (image.size.width) / 2
let bannerY = bannerHeight / 2 - (image.size.height) / 2
imageView.frame = CGRect(x: bannerX, y: bannerY, width: bannerWidth, height: bannerHeight)
imageView.contentMode = .scaleAspectFit
self.navigationItem.titleView = imageView // ViewController without Tabbarcontroller
self.tabBarController?.navigationItem.titleView = imageView //ViewController with Tabbarcontroller
}
Добавьте этот код в свой контроллер просмотра:
// title color
self.navigationController?.navigationBar.titleTextAttributes = [NSAttributedString.Key.foregroundColor: UIColor.black]
Это работает для меня. Я надеюсь, что это поможет кому-то.