我宣布 UICollectionView
和其对应的单元格进行编程。在写出vanilla设置后,我发现我无法配置单元格的大小。无论我是否放置逻辑,或者是什么尺寸,单元格(红色)看起来都是一些默认的正方形(和小)尺寸。 本帖末尾有一个屏幕截图。
作为参考,代码如下。
setupView(){}
// collection view for screens
let screenHeight : CGFloat = CGFloat(height/6)
let screenWidth = screenHeight * ( width/height )
let offset_top_screens : CGFloat = height - rowHeight - screenHeight
let screenRow = UICollectionView(
frame: CGRect(x: 0, y: offset_top_screens, width: width, height: screenHeight)
, collectionViewLayout: UICollectionViewFlowLayout()
)
//screenRow.translatesAutoresizingMaskIntoConstraints = false
screenRow.backgroundColor = Color.grayTertiary
// set up collection view delegates
screenRow.dataSource = self
screenRow.alwaysBounceHorizontal = true
screenRow.register(ScreenItem.self, forCellWithReuseIdentifier: ScreenItem.identifier) // register w/ storyboard
self.view.addSubview(screenRow)
self.screenRow = screenRow
self.view.bringSubviewToFront(screenRow)
self.screenHeight = screenHeight
self.screenWidth = screenWidth
// end collection view screen
}
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return dataSource.count
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let row = indexPath.row
let user = self.dataSource[row]
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "ScreenItem", for: indexPath) as! ScreenItem
/*
cell.uuid = user.uuid
cell.delegate = self
cell.mediaSource = ... what is the pipe here?
*/
return cell
}
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
return CGSize(width: 45, height:40) // changing these values do not change anything
// return CGSize(width: 90, height: collectionView.bounds.height) <- this does nothing
}
func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
insetForSectionAt section: Int) -> UIEdgeInsets {
return UIEdgeInsets(top: 0, left: 0, bottom: 0, right: 0) //.zero
}
func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
minimumInteritemSpacingForSectionAt section: Int) -> CGFloat {
return 0
}
func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
minimumLineSpacingForSectionAt section: Int) -> CGFloat {
return 0
}
// somewhere in a different file
/*
@Use: display user's screen
*/
class ScreenItem: UICollectionViewCell {
static var identifier: String = "ScreenItem"
weak var textLabel: UILabel!
override init(frame: CGRect) {
super.init(frame: frame)
self.backgroundColor = Color.red
}
required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
}
override func prepareForReuse() {
super.prepareForReuse()
self.reset()
}
func reset() {
// @TOOD: reset things here
}
}
__更新 __父类定义
class CallController:
UIViewController
, UICollectionViewDataSource
, UICollectionViewDelegate
你好像没有设置委托。如果你使用的是 UICollectionViewFlowLayout
那么你 UIViewController
应实施 UICollectionViewDelegateFlowLayout
协议。
UICollectionViewDelegateFlowLayout。
您的 UIViewController
实例已经实现了这个协议?您是否设置了 delegate
财产?