Search code examples
iosswiftuipageviewcontrolleruipagecontrol

UIPageViewControllerDataSource is not called


The UIPageViewControllerDataSource is not being called from ViewDidLoad, hence only the first page is displayed and swipe doesn't do anything.

I have followed this tutorial:

https://spin.atomicobject.com/2015/12/23/swift-uipageviewcontroller-tutorial/

The answers in questions similar to this do not work. I have viewed 5 similar questions but none of them work for me.


class SetupViewController: UIPageViewController {

      private(set) lazy var pages : [UIViewController] = {
         return [self.newPage(1), self.newPage(2), self.newPage(3), self.newPage(4)]
      }()

      private func newPage(_ page: Int) -> UIViewController {
          return UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "Page\(page)")
      }

      override func viewDidLoad() {
            super.viewDidLoad()  

            dataSource = self

            if let firstPage = pages.first {
                print(#function, "if let firstPage", firstPage, pages)  //viewDidLoad() if let firstPage page1name [page1, page2, page3, page4]
                setViewControllers([firstPage], direction: .forward, animated: true, completion: nil)

          }
     }
}

extension SetupViewController: UIPageViewControllerDataSource {

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {
        print(#function)           //It doesn't print
        guard let pageIndex = pages.firstIndex(of: viewController) else { return nil }
        let nextIndex = pageIndex + 1
        let pageCount = pages.count
        guard nextIndex != pageCount else { return nil }
        guard pageCount > nextIndex else { return nil }
        return pages[nextIndex]
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {
        print(#function)            //It doesn't print
        guard let pageIndex = pages.firstIndex(of: viewController) else { return nil }
        let previousIndex = pageIndex - 1
        guard previousIndex >= 0 else { return nil }
        guard pages.count > previousIndex else { return nil }
        return pages[previousIndex]
    }

}

Storyboard IDs are: Page1, Page2, Page3 & Page4

What am I doing wrong?


Solution

  • May be you have a configuration problem i have created a demo here

    https://github.com/ShKhan9/PagerShow


    let wind = (UIApplication.shared.delegate as! AppDelegate).window!
    wind.rootViewController = SetupViewController()