setViewControllers 不起作用
setViewControllers doesn't work
我正在尝试使用“下一步”按钮更改我的 UIPageViewController 的当前 ViewController。因此,我使用委托在 mainViewController 中调用 containterViewController 中的函数。但它不执行 setViewControllers 行。
在这里你可以看到我的代码:
这是我使用委托调用的方法:
func forwardPage() {
print("Start")
currentPage += 1
print(vcs[currentPage])
self.setViewControllers([vcs[currentPage]], direction: .forward, animated: true) { (true) in
print("Done")
}
}
这是我的代表:
protocol WalkthroughViewControllerDelegate {
func forwardPage()
func currentIndex() -> Int
}
这是连接到我的“下一步”按钮的功能:
@IBAction func nextButtonTapped(_ sender: Any) {
if let index = delegate?.currentIndex() {
print("Here... \(index)")
switch index {
case 0...1:
print("Forwarding...")
delegate?.forwardPage()
case 2:
dismiss(animated: true, completion: nil)
default: break
}
}
updateUI()
}
除 "Done" 之外的所有内容都被打印
非常感谢您的帮助
我为此苦苦挣扎了一段时间
非常感谢:)
编辑:可能发生这种情况是因为 UIPageViewController 在 containerView 中。但我不确定
第二次编辑:我已经为这个问题创建了一个 git-hub 存储库。这是 link:https://github.com/LennartPhil/App-Popup-Screen。希望您能理解,我不会向您展示我所有的文件。
好的 - 问题是您的代码在 viewDidLoad()
:
let storyboard = UIStoryboard(name: "ExtraViewControllers", bundle: nil)
let walkthroughPageVC = storyboard.instantiateViewController(withIdentifier: "WalkthroughPageVC") as! WalkthroughPageViewController
delegate = walkthroughPageVC
正在创建 WalkthroughPageViewController
的新实例,一旦 viewDidLoad()
退出,它就会超出范围。所以它不存在了。
您需要做的是在 prepare(for segue:...)
中获取对它的引用,并将其设置为您的委托:
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let vc = segue.destination as? WalkthroughPageViewController {
self.delegate = vc
}
}
我 fork 你的 GitHub 仓库并将文件添加到一个项目中,所以你可以看到它 运行: https://github.com/DonMag/App-Popup-Screen
我正在尝试使用“下一步”按钮更改我的 UIPageViewController 的当前 ViewController。因此,我使用委托在 mainViewController 中调用 containterViewController 中的函数。但它不执行 setViewControllers 行。
在这里你可以看到我的代码:
这是我使用委托调用的方法:
func forwardPage() {
print("Start")
currentPage += 1
print(vcs[currentPage])
self.setViewControllers([vcs[currentPage]], direction: .forward, animated: true) { (true) in
print("Done")
}
}
这是我的代表:
protocol WalkthroughViewControllerDelegate {
func forwardPage()
func currentIndex() -> Int
}
这是连接到我的“下一步”按钮的功能:
@IBAction func nextButtonTapped(_ sender: Any) {
if let index = delegate?.currentIndex() {
print("Here... \(index)")
switch index {
case 0...1:
print("Forwarding...")
delegate?.forwardPage()
case 2:
dismiss(animated: true, completion: nil)
default: break
}
}
updateUI()
}
除 "Done" 之外的所有内容都被打印
非常感谢您的帮助
我为此苦苦挣扎了一段时间
非常感谢:)
编辑:可能发生这种情况是因为 UIPageViewController 在 containerView 中。但我不确定
第二次编辑:我已经为这个问题创建了一个 git-hub 存储库。这是 link:https://github.com/LennartPhil/App-Popup-Screen。希望您能理解,我不会向您展示我所有的文件。
好的 - 问题是您的代码在 viewDidLoad()
:
let storyboard = UIStoryboard(name: "ExtraViewControllers", bundle: nil)
let walkthroughPageVC = storyboard.instantiateViewController(withIdentifier: "WalkthroughPageVC") as! WalkthroughPageViewController
delegate = walkthroughPageVC
正在创建 WalkthroughPageViewController
的新实例,一旦 viewDidLoad()
退出,它就会超出范围。所以它不存在了。
您需要做的是在 prepare(for segue:...)
中获取对它的引用,并将其设置为您的委托:
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let vc = segue.destination as? WalkthroughPageViewController {
self.delegate = vc
}
}
我 fork 你的 GitHub 仓库并将文件添加到一个项目中,所以你可以看到它 运行: https://github.com/DonMag/App-Popup-Screen