swift - Swift:ScrollView 仅显示添加的最后一个视图
问题描述
我正在尝试使用 scrollView 重新创建 UIPageController 以获得更多关于手势识别的灵活性。一切正常,例如分页,但目前,我的 scrollView 仅将 page3 显示为第一页。我错过了什么?任何人都可以帮助我吗?
let scrollView = UIScrollView()
let pageControl = UIPageControl()
var pages: [UIView] {
get {
let page1 = UIView()
page1.backgroundColor = .systemBlue
let page2 = UIView()
page1.backgroundColor = .systemPurple
let page3 = UIView()
page1.backgroundColor = .systemOrange
return [page1, page2, page3]
}
}
override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = .white
view.addSubview(scrollView)
scrollView.backgroundColor = .systemRed
scrollView.anchor(top: view.safeAreaLayoutGuide.topAnchor, leading: view.leadingAnchor, bottom: view.bottomAnchor, trailing: view.trailingAnchor, padding: .init(top: 0, left: 0, bottom: 0, right: 0))
view.addSubview(pageControl)
//BringSubViewToFront makes sures its always up front
view.bringSubviewToFront(pageControl)
pageControl.anchor(top: nil, leading: view.leadingAnchor, bottom: view.safeAreaLayoutGuide.bottomAnchor, trailing: view.trailingAnchor)
setupScrollView(pages: pages)
pageControl.numberOfPages = pages.count
pageControl.currentPage = 0
}
fileprivate func setupScrollView(pages: [UIView]) {
scrollView.delegate = self
scrollView.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height)
scrollView.contentSize = CGSize(width: view.frame.width * CGFloat(pages.count), height: view.frame.height)
scrollView.isPagingEnabled = true
//Disables vertical scrolling and horizontal bounces
scrollView.contentSize.height = 1
scrollView.bounces = false
for i in 0..<pages.count {
pages[i].frame = CGRect(x: view.frame.width * CGFloat(i), y: 0, width: view.frame.width, height: view.frame.height)
scrollView.addSubview(pages[i])
}
}
}
extension ChartViewController: UIScrollViewDelegate {
func scrollViewDidScroll(_ scrollView: UIScrollView) {
let pageIndex = round(scrollView.contentOffset.x / view.frame.width)
pageControl.currentPage = Int(pageIndex)
}
}
解决方案
设置背景颜色时 pages 变量中有错字。
修复:请将 page1 替换为 page2 和 page3。
page2 .backgroundColor = .systemPurple
page3 .backgroundColor = .systemOrange
推荐阅读
- python - 如何将一个长字符串中的两个单词组合成一个并找到它们的关联句子?
- mysql - 如何减少包含额外单词的行的分数
- perl - 如何获取所有第三个条目,直到它们出现在第二列
- ruby - 从备份恢复系统后 Ruby ripper.bundle 库版本不兼容错误
- port - 在 HandleHTTPRequest 上接收数据的问题无法正常工作
- hadoop - 无法在 Ambari 中加载纱线应用程序日志
- sql - 按列分组数据
- java - 如何忽略大小写并考虑字母数字字符
- linux - vagrant up 命令 SSL 证书问题
- android - Tablayout 在 Android kotlin 的 Fragment 中不起作用