如何在 Swift 中正确推进 PageViewController [英] How to properly advance a PageViewController in Swift

查看:113
本文介绍了如何在 Swift 中正确推进 PageViewController的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试用 Swift 开发一个教程.我有一个使用指标的页面视图控制器(http://www.appcoda.com/uipageviewcontroller-storyboard-tutorial/) 但我想添加一个按钮以通过单击它而不是滑动屏幕来转到下一页(TODO NextPage).

I am trying to develop a tutorial in Swift. I have a page view controller working with the indicators (http://www.appcoda.com/uipageviewcontroller-storyboard-tutorial/) but I want to add a button to go to the next page by clicking it instead of swiping the screen (TODO NextPage).

我试过了:

let startVC = self.viewControllerAtIndex(self.index + 1) as TutorialContentViewController
let viewControllers = NSArray(object: startVC)
self.pageViewController.setViewControllers(viewControllers as! [UIViewController],
    direction: UIPageViewControllerNavigationDirection.Forward,
    animated: true,
    completion: nil)

问题是圆形页面指示器没有更新,点击下一步后,所有页面都是第二页.

The problem is that circle page indicator is not being updated and after clicking next, all the pages are the second page.

源代码

import UIKit

class TutorialViewController: UIViewController, UIPageViewControllerDataSource {

var pageViewController: UIPageViewController!
var pageTexts: NSArray!
var pageImages: NSArray!
var index: Int = 0

@IBOutlet var button: UIButton!

override func viewDidLoad() {
    super.viewDidLoad()

    self.pageTexts = NSArray(objects: "Explore", "Today Widget")
    self.pageImages = NSArray(objects: "background1.jpg", "background2.jpg")

    self.pageViewController = self.storyboard?.instantiateViewControllerWithIdentifier("PageViewController") as! UIPageViewController

    self.pageViewController.dataSource = self

    let startVC = self.viewControllerAtIndex(index) as TutorialContentViewController
    let viewControllers = NSArray(object: startVC)

    self.pageViewController.setViewControllers(viewControllers as! [UIViewController], direction: .Forward, animated: true, completion: nil)
    self.pageViewController.view.frame = CGRectMake(0, 0, self.view.frame.width, self.view.frame.size.height - 60)

    self.addChildViewController(self.pageViewController)
    self.view.addSubview(self.pageViewController.view)
    self.pageViewController.didMoveToParentViewController(self)
}

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

func viewControllerAtIndex(index: Int) -> TutorialContentViewController {
    if (index >= self.pageTexts.count) {
        return TutorialContentViewController()
    }

    let vc: TutorialContentViewController = self.storyboard?.instantiateViewControllerWithIdentifier("TutorialContentViewController") as! TutorialContentViewController

    vc.image = self.pageImages[index] as! String
    vc.text = self.pageTexts[index] as! String
    vc.pageIndex = index
    self.index = index

    self.button.setTitle(self.index == self.pageTexts.count - 1 ? "Finish" : "Next", forState: .Normal)

    return vc
}


// MARK: - Page View Controller Data Source
func pageViewController(pageViewController: UIPageViewController, viewControllerBeforeViewController viewController: UIViewController) -> UIViewController? {
    let vc = viewController as! TutorialContentViewController
    let index = vc.pageIndex as Int

    return self.viewControllerAtIndex(index)
}

func pageViewController(pageViewController: UIPageViewController, viewControllerAfterViewController viewController: UIViewController) -> UIViewController? {
    let vc = viewController as! TutorialContentViewController
    var index = vc.pageIndex as Int

    if (index == NSNotFound) {
        return nil
    }

    index++
    if (index == self.pageTexts.count) {
        self.button.setTitle("Finish", forState: .Normal)
        return nil
    } else {
        self.button.setTitle("Next", forState: .Normal)
    }
    return self.viewControllerAtIndex(index)
}

func presentationCountForPageViewController(pageViewController: UIPageViewController) -> Int {
    return self.pageTexts.count
}

func presentationIndexForPageViewController(pageViewController: UIPageViewController) -> Int {
    return 0
}

@IBAction func onButtonClick(sender: AnyObject) {
    if (self.index == self.pageTexts.count - 1) {
        let vc : UIViewController = self.storyboard!.instantiateViewControllerWithIdentifier("splashViewController")
        vc.modalTransitionStyle = UIModalTransitionStyle.CrossDissolve
        self.presentViewController(vc, animated: true, completion:nil)
    } else {
        //TODO NextPage
    }
}

}

推荐答案

这里 let viewControllers = NSArray(object: startVC) 你只需要一个 UIViewController 的数组UIViewController(你的第二个 UIViewController).

Here let viewControllers = NSArray(object: startVC) you make an array of UIViewController with only one UIViewController (your second UIViewController).

改为使用代码中的 viewControllerAtIndex 函数.

Instead use the viewControllerAtIndex function from your code.

所以现在你的 UIButton 动作应该是这样的:

So now your UIButton action should look like this:

func nextPage(sender: AnyObject) {
    self.pageViewController.setViewControllers([self.viewControllerAtIndex(self.index + 1)!], direction: .Forward, animated: true, completion: nil)
}

这篇关于如何在 Swift 中正确推进 PageViewController的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆