我们说我有3 ViewControllers
标有" A"," B"和" C"。现在," A"是窗口的rootViewController
,它表示" B"模态。当按下按钮时," B"它应该立即以模态方式呈现C并且解雇" B"自动。我怎样才能做到这一点?我在StackOverflow中看到了所有示例,但它们无法正常工作
@IBAction func proceedBtnTapped(_ sender: Any) {
weak var pvc = self.presentingViewController
let vc = ThirdViewController()
pvc?.present(vc, animated: true, completion: { [weak self] in
self?.dismiss(animated: true, completion: nil)
})
}
这是我的代码。有什么帮助吗?
答案 0 :(得分:2)
首先关闭 b 视图控制器,然后在 A 上显示 c 视图控制器。
试试这个。
ComplexObject
答案 1 :(得分:2)
如果您使用segue
,请使用' Unwind segue
'
在您的' A视图控制器'
中写入给定代码@IBAction func unwindToThisViewController(segue: UIStoryboardSegue) {
self.performSegue(withIdentifier: "YourSegueForC_VeiwController", sender: nil)
}
在B_viewcontroller中,按下按钮调用'展开segue'。然后解雇B_VC,然后C_VC出现在A_VC上。
注意: - 任何View_controler上只有一个View_controler。如果要添加另一个,请从该View控制器中删除或关闭另一个ViewController。
答案 2 :(得分:2)
感谢您的帮助,最后我使用委托和协议完成了这项工作。我们需要在SecondViewController中创建协议,我们必须在FirstViewController中使用该协议。
// Declare protocol and variable delegate in SecondViewController
protocol dismissVC {
func presentVC()
}
var delegateVC: dismissVC? = nil
// Call that protocol in FirstViewController
class FirstViewController: UIViewController, dismissVC {
func presentVC() {
let pickVc = UIStoryboard(name:"Main", bundle:
nil).instantiateViewController(withIdentifier: "third-VC")
as! ThirdViewController
pickVc.modalPresentationStyle = .custom
present(pickVc, animated: true, completion: nil)
}
}
// Action method in SecondViewController
@IBAction func proceedBtnTapped(_ sender: Any) {
self.dismiss(animated: true) {
self.delegateVC!.presentVC()
}
// and at last call that delegate when you try to use segue
let SecondVc = UIStoryboard(name:"Main", bundle: nil).instantiateViewController(withIdentifier: "second-VC") as! SecondViewController
Vc.modalPresentationStyle = .custom
Vc.delegateVC = self // add delegate here
self.present(Vc, animated: true, completion: nil)
})
// At last call delegate
yourVc.delegateVC = self
答案 3 :(得分:1)
使用委派模式EX:UIImagePickerViewControll
class A:UIViewController, BDelegate {
@IBAction func onOpenBController(_ sender:Any) {
let bVC = B()
bVC.delegate = self
present(bVC, animated: true, completion: nil)
}
func bControllerDidSelect(_ controller: B) {
controller.dismiss(animated: true, completion: nil) //Dismiss B controller
present(C(), animated: true, completion: nil) //Present C controller
}
}
class B:UIViewController {
weak var delegate:BDelegate?
@IBAction func onSomeClickEvent(_ sender:Any) {
delegate?.bControllerDidSelect(self)
}
}
protocol BDelegate: class {
func bControllerDidSelect(_ controller:B)
}
class C:UIViewController {
}