Изменить свойство View Controller из метода делегата - PullRequest
0 голосов
/ 10 июня 2019

Я использую Swift 4.2 и Xcode 10.2.

Я создал пользовательское оповещение, которое UIViewController называется DialAlert. Он накладывается поверх текущего UIViewController и имеет две кнопки, Call и Cancel.

При нажатии Call я сообщаю о касании нижележащему контроллеру представления с помощью метода делегата, называемого callTapped.. Этот метод выполняет настройку вызова с использованием различных других методов. Пока он выполняет настройку вызова, я хотел бы обновить DialAlert viewcontroller со статусом. Но я не могу получить доступ к его свойствам из callTapped, метода делегата, потому что он был создан в методе tableView следующим образом:

let dialAlert = self.storyboard?.instantiateViewController(withIdentifier: Constants.Storyboard.dialAlert) as! DialAlert

И именно в этом методе tableView я устанавливаю все его начальные свойства.

Я пробовал этот код в начале урока:

var dialAlert = UIViewController() as! DialAlert

и затем ссылается на self.dialAlert по всему коду (который скомпилировал), но во время выполнения я получаю ошибку, что не могу привести значение типа UIViewController к DialAlert.

Как изменить свойства dialAlert в методе, отличном от того, в котором был создан экземпляр? Я нашел некоторые ответы в SO, которые выглядели многообещающими, но ничего недавнего и ничего не значащего.

1 Ответ

0 голосов
/ 11 июня 2019

У меня есть решение ваших проблем, я не знаю, как вы кодируете, чтобы показать свой DialAlert, но по моему вы можете понять, как его реализовать.

Итак, прежде всего в AppDelegate.swift добавьте следующий код.

class AppDelegate: UIResponder, UIApplicationDelegate {

    static var shared  = UIApplication.shared.delegate as! AppDelegate
    var window: UIWindow?

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        return true
    }

    .....
    .....
}

После этого, внутри вашего диалогового оповещения объявите протокол и создайте делегата, кроме этой проверки делегата и вызова метода делегата при нажатии кнопки.

DialAlertVC.swift

protocol DialAlertVCDelegate: class {
    func callButtonTapped(_ sender: UIButton)
    func cancelButtonTapped(_ sender: UIButton)
}


class DialAlertVC: UIViewController {

    @IBOutlet weak var dialAlertView: UIView!

    weak var delegate   : DialAlertVCDelegate?

    class func viewController() -> DialAlertVC {
        return UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "DialAlertVC") as! DialAlertVC
    }

    @IBAction func btnCallTapped(_ sender: UIButton) {

        if let selfDelegate = self.delegate {
            selfDelegate.callButtonTapped(sender)
        }
    }

    @IBAction func btnCancelTapped(_ sender: UIButton) {

        if let selfDelegate = self.delegate {
            selfDelegate.cancelButtonTapped(sender)
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()
    }
}

Теперь пришло время показать / скрыть DialoAlertVC, поэтому внутри ViewController добавьте следующий код.

ViewController.swift

class ViewController: UIViewController {

    @IBOutlet weak var lblButtonTapped: UILabel!

    var dialAlertVC         : DialAlertVC?

    @IBAction func btnShowDialAlert(_ sender: UIButton) {
        self.showDialAlert(true)
    }

    func showDialAlert(_ show: Bool) {

        if show {

            if self.dialAlertVC != nil {
                self.dialAlertVC?.view.removeFromSuperview()
                self.dialAlertVC = nil
            }

            dialAlertVC = DialAlertVC.viewController()
            dialAlertVC?.delegate = self
            AppDelegate.shared.window?.addSubview(dialAlertVC!.view)

        } else {

            if self.dialAlertVC != nil {
                self.dialAlertVC?.view.removeFromSuperview()
                self.dialAlertVC = nil
            }
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()
    }
}

extension ViewController: DialAlertVCDelegate {

    func callButtonTapped(_ sender: UIButton) {
        self.showDialAlert(false)
        self.lblButtonTapped.text = "Call Button Tapped"
    }

    //------------------------------------------------------------------------------

    func cancelButtonTapped(_ sender: UIButton) {
        self.showDialAlert(false)
        self.lblButtonTapped.text = "Cancel Button Tapped"
    }
}

Смотрите демонстрационный проект здесь: https://gofile.io/?c=P2VKCl

Надеюсь, это поможет вам.

...