我读了很多问题并且没有回答这个问题。一些是针对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")
}
}
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。在故事板上,它包含两个按钮和一个Container视图控制器。嵌入在容器视图控制器中的是TabViewController,即委托者。你可以在代理人看到我试图获得参考。它确实得到了一个引用,大概是对新实例化的实例。我需要一个对应用程序启动时旋转的原始视图控制器的引用。
我将以下代码添加到委托人:
override func prepare(for segue: NSStoryboardSegue, sender: Any?) {
let controller = segue.destinationController as! TabViewController
self.delegate = controller as SwitchTabDelegate
}
根据设计模式,它不应该如何运作。委托人应该不了解被授权人。我在这个问题上花了太多时间,所以黑客会这么做。
答案 0 :(得分:0)
使用故事板时,您希望在创建子项时“推送”对子项的引用,而不是从上游控制器中引用它们。这就是-prepareForSegue:sender:用于。