在 PageViewController 导航不起作用

In PageViewController navigation not working(在 PageViewController 导航不起作用)
本文介绍了在 PageViewController 导航不起作用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有 3 种类型的 VC,第一种 VC,第 2 种 VC 是 PageViewController 有 3 个页面(我在这里添加了 PageController 到普通 ViewController),第三个是FinalViewController.

I have 3 types of VC's , 1st Vc, 2nd VC is PageViewController with 3 pages(I added PageController to normal ViewController here), third one is FinalViewController.

第一个 VC 有按钮,当我单击它时,它将移动到第二个 VC,即 PageViewController(它有 3 个页面 [3 个 ViewConrollers] 工作正常).

1st VC has button when i click it will move to 2nd VC that is PageViewController(It has 3 pages[3 ViewConrollers] working fine).

在加载第一个 VC 后的 PageViewController 中,当我点击我想完全导航 FinalViewController 时,它具有带有手势的 view.

In PageViewController after loading first VC, it has view with gestures when i tap that i want to navigate FinalViewController completely.

这里导航不起作用.

我的第一个 VC 代码

My 1st VC code

     override func viewWillAppear(_ animated: Bool) {
        self.navigationController?.navigationBar.isHidden = true
    }

    override func viewWillDisappear(_ animated: Bool) {
        self.navigationController?.navigationBar.isHidden = false
    }

    @IBAction func btn(_ sender: Any) {

        let storyboard = self.storyboard?.instantiateViewController(withIdentifier: "NVC")
        self.navigationController?.pushViewController(storyboard!, animated: true)
    }

My PageViewController code

    import UIKit

    class NewViewController: UIViewController, UIPageViewControllerDataSource, UIPageViewControllerDelegate {

    @IBOutlet weak var pagerController: UIPageControl!
    @IBOutlet weak var pageControllerView: UIView!

    // The pages it contains
    var pages =  [UIViewController]()

    // The UIPageViewController
    var pageContainer: UIPageViewController!
    // Track the current index
    var currentIndex: Int?
    private var pendingIndex: Int?

    override func viewDidLoad() {
        super.viewDidLoad()

        // Setup the pages
        let storyboard = UIStoryboard(name: "Main", bundle: nil)
        let page1 = storyboard.instantiateViewController(withIdentifier: "ViewController") as! ViewController
        let page2: UIViewController! = storyboard.instantiateViewController(withIdentifier: "SecondViewController")
        let page3: UIViewController! = storyboard.instantiateViewController(withIdentifier: "ThirdViewController")
        pages.append(page1)
        pages.append(page2)
        pages.append(page3)

        page1.variable = "This is strig..."

        // Create the page container
        pageContainer = UIPageViewController(transitionStyle: .scroll, navigationOrientation: .horizontal, options: nil)
        pageContainer.delegate = self
        pageContainer.dataSource = self
        pageContainer.setViewControllers([page1], direction: UIPageViewController.NavigationDirection.forward, animated: false, completion: nil)

        // Add it to the view
        pageControllerView.addSubview(pageContainer.view)

        // Configure our custom pageControl
        view.bringSubviewToFront(pagerController)
        pagerController.numberOfPages = pages.count
        pagerController.currentPage = 0


    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


    // MARK: - UIPageViewController delegates

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {
        let currentIndex = pages.firstIndex(of:viewController)!
        if currentIndex == 0 {
            return nil
        }
        let previousIndex = abs((currentIndex - 1) % pages.count)
        return pages[previousIndex]
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {
        let currentIndex = pages.firstIndex(of:viewController)!
        if currentIndex == pages.count-1 {
            return nil
        }
        let nextIndex = abs((currentIndex + 1) % pages.count)
        return pages[nextIndex]
    }


    func pageViewController(_ pageViewController: UIPageViewController, willTransitionTo pendingViewControllers: [UIViewController]) {
        pendingIndex = pages.firstIndex(of:pendingViewControllers.first!)
    }

    func pageViewController(_ pageViewController: UIPageViewController, didFinishAnimating finished: Bool, previousViewControllers: [UIViewController], transitionCompleted completed: Bool) {
        if completed {
            currentIndex = pendingIndex
            if let index = currentIndex {
                pagerController.currentPage = index
            }
        }
    }

    }

My `ViewConroller` code means which is loading in `PageViewController` 

    import UIKit

    class ViewController: UIViewController {

    var variable = String()
    @IBOutlet weak var subView: UIView!

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.

        //Add gesture to incoming call view
        let incomingCallsViewTap = UITapGestureRecognizer(target: self, action: #selector(incomingCallsViewTapFunction(_:)))
        self.subView!.addGestureRecognizer(incomingCallsViewTap)


    }

    // Tap gestrure selector fuction
    @objc func incomingCallsViewTapFunction(_ sender: UITapGestureRecognizer) {
        let clvc = self.storyboard?.instantiateViewController(withIdentifier: "FVC") as! FinalViewController
        self.navigationController?.pushViewController(clvc, animated: false)
    }



    @IBAction func btn(_ sender: Any) {

        print("ViewController one")

        print(variable)
    }

    }

推荐答案

navigationViewController 为 nil,所以我必须执行以下操作:

navigationViewController is nil so I had to do the following:

(UIApplication.shared.keyWindow?.rootViewController as? UINavigationController)?.pushViewController(clvc, animated: true)


// Tap gestrure selector fuction
@objc func incomingCallsViewTapFunction(_ sender: UITapGestureRecognizer) {
    let clvc = self.storyboard?.instantiateViewController(withIdentifier: "FVC") as! FinalViewController
//        self.navigationController?.pushViewController(clvc, animated: false)

    (UIApplication.shared.keyWindow?.rootViewController as? UINavigationController)?.pushViewController(clvc, animated: true)

}

这篇关于在 PageViewController 导航不起作用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Why local notification is not firing for UNCalendarNotificationTrigger(为什么没有为UNCalendarNotificationTrigger触发本地通知)
iOS VoiceOver functionality changes with Bundle Identifier(IOS画外音功能随捆绑包标识符而变化)
tabbar middle tab out of tabbar corner(选项卡栏中间的选项卡角外)
Pushing UIViewController above UITabBar(将UIView控制器推送到UITabBar上方)
Dropbox Files.download does not start when number of files in folder is gt; 1000(当文件夹中的文件数为1000时,Dropbox Files.Download不会启动)
How can I sync two flatList scroll position in react native(如何在本机Reaction中同步两个平面列表滚动位置)