ios - swift: UIPageViewController 大小

标签 ios swift

我有 UIPageViewController 脊椎中间位置。现在我的 2 页占据了整个屏幕。但是我想更改我可以在 Controller 的其他部分创建按钮的翻页的大小。怎么做?

代码:

import UIKit

class PageViewController: UIViewController {

    @IBOutlet weak var PageControl: UIPageControl!

    var pageViewController: UIPageViewController?
    var images = ["book1page1.png","book1","book1","book1page2.png","book1page1.png","book1page2.png"]
    var pendingIndex: Int?

    override func viewDidLoad() {
        super.viewDidLoad()

        createPageViewController()
        setupPageControll()

    }

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

    func createPageViewController() {
        // Instantiate the PageViewController
        let pageController = self.storyboard?.instantiateViewController(withIdentifier: "PageViewController") as! UIPageViewController
        pageController.dataSource = self
        pageController.delegate = self

        if images.count > 0{
            let firstController = getContentViewController(withIndex: 0)!
            let contentControllers = [firstController]

            pageController.setViewControllers(contentControllers, direction: UIPageViewControllerNavigationDirection.forward, animated: true, completion: nil)

        }

        pageViewController = pageController

        self.addChildViewController(pageViewController!)

        //self.view.addSubview(pageViewController!.view)
        self.view.insertSubview(pageViewController!.view, at: 0)
        pageViewController!.didMove(toParentViewController: self)

    }

    //Setup Pagination Icons and count
    func presentationCount(for pageViewController: UIPageViewController) -> Int {
        return images.count
    }

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

    func setupPageControll(){
        let apperance = UIPageControl.appearance()
        apperance.pageIndicatorTintColor = UIColor.gray
        apperance.currentPageIndicatorTintColor = UIColor.white
        apperance.backgroundColor = UIColor.clear
    }

    func currentControllerIndex() -> Int{
        let pageItemController = self.currentConroller()

        if let controller = pageItemController as? ContentViewController {
            return controller.itemIndex
        }
        return -1
    }

    ///////////////////////////////////////////////

    func currentConroller() -> UIViewController?{
        if (self.pageViewController?.viewControllers?.count)! > 0{
            return self.pageViewController?.viewControllers![0]
        }

        return nil
    }

    func getContentViewController(withIndex index: Int) -> ContentViewController? {
        if index < images.count{
            let contentVC = self.storyboard?.instantiateViewController(withIdentifier: "ContentViewController") as! ContentViewController
            contentVC.itemIndex = index
            contentVC.imageName = images[index]

            return contentVC
        }

        return nil
    }

}

extension PageViewController: UIPageViewControllerDataSource, UIPageViewControllerDelegate {

    func pageViewController(_ pageViewController: UIPageViewController, willTransitionTo pendingViewControllers: [UIViewController]) {
        pendingIndex = (pendingViewControllers.first as! ContentViewController).itemIndex
    }

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

        }
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {
        let contentVC = viewController as! ContentViewController
        if contentVC.itemIndex > 0 {
            return getContentViewController(withIndex: contentVC.itemIndex - 1)
        }

        return nil
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {
        let contentVC = viewController as! ContentViewController
        if contentVC.itemIndex + 1 < images.count {
            return getContentViewController(withIndex: contentVC.itemIndex + 1)
        }

        return nil
    }
}

最佳答案

在这里你实例化了 UIPageViewController (id:"PageViewController") 并在 UIViewController 中添加了 subview ,所以如果你想创建 UIButton 你可以创建,但如果它想在这个 UIPageViewController 前面可见,你可以把 self.view.insertSubview(pageViewController!.view, at: 0) 说成你的 UIViewController 将此 subview 放在索引 0 (意味着在每个 subview 后面)

下面我给出了代码:在 index 0 添加 subview 并使用 pageController.view.frame 调整 PageViewController 的大小= CGRect(x: 50, y: 50, width: self.view.frame.width - (5.0 * 20.0), height: self.view.frame.height - (2.0 * 50.0)) 还添加了两个UIPageController

底部的按钮调用“Next”和“Previous”

检查打击代码:

func createPageViewController() {
        let pageController = self.storyboard?.instantiateViewController(withIdentifier: "PageViewController") as! UIPageViewController

        pageController.isDoubleSided = true
        pageController.dataSource = self
        pageController.delegate = self

        if images.count > 1{
            let firstController = getContentViewController(withIndex: 0)!
            let secondController = getContentViewController(withIndex: 1)!
            let contentControllers = [firstController,secondController]
            pageController.setViewControllers(contentControllers, direction: UIPageViewControllerNavigationDirection.forward, animated: true, completion: nil)

        }

        pageViewController = pageController
        self.addChildViewController(pageViewController!)
        self.view.insertSubview(pageViewController!.view, at: 0)

        pageController.view.frame = CGRect(x: 50, y: 50, width: self.view.frame.width - (5.0 * 20.0), height: self.view.frame.height - (2.0 * 50.0))
        pageController.view.layer.borderColor = UIColor.lightGray.cgColor
        pageController.view.layer.borderWidth = 1.0
        pageViewController!.didMove(toParentViewController: self)

        //Next Page Button
        let nextButton = UIButton()
        nextButton.frame = CGRect(x: pageController.view.frame.maxX - 75, y: pageController.view.frame.maxY + 5, width: 75, height: 50)
        nextButton.backgroundColor = UIColor.blue
        nextButton.setTitle("Next", for: .normal)
        nextButton.addTarget(self, action: #selector(buttonActionNext), for: .touchUpInside)
        self.view.addSubview(nextButton)

        //Previous Page Button
        let previousButton = UIButton()
        previousButton.frame = CGRect(x: pageController.view.frame.minX, y: pageController.view.frame.maxY + 5, width: 75, height: 50)
        previousButton.backgroundColor = UIColor.blue
        previousButton.setTitle("Previous", for: .normal)
        previousButton.addTarget(self, action: #selector(buttonActionPrevious), for: .touchUpInside)
        self.view.addSubview(previousButton)
    }

    @objc func buttonActionNext(sender: UIButton!) {
        print("Next page")
    }

    @objc func buttonActionPrevious(sender: UIButton!) {
        print("Previous Page")
    }

关于ios - swift: UIPageViewController 大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51466841/

相关文章:

ios - 使用 Apple Universal Linking 强制打开应用程序

ios - 当应用程序处于焦点状态时,无法将 OneSignal 通知显示为横幅 :iOS

当应用程序在后台时,iOS 12.4 AVAudioRecorder.record 返回 false

ios - 如何在 Facebook Analytics SDK 2020 中记录自定义事件以实现 swift 文档已弃用

ios - 在已越狱的 iPad 上启动应用程序。 (iOS)

ios - 如何从不同层次的JSON对象中拉取数据

ios - Pod 安装不下载框架

c - 在 C 中使用 Swift 中的 Char 数组

ios - NSIndexPath 以 1 开头

ios - 编辑tableView时自定义单元格imageView移动到左侧