Swift - создание управляющего контроллера без раскадров в App Delegate
Я перестраиваю приложение без раскадровки, а часть его, с которой у меня возникают проблемы, - это программно программировать просмотр-просмотр. Там написано мало вещей, которые не используют раскадровки, поэтому найти ответ для этого было непросто.
Моя проблема довольно проста. У меня есть мой ViewController
и мой SecondViewController
, и я хочу нажать от первого до последнего.
В AppDelegate
:
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
// Override point for customization after application launch.
window = UIWindow(frame: UIScreen.mainScreen().bounds)
window?.backgroundColor = UIColor.whiteColor()
window?.rootViewController = ViewController()
window?.makeKeyAndVisible()
return true
}
Затем в ViewController.swift
:
class ViewController: UIViewController, AVAudioPlayerDelegate, UITextFieldDelegate {
override func viewDidLoad() {
super.viewDidLoad()
startFinishButton.setTitle("Begin", forState: .Normal)
startFinishButton.addTarget(self, action: "moveToSecondViewController", forControlEvents: .TouchUpInside)
view.addSubview <*> startFinishButton
}
func moveToSecondViewController(sender: UIButton) {
let vc = SecondViewController()
println(self.navigationController) // returns nil
self.navigationController?.pushViewController(vc, animated: true)
}
}
Печать self.navigationController
возвращает нуль. Я пробовал делать:
var navController = UINavigationController()
, когда класс ViewController
создается (но вне ViewDidLoad, прямо под объявлением класса), и выполнил нажатие с помощью navController
var, но это не сработало.
Я думаю, может быть, решение состоит в том, чтобы создать контроллер навигации в App Delegate, который будет использовать все приложение, я полагаю, что это глобальная переменная?
Моя надежда заключается в том, что этот пост может обслуживать многих других, которые являются новыми для Swift и хотят удалить раскадровки из своего приложения.
Спасибо, что посмотрели и за вашу помощь.
Ответы
Ответ 1
В Swift 3
Поместите этот код внутри метода didFinishLaunchingWithOptions в класс AppDelegate.
window = UIWindow(frame: UIScreen.main.bounds)
let mainController = MainViewController() as UIViewController
let navigationController = UINavigationController(rootViewController: mainController)
navigationController.navigationBar.isTranslucent = false
self.window?.rootViewController = navigationController
self.window?.makeKeyAndVisible()
Ответ 2
В AppDelegate
var window: UIWindow?
var navController: UINavigationController?
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
navController = UINavigationController()
var viewController: ViewController = ViewController()
self.navController!.pushViewController(viewController, animated: false)
self.window = UIWindow(frame: UIScreen.mainScreen().bounds)
self.window!.rootViewController = navController
self.window!.backgroundColor = UIColor.whiteColor()
self.window!.makeKeyAndVisible()
return true
}
В ViewController
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
self.title = "FirstVC"
var startFinishButton = UIButton.buttonWithType(UIButtonType.System) as! UIButton
startFinishButton.frame = CGRectMake(100, 100, 100, 50)
startFinishButton.backgroundColor = UIColor.greenColor()
startFinishButton.setTitle("Test Button", forState: UIControlState.Normal)
startFinishButton.addTarget(self, action: "buttonAction:", forControlEvents: UIControlEvents.TouchUpInside)
self.view.addSubview(startFinishButton)
}
func buttonAction(sender:UIButton!)
{
println("Button tapped")
let vc = SecondViewController()
self.navigationController?.pushViewController(vc, animated: true)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}