WedX - журнал о программировании и компьютерных науках

Как установить цвет фона панели навигации для всех сцен

У меня есть вид с вкладками с 5 вкладками. Также у меня есть панель навигации, и с помощью следующего кода я меняю цвет фона:

//Change navigation colors
viewController.navigationController?.navigationBar.barTintColor = UIColor.orange
viewController.navigationController?.navigationBar.tintColor = UIColor.white
viewController.navigationController?.navigationBar.titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white]

Каждая вкладка имеет свой собственный контроллер представления, поэтому вместо того, чтобы помещать тот же код в метод viewDidLoad(), я создал класс UIHelper со статическим методом setupNavigation(viewController: UIViewController). Итак, в каждом viewController в методе viewDidLoad() я просто вызываю метод:

UIHelper.setupNavigation(viewController: self)

Есть ли более простой способ изменить глобальный цвет фона панели навигации?

Я использую Свифт 4.

Изменить: на самом деле у меня есть один MasterViewController, и каждый контроллер представления вкладки расширяет его. Итак, UIHelper.setupNavigation называется в viewDidDLoad() MasterViewController.

18.04.2018

Ответы:


1

У вас есть много способов сделать это: Сначала создайте superViewController, и все остальные контроллеры представления наследуют этот:

import UIKit

class SuperViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        self.navigationController?.navigationBar.barTintColor = UIColor.orange
        self.navigationController?.navigationBar.tintColor = UIColor.white
        self.navigationController?.navigationBar.titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white]
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
}

Другие контроллеры представлений, подобные этому:

class ViewController: SuperViewController {

    @IBOutlet weak var pageVC: UIView!
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
}

Теперь вам не нужно устанавливать цвет навигации в приложении, используйте Inherit superViewcontroller в каждом контроллере представления. Вы можете добавить все распространенные методы, которым вы собираетесь следовать в каждом контроллере.

Второй способ сделать это

///Common NavigationController for every controller used in application
class NavigationController: UINavigationController {

    // MARK: - View Lifecycle
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        self.navigationBar.barTintColor = UIColor.red
        self.navigationBar.titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white]
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
}

Используйте этот навигационный контроллер везде в приложении. Если вам нужен навигационный контроллер, укажите этот класс в навигационном контроллере.

18.04.2018
  • Да, у меня есть MasterViewController, и UIHelper.setupNavigation(viewController: self) помещается в его viewDidLoad(). Я предполагаю, что другой ответ предлагает более глобальный и точный способ сделать это. Я собираюсь прочитать больше об этом. Спасибо за ответ 18.04.2018
  • Пожалуйста, используйте общий навигационный контроллер в вашем приложении. Я обновил свой ответ. Пожалуйста, посмотрите 18.04.2018

  • 2

    Вы можете использовать прокси-класс панели навигации (который перенаправляет настройки на все панели навигации), например, запустите это в методе DidFinishLaunchingWithOptions AppDelegate:

    UINavigationBar.appearance().barTintColor = UIColor.orange
    UINavigationBar.appearance().tintColor = UIColor.white
    UINavigationBar.appearance().titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white]
    
    18.04.2018
  • Этот ответ относится к панели навигации, а не к строке состояния. 18.09.2018

  • 3

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

    import UIKit
    
    class CustomNavigationController: UINavigationController {
    
        override func viewDidLoad() {
            super.viewDidLoad()
    
            //Change navigation colors
            self.navigationBar.barTintColor = UIColor.orange
            self.navigationBar.tintColor = UIColor.white
            self.navigationBar.titleTextAttributes = [NSAttributedStringKey.foregroundColor: UIColor.white]
        }
    
        //this method allow you to ask each controller for status bar style in navigation stack
        override var childViewControllerForStatusBarStyle: UIViewController? {
            return self.topViewController
        }
    
    }
    

    В вашем классе контроллера представления вы также должны переопределить это свойство.

    import UIKit
    
    class ViewController: UIViewController {
    
        override var preferredStatusBarStyle: UIStatusBarStyle {
            return .lightContent
        }
    
    }
    
    18.04.2018

    4

    Для поддержки темного режима и swift5 используйте это в AppDelegate:

     func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
    
     UINavigationBar.appearance().titleTextAttributes = [NSAttributedString.Key.foregroundColor: .green]
        
        if #available(iOS 13.0, *) {
            if UITraitCollection.current.userInterfaceStyle == .dark {
                UINavigationBar.appearance().barTintColor = .black
            } else {
                UINavigationBar.appearance().barTintColor = .white
            }
        } else {
            UINavigationBar.appearance().barTintColor = .white
        }
    
    ...
    return true
    }
    
    31.03.2021
    Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]