我目前有一个button
,目前在主屏幕上显示UIPageViewController
作为叠加层。用户可以随时点击它,它仍然会显示嵌入ViewControllers
的UIPageViewController
。但是,此时,当用户单击按钮以显示叠加并关闭它并再次打开时。保存最后一页的最后一页索引/状态并再次显示。我想做的是始终在ViewController
显示第一个UIPageviewController
。我尝试了不同的方法,但没有运气。
以下是显示当前机制如何工作的屏幕截图
HomeHelpViewController包含UIPageViewController
class HomeHelpViewController: UIPageViewController, UIPageViewControllerDataSource {
var helpPages: [UIViewController] = []
var currentIndex: Int = 0
override func viewDidLoad() {
super.viewDidLoad()
let helpStoryboard = UIStoryboard(name: "HomeHelp", bundle: nil)
for scanIdentifier in ["homeHelpVC1","homeHelpVC2","homeHelpVC3","homeHelpVC4"] {
let scanVC = helpStoryboard.instantiateViewController(withIdentifier: scanIdentifier)
self.helpPages.append(scanVC)
}
self.dataSource = self
self.setViewControllers([self.helpPages.first!], direction: .forward, animated: true)
}
//MARK:- UIPageViewControllerDataSource
func pageViewController(_ pPageViewController: UIPageViewController, viewControllerBefore pViewController: UIViewController) -> UIViewController? {
self.currentIndex = self.helpPages.firstIndex(of: pViewController)!
if self.currentIndex > 0 {
return self.helpPages[self.currentIndex - 1]
}
return nil
}
func pageViewController(_ pPageViewController: UIPageViewController, viewControllerAfter pViewController: UIViewController) -> UIViewController? {
self.currentIndex = self.helpPages.firstIndex(of: pViewController)!
if self.currentIndex < (self.helpPages.count - 1) {
return self.helpPages[self.currentIndex + 1]
}
return nil
}
func presentationCount(for pPageViewController: UIPageViewController) -> Int {
return self.helpPages.count
}
func presentationIndex(for pPageViewController: UIPageViewController) -> Int {
return self.currentIndex
}
}
具有按钮的HomePageViewController将UIPageViewController显示为叠加层
class HomePageViewController: UIViewController {
@IBOutlet weak var helpOverlay: BaseOverlayView!
@IBAction func helpButton(_ pSender: Any) {
self.helpButton.setImage(AppDelegate.helpButtonImage(tutorial: true), for: .normal)
self.helpOverlay.showOnView(self.view)
}
@IBAction func closeHelp(_ pSender: UIButton) {
self.helpOverlay.removeFromView()
self.helpButton.setImage(AppDelegate.helpButtonImage(tutorial: false), for: .normal)
}
}
声明一个变量来访问HomePageViewController中的HomeHelpViewController
class HomePageViewController: UIViewController {
weak var homePageController : HomeHelpViewController?
@IBOutlet weak var helpOverlay: BaseOverlayView!
@IBAction func helpButton(_ pSender: Any) {
if let homePageController = homePageController {
homePageController.setViewControllers([homePageController.helpPages.first!], direction: .forward, animated: true)
}
self.helpButton.setImage(AppDelegate.helpButtonImage(tutorial: true), for: .normal)
self.helpOverlay.showOnView(self.view)
}
@IBAction func closeHelp(_ pSender: UIButton) {
self.helpOverlay.removeFromView()
self.helpButton.setImage(AppDelegate.helpButtonImage(tutorial: false), for: .normal)
}
}
在这个循环中分配你的HomeHelpViewController
for scanIdentifier in ["homeHelpVC1","homeHelpVC2","homeHelpVC3","homeHelpVC4"] {
let scanVC = helpStoryboard.instantiateViewController(withIdentifier: scanIdentifier) as? HomePageViewController
scanVc?.homePageController = self
self.helpPages.append(scanVC)
}
这可能是因为UIPageViewController没有被正确解雇。
func dismiss(animated flag: Bool, completion: (() -> Void)? = nil)
你可以参考这里的文档:https://developer.apple.com/documentation/uikit/uiviewcontroller/1621505-dismiss
这有效地释放了UIPageViewController,这样一旦按下按钮,它将在第一页再次重新初始化。