Swift - заголовок не отображается для контроллера навигации

У меня есть контроллер представления навигации, который после действия отправляет переход к контроллеру панели вкладок. По этой причине контроллер представления с вкладками наследует панель навигации. Я пытаюсь применить заголовок к одному из моих контроллеров представления, прикрепленных к контроллеру панели вкладок, но настройка заголовка с помощью кода не работает для меня. Кто-нибудь знает причину, почему это может быть?

Вот изображение моей раскадровки:

storuboard

В контроллере вида с кнопкой выхода я пытаюсь установить заголовок в навигационной панели (код):

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]

Это работает для меня. Я надеюсь, что это поможет кому-то.

Другие вопросы по тегам