【问题标题】:PageViewController shows part of other viewcontrollerPageViewController 显示其他视图控制器的一部分
【发布时间】:2019-02-03 10:55:32
【问题描述】:

我有一个UIPageViewController 和 2 个UIViewControllers,它们都有一个UIImageView 作为背景,内容模式设置为scaleAspectFill。出于某种原因,这会导致第二个UIViewController 在第一个滚动到第二个UIViewController 时部分可见,而不是滚动回第一个UIViewController

复制项目可以在这里找到:https://github.com/Jasperav/PageViewControllerGlitch。代码也在照片下方。

照片(空格是第一个UIViewController,绿色部分是第二个UIViewController):

代码(我不使用故事板,对于具有正确窗口的复制路径,请使用 github 链接):

import UIKit

class PageViewController: UIPageViewController, UIPageViewControllerDataSource, UIPageViewControllerDelegate {

    private let pageViewControllers: [UIViewController] = [VC1(), VC2()]

    init() {
        super.init(transitionStyle: .scroll, navigationOrientation: .horizontal, options: nil)

        dataSource = self
        delegate = self

        setViewControllers([pageViewControllers.first!], direction: .forward, animated: false, completion: nil)
    }

    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    func presentationCount(for pageViewController: UIPageViewController) -> Int {
        return pageViewControllers.count
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {
        guard let index = pageViewControllers.index(of: viewController), index > 0 else { return nil }

        let previousIndex = index - 1

        return pageViewControllers[previousIndex]
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {
        guard let index = pageViewControllers.index(of: viewController), (index + 1) != pageViewControllers.count else { return nil }

        return pageViewControllers[index + 1]
    }
}

class VC: UIViewController {
    init(background: UIImage) {
        super.init(nibName: nil, bundle: nil)

        let backgroundImageView = UIImageView(image: background)

        backgroundImageView.contentMode = .scaleAspectFill

        view.addSubview(backgroundImageView)

        backgroundImageView.translatesAutoresizingMaskIntoConstraints = false

        backgroundImageView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
        backgroundImageView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true
        backgroundImageView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
        backgroundImageView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

class VC1: VC {
    init() {
        super.init(background: #imageLiteral(resourceName: "bg1"))
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

class VC2: VC {
    init() {
        super.init(background: #imageLiteral(resourceName: "bg2"))
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }
}

【问题讨论】:

    标签: swift uipageviewcontroller


    【解决方案1】:

    当你使用AspectFill作为内容模式时,如果图片大于UImageView的尺寸,图片就会溢出。要解决此问题,您可以剪切其子视图:

    backgroundImageView.contentMode = .scaleAspectFill
    backgroundImageView.clipsToBounds = true
    

    另一种解决方案是尝试另一种内容模式,例如.scaleToFill。 希望这会有所帮助,我刚刚在您的演示项目中尝试了这个解决方案并且都有效。

    【讨论】:

    • 我应该知道这一点 :P 谢谢! :)
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-02-12
    • 2014-09-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多