【发布时间】:2019-09-26 23:24:01
【问题描述】:
我已经有一个以编程方式制作的 UIViewController,并希望在底部有一个包含 4 个单元格的集合视图,但我希望能够在集合视图的不同页面中滑动以查看不同的单元格。我不确定从哪里开始在集合视图上启用分页以及如何设置单元格,或者创建页面控制器并将集合视图添加到其中?我已经在网上看到了几种方法,但这并不真正符合我的需求。
我想要这样的东西:
如果我可以为您提供更多信息,请告诉我。我刚刚创建了一个基本的页面控制器,但不确定如何实现我想要的。
编辑:我创建了一个集合视图并添加了约束以获得我想要的布局;但是我不确定如何让它像页面一样滑动。
这是集合视图的代码:
let friendsCollectionView: UICollectionView = {
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .horizontal
let cv = UICollectionView(frame: .zero, collectionViewLayout: layout)
cv.translatesAutoresizingMaskIntoConstraints = false
cv.register(FriendsCell.self, forCellWithReuseIdentifier: "cell")
cv.backgroundColor = UIColor.blue
cv.layer.cornerRadius = 10
return cv
}()
view.addSubview(friendsCollectionView)
friendsCollectionView.anchor(top: separatorView.bottomAnchor, left: nil, bottom: nil, right: nil, paddingTop: 50, paddingLeft: 0, paddingBottom: 0, paddingRight: 0, width: 250, height: 250)
friendsCollectionView.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
return CGSize(width: 75, height: 75)
}
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets {
if section == 0 {
return UIEdgeInsets(top: 85, left: 10, bottom: 0, right: 0)
}
if section == 1 {
return UIEdgeInsets(top: 10, left: 0, bottom: 10, right: 0)
}
if section == 2 {
return UIEdgeInsets(top: 85, left: 5, bottom: 0, right: 0)
}
return UIEdgeInsets(top: 0, left: 0, bottom: 0, right: 0)
}
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
if section == 0 { return 1 }
if section == 1 { return 2 }
if section == 2 { return 1 }
return 0
}
func numberOfSections(in collectionView: UICollectionView) -> Int {
return 3
}
【问题讨论】:
-
“但我希望能够在集合视图的不同页面中滑动以查看不同的单元格”不清楚是什么意思。你的意思是每个页面都是四个不同单元格的集合吗?
-
没错。
-
好的,那么这与集合视图有什么关系?您的页面视图控制器页面是单独的视图控制器!它们不是单个视图(例如集合视图)的一部分。您只需要一个包含四个菱形图像的视图控制器来充当您的页面。
-
我对您遇到的问题感到困惑?您是否尝试过这样做?您自己尝试过任何代码吗?对我来说,实现您需要的东西似乎相当简单,但是很难为您提供准确的答案,因为您似乎没有尝试自己实现任何这些......一个简单的谷歌搜索......如何添加 uicollection以编程方式查看...会产生答案
-
是的,我试过了,但没有任何结果。我试图做一个集合视图的原因是因为我还想实现一个圆形动画,这样四个单元格将以圆周运动旋转,然后反弹回来,除非这可以通过普通视图控制器轻松实现。我还想有一个集合视图,因为这样会更容易从数据库中提取值,这样我就可以最小化我的数据库存储。
标签: swift uiview uicollectionview uipageviewcontroller