ios - 在不同的滑动 View 之间传递 UIPageViewController 中的数据

标签 ios swift uipageviewcontroller

我正在开发一个包含 3 个 View 的项目,可通过滑动访问。

以下代码实现了我用来处理滑动 Action 的 PageViewController:

import UIKit

class PageViewController: UIPageViewController, UIPageViewControllerDelegate, UIPageViewControllerDataSource {

    lazy var orderedViewControllers : [UIViewController] = {
        return [self.newVC(viewController : "ClimaVC"),
            self.newVC(viewController : "WeatherVC"),
            self.newVC(viewController : "ClosetVC")]
    }()

    var myViewControllers = [UIViewController]()

    var currentIndex : Int = 0


    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.

        self.dataSource = self

        setViewControllers([orderedViewControllers[1]],
                           direction: .forward, animated: true, completion: nil)

        self.delegate = self
    }


    func newVC(viewController : String) -> UIViewController {

        return UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: viewController)
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {

        guard let viewControllerIndex = orderedViewControllers.index(of: viewController) else {
            return nil
        }

        let previousIndex = viewControllerIndex - 1;

        guard previousIndex >= 0 else {
            // return orderedViewControllers.last
            //Return nil to avoid swiping forever.
            return nil
        }

        guard orderedViewControllers.count > previousIndex else {
            return nil
        }

        currentIndex = previousIndex

        return orderedViewControllers[previousIndex]
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {

        guard let viewControllerIndex = orderedViewControllers.index(of: viewController) else {
            return nil
        }

        let nextIndex = viewControllerIndex + 1;

        guard orderedViewControllers.count != nextIndex else {
            //return orderedViewControllers.first
            //Return nil to avoid swiping forever.
            return nil
        }

        guard orderedViewControllers.count > nextIndex else {
            return nil
        }

        return orderedViewControllers[nextIndex]
    }
}

主视图 Controller 是 WeatherVC。在此 View 中,时间数据被检索并存储在名为 timeOfDay 的整数变量中。

根据 timeOfDay 的值,显示的背景会有所不同。虽然我能够在 WeatherVC 中使用这个变量,但我需要将这个变量 timeOfDay 传递给另外两个 View Controller ClimaVC ClosetVC

我尝试设置委托(delegate)协议(protocol)但失败了,使用 UIPageViewControllerDelegate 提供的不同功能进行了探索,但它并没有让我到任何地方。

我真的很感激在这方面的一些帮助,

非常感谢!

最佳答案

并不复杂,只需在 pageviewcontroller 数据源分配值即可。

        import UIKit

                    class ClimaViewController: UIViewController{
            var timeOfDayClima: Int = 0

            override func viewDidAppear(_ animated: Bool) {
                super.viewDidAppear(animated)
                print (timeOfDayClima)
            }
        }

        class WeatherViewController: UIViewController{
            var timeOfDayClima: Int = 0


            override func viewDidAppear(_ animated: Bool) {
                super.viewDidAppear(animated)
               timeOfDayClima +=  1
            }
        }

        class ClosetViewController: UIViewController{
            var timeOfDayClima: Int = 0

            override func viewDidAppear(_ animated: Bool) {
                super.viewDidAppear(animated)
                print (timeOfDayClima)
            }
        }
        class PageViewController: UIPageViewController, UIPageViewControllerDelegate, UIPageViewControllerDataSource {

            lazy var orderedViewControllers : [UIViewController] = {
                return [self.newVC(viewController : "ClimaVC"),
                        self.newVC(viewController : "WeatherVC"),
                        self.newVC(viewController : "ClosetVC")]
            }()

            var myViewControllers = [UIViewController]()

            var currentIndex : Int = 0


            override func viewDidLoad() {
                super.viewDidLoad()

                // Do any additional setup after loading the view.

                self.dataSource = self

                setViewControllers([orderedViewControllers[1]],
                                   direction: .forward, animated: true, completion: nil)

                self.delegate = self


            }


            func newVC(viewController : String) -> UIViewController {

                return UIStoryboard(name: "Second", bundle: nil).instantiateViewController(withIdentifier: viewController)


            }

            func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {

                //Guard = some kind of if statement.
                guard let viewControllerIndex = orderedViewControllers.index(of: viewController) else {
                    return nil
                }



                let previousIndex = viewControllerIndex - 1;



                guard previousIndex >= 0 else {
                    // return orderedViewControllers.last
                    //Return nil to avoid swiping forever.
                    return nil
                }

                guard orderedViewControllers.count > previousIndex else {
                    return nil
                }

                currentIndex = previousIndex


                if(currentIndex == 0) {
                    (orderedViewControllers.first as! ClimaViewController).timeOfDayClima = (orderedViewControllers[1] as! WeatherViewController).timeOfDayClima
                }

                return orderedViewControllers[previousIndex]

            }

            func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {

                //Guard = some kind of if statement.
                guard let viewControllerIndex = orderedViewControllers.index(of: viewController)
                    else {
                        return nil
                }

                let nextIndex = viewControllerIndex + 1;

                guard orderedViewControllers.count != nextIndex else {
                    //return orderedViewControllers.first
                    //Return nil to avoid swiping forever.
                    return nil
                }

                guard orderedViewControllers.count > nextIndex else {
                    return nil
                }

                currentIndex = nextIndex
                if(currentIndex == orderedViewControllers.count - 1) {
                    (orderedViewControllers.last as! ClosetViewController).timeOfDayClima = (orderedViewControllers[1] as! WeatherViewController).timeOfDayClima
                }


                if(nextIndex == 0) {
                    let secondVC = self.storyboard?.instantiateViewController(withIdentifier: "ClimaVC") as! ClimaViewController
                    secondVC.timeOfDayClima = 1
                }

                return orderedViewControllers[nextIndex]

            }

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


        }

关于ios - 在不同的滑动 View 之间传递 UIPageViewController 中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53056058/

相关文章:

ios - 我可以在 iOS 中连接摩托罗拉 rs507 作为蓝牙外设吗?

ios - 第一个 UIButton 触发同一 View 的另一个 UIbutton 事件

swift - Realm :将 Realm 与应用程序捆绑在一起

ios - 在 UIPageViewController 中禁用弹跳效果

ios - 为什么每次更改单元格对应的对象的值时都会调用我的 `configureCell:` 方法? (但我不保存它。)

ios - 通过兄弟 subview 传播触摸事件?

ios - 如何使用 Objective-C iOS 读取 excel 文件?

ios - SpriteKit 的坐标系在 Xcode 8 中是否发生了变化?

ios - 我应该在 presentationIndexForPageViewController : for my UIPageViewControllerDataSource? 中返回什么

swift - MXSegmentedPager初始页面