UIpageViewController和Timer

时间:2017-09-18 11:25:57

标签: swift timer uipageviewcontroller

我的屏幕顶部的一个My UICollectionViewCell中有一个UIPageViewController(height = frame.height / 3)它包含许多图像 它运作良好,但我需要它每3秒自动滚动到下一个图像我该怎么办?

import UIKit

class PageViewController: UIPageViewController , UIPageViewControllerDataSource{

    var scrollingTimer = Timer()
    let imageNames = ["Apple_Watch_Main" , "Pic2" , "Pic3"]

    override func viewDidLoad() {
        super.viewDidLoad()

        dataSource = self
        let frameViewController = FrameViewController()
        frameViewController.imageName = imageNames.first

        let viewControllers = [frameViewController]
        setViewControllers(viewControllers, direction: .forward, animated: true, completion: nil)

    }

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

        let currentImageName = (viewController as! FrameViewController).imageName
        let currentIndex = imageNames.index(of: currentImageName!)
        if currentIndex! > 0 {
            let frameViewController = FrameViewController()
            frameViewController.imageName = imageNames[currentIndex! - 1]
            return frameViewController
        }
        return nil
    }

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

        let currentImageName = (viewController as! FrameViewController).imageName
        let currentIndex = imageNames.index(of: currentImageName!)
        if currentIndex! < imageNames.count - 1 {
            let frameViewController = FrameViewController()
            frameViewController.imageName = imageNames[currentIndex! + 1]
            return frameViewController
        }
        return nil
    }
}

我在这里加入了我的手机

override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {

        switch indexPath.item {
        case 0 :
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: cellId, for: indexPath) as!ImageCell

            let pagecontroller = PageViewController(transitionStyle: .scroll, navigationOrientation: .horizontal, options: nil)
            self.addChildViewController(pagecontroller)

            cell.addSubview(pagecontroller.view)

            pagecontroller.view.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height/3)
            return cell
        case 1 :
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "filterandorganize", for: indexPath) as! FilterAndOrganize
            return cell
        case 2 :
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Offers", for: indexPath) as! Offers
            return cell
        case 3 :
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "OfferedProducts", for: indexPath) as! OfferedProducts
            cell.firstViewController = self
            return cell
        default:
            let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "Offers", for: indexPath) as! Offers
            return cell
        }
    }

案例0

我搜索了很多,我发现了一些这样的问题,但没有任何完整正确的答案

这里是我发现的答案,但它仍然有一个错误,那就是当用户自己滑动时,自动滚动不完美,可能会将一张图片跳到另一张

class PageViewController: UIPageViewController , UIPageViewControllerDataSource{
    var index = 0
    let imageNames = ["Apple_Watch_Main" , "Pic2" , "Pic3"]

    override func viewDidLoad() {
        super.viewDidLoad()
        dataSource = self

        let frameViewController = FrameViewController()
        frameViewController.imageName = imageNames[index]
        index += 1
        let viewControllers = [frameViewController]
        setViewControllers(viewControllers, direction: .forward, animated: true, completion: nil)

        Timer.scheduledTimer(timeInterval: 6.0 ,
                             target: self,
                             selector: #selector(myFunc(_:)),
                             userInfo: index,
                             repeats: true)
    }
    //FIXME: needs some fixes
    func myFunc(_ timer: Timer) {
        if index == imageNames.count  {
            index = 0
        }
        else {
            self.changePIC(index)
            index += 1
        }
    }
    func changePIC(_ i: Int) {
        let frameViewController = FrameViewController()
        frameViewController.imageName = imageNames[i]
        let viewControllers = [frameViewController]
        setViewControllers(viewControllers, direction: .forward, animated: true, completion: nil)
    }

1 个答案:

答案 0 :(得分:0)

首先将timeIntervalrepeats选项的计时器设为真。

示例:

Timer.scheduledTimer(timeInterval: 3, target: self, selector: #selector(scrollToNextItem), userInfo: nil, repeats: true

现在你有Timer每隔3秒会触发scrollToNextItem方法。

现在阅读setViewControllers(_:direction:animated:completion:)以了解如何设置要显示的视图控制器。

实现具有所需逻辑的scrollToNextItem方法。