【问题标题】:Image Slider using UIScrollView and Auto Layout使用 UIScrollView 和自动布局的图像滑块
【发布时间】:2018-12-09 07:52:58
【问题描述】:

我正在尝试使用 scrollView 和 pageControl 实现图像滑块,并使用 .addSubView 方法以编程方式将图像附加到 scrollView。代码如下:

@IBOutlet weak var sliderScrollView: UIScrollView!
@IBOutlet weak var sliderPageControl: UIPageControl!
var images: [String] = ["0", "1", "2"]

func updateSlider() {
        sliderPageControl.numberOfPages = images.count

        for index in 0..<images.count {
            frame.origin.x = sliderScrollView.frame.size.width * CGFloat(index)
            print(sliderScrollView.frame.size.width)
            frame.size = sliderScrollView.frame.size

            let image = UIImageView(frame: frame)
            image.contentMode = .scaleAspectFill
            image.image = UIImage(named: cafeObject.images[index])
            sliderScrollView.addSubview(image)
        }
        sliderScrollView.contentSize = CGSize(width: sliderScrollView.frame.size.width * CGFloat(cafeObject.images.count), height: sliderScrollView.frame.size.height)
        sliderScrollView.delegate = self
        sliderPageControl.currentPage = 0
}

override func scrollViewDidScroll(_ scrollView: UIScrollView) {
    let pageNumber = scrollView.contentOffset.x / scrollView.frame.size.width

    switch scrollView {
    case sliderScrollView:
        sliderPageControl.currentPage = Int(pageNumber)
    default:
        break
    }
}

当我在 iPhone 8 布局上设计故事板时,上面的代码在 iPhone 8 上运行良好。但是,一旦我在 iPhone 8 Plus 中运行代码,照片就无法适应新的滚动视图大小。我已经为滚动视图添加了约束,使得顶部、前导、尾随和底部等于超级视图的顶部、前导、尾随和底部。调试时,我发现 UIImageView 的 frame 仍然使用 iPhone 8 上的旧宽度。

是否有任何解决方法,无论是通过编程方式还是使用界面构建器?谢谢!

【问题讨论】:

    标签: swift uiscrollview uiimageview ios-autolayout uipagecontrol


    【解决方案1】:

    好的,我设法通过将 updateSlider() 函数放在 viewDidLayoutSubviews() 下来解决这个问题!

    【讨论】:

      猜你喜欢
      • 2011-09-23
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-11-30
      • 1970-01-01
      • 2016-10-25
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多