Как использовать новый делегат сцены в Xcode

Я пытаюсь изменить текст метки или показать предупреждение, когда мое приложение iOS становится активным из фонового состояния.

Когда я вызываю функцию в классе ViewController, нормально работает только метод print (). Но когда я хочу взаимодействовать с объектами этого класса, он показывает ошибки.

SceneDelegate.swift:

var vc = ViewController()

func sceneDidBecomeActive(_ scene: UIScene) {
    // Called when the scene has moved from an inactive state to an active state.
    // Use this method to restart any tasks that were paused (or not yet started) when the scene was inactive.

    vc.showMessage("Test message")
}

ViewController.swift:

@IBOutlet weak var textLabel: UILabel!

func showMessage(_ incomingMessage:String!) {
    let warning = UIAlertController(title: "Warning", message: incomingMessage, preferredStyle: .alert)
    let aButton = UIAlertAction(title: "OK", style: .cancel, handler: nil)
    warning.addAction(aButton)

    self.present(warning, animated: true)

    textLabel.text = incomingMessage

    print("message is : " + incomingMessage)
}

person anixrud    schedule 24.10.2019    source источник


Ответы (1)


Как всегда, правильное решение - заставить контроллер представления прослушивать соответствующее событие жизненного цикла вместо того, чтобы делегат приложения или делегат сцены пытался сообщить контроллеру представления что-либо.

В делегате сцены удалите создание ViewController и попытку вызвать showMessage.

Затем обновите свой ViewController класс. Добавьте в viewDidLoad следующее:

NotificationCenter.default.addObserver(self, selector: #selector(didActivate), name: UIScene.didActivateNotification, object: nil)

Затем добавьте метод didActivate:

func didActivate() {
    showMessage("Test Message")
}

А затем добавьте deinit:

deinit {
    NotificationCenter.default.removeObserver(self)
}

Таким образом, только контроллер представления должен знать логику того, что ему нужно делать и когда.

Также обратите внимание, что если вы действительно хотите определить, когда сцена возвращается из фона (выходит на передний план), используйте уведомление willEnterForegroundNotification вместо didActivateNotification.

person rmaddy    schedule 24.10.2019