Получение справки по контроллеру представления

Я прочитал довольно много вопросов и ответов нет этой проблемы. Некоторые для Ojective C. Некоторые для iOS. Те, которые были близки к тому, что мне нужно, не работали.

Я установил протокол для делегирования. Не работает Проблема в том, что переменная делегата не установлена. Мне нужна ссылка на активный контроллер.

доверитель

protocol SwitchTabDelegate: class {
  func selectTab(tab: Int)
}

class ViewController: NSViewController {

  weak var delegate: SwitchTabDelegate?

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

  @IBAction func selectCompositions(_ sender: NSButton) {

    if let delegate = self.delegate {
      delegate.selectTab(tab: 2)
    }
    else {
      print("self.delegate is nil")
    }
    print("delegate called")
  }
}

Delegatee

class TabViewController: NSTabViewController, SwitchTabDelegate {

  var viewController : ViewController?;

  override func viewDidLoad() {
    super.viewDidLoad()
    //viewController = storyboard?.instantiateController(withIdentifier: "viewController") as? ViewController
   // viewController?.delegate = self
  // print(viewController)
  }

  func selectTab(tab: Int) {
    print("In the delegate")
    switchToDataTab()
  }

  func switchToDataTab() {
    Timer.scheduledTimer(timeInterval: 0.2, target: self,
        selector: #selector(switchToDataTabCont),
        userInfo: nil, repeats: false)
  }

  func switchToDataTabCont(){
    self.selectedTabViewItemIndex = 2
  }
}

Делегат является основным NSViewContoller. На раскадровке он содержит две кнопки и контроллер представления контейнера. В контроллер представления контейнера встроен TabViewController, делегат. Вы можете увидеть в делегате, где я пытался получить ссылку. Он действительно получает ссылку, предположительно, на недавно созданный экземпляр. Мне нужна ссылка на оригинальный контроллер представления, который был запущен при запуске приложения.

Ответ

Я добавил следующий код в делегаторе:

override func prepare(for segue: NSStoryboardSegue, sender: Any?) {

  let controller = segue.destinationController as! TabViewController
  self.delegate = controller as SwitchTabDelegate
 }

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

1 ответ

Решение

При использовании раскадровок вы хотите "выдвигать" ссылки на детей при их создании, а не извлекать их из вышестоящего контроллера. Для этого используется -prepareForSegue:sender:.

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