无法创建 3 列 UICollectionView
Posted
技术标签:
【中文标题】无法创建 3 列 UICollectionView【英文标题】:Can't create a 3 column UICollectionView 【发布时间】:2018-11-23 23:13:29 【问题描述】:我正在尝试创建一个 3 列的 UICollectionView/网格视图,但尽管我尝试了一切,但我没有成功。
我使用的代码如下:
import UIKit
class SearchResultsViewController: UIViewController,UICollectionViewDataSource, UICollectionViewDelegate, UICollectionViewDelegateFlowLayout
// Actual code
@IBOutlet weak var collectionView: UICollectionView!
public var results: [UIImage]!
func loadImages(images: [UIImage])
results = images
override func viewDidLoad()
super.viewDidLoad()
collectionView.dataSource = self
collectionView.delegate = self
self.navigationController?.setNavigationBarHidden(false, animated: true)
// Disable the margins
let flow = collectionView?.collectionViewLayout as! UICollectionViewFlowLayout
collectionView.contentOffset = CGPoint.zero
flow.estimatedItemSize = UICollectionViewFlowLayout.automaticSize
flow.minimumInteritemSpacing = 0
flow.minimumLineSpacing = 0
// UICollectionView
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int
return 64
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
let screenWidth = UIScreen.main.bounds.width
return CGSize(width: screenWidth/3, height: screenWidth/3)
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets
return UIEdgeInsets(top: 0, left: 0, bottom: 5, right: 5)
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath)
return cell
我正在寻找与 Instagram 等照片应用程序类似的三列布局(请注意,64 是作为虚拟数据存在的,因此我可以测试它是否有效,如果有效,它将被实际图像替换)
我最终没有得到预期的结果,而是这样: [
【问题讨论】:
为什么要添加 5 的右插图?您添加的每个额外空间都必须从您的项目宽度计算中删除,在您的情况下为 (screenWidth - 5) / 3。 【参考方案1】:这样使用:
lazy var collectionView: UICollectionView =
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .vertical
layout.minimumLineSpacing = 10
layout.minimumInteritemSpacing = 10
let width = (view.frame.width - 10 * 3) / 2
layout.itemSize = CGSize(width: width, height: width)
layout.sectionInset = UIEdgeInsets(top: 10, left: 10, bottom: 10, right: 10)
let cv = UICollectionView(frame: .zero, collectionViewLayout: layout)
cv.delegate = self
cv.dataSource = self
cv.translatesAutoresizingMaskIntoConstraints = false
cv.showsVerticalScrollIndicator = false
cv.backgroundColor = .clear
return cv
()
另外,您不需要使用这些方法。不再需要。
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAt section: Int) -> CGFloat
【讨论】:
以上是关于无法创建 3 列 UICollectionView的主要内容,如果未能解决你的问题,请参考以下文章
如何创建带有列标题和行标题的 UICollectionView?