这篇只是做UIColletionView的常用属性、代理方法和数据源方法的备忘,之后做一些自定义布局,增加删除动画等。
// 创建布局类
let layout = UICollectionViewFlowLayout()
layout.itemSize = CGSizeMake(50.0, 50.0)
layout.headerReferenceSize = CGSizeMake(view.frame.size.width, 100)
layout.scrollDirection = UICollectionViewScrollDirection.Vertical
layout.minimumLineSpacing = 50.0
layout.minimumInteritemSpacing = (view.frame.size.width - 20 - 50 * 4) / 4
layout.sectionInset = UIEdgeInsetsMake(10, 10, 0, 10)
// 创建collection view
let collectionView = UICollectionView(frame: CGRectMake(0, 20, view.frame.size.width, view.frame.size.height - 20), collectionViewLayout: layout)
collectionView.backgroundColor = UIColor.whiteColor()
collectionView.delegate = self
collectionView.dataSource = self
// 注册Cell SectionHeader SectionFooter
collectionView.registerClass(UICollectionViewCell.self, forCellWithReuseIdentifier: "Cell")
collectionView.registerClass(UICollectionReusableView.self, forSupplementaryViewOfKind: UICollectionElementKindSectionHeader, withReuseIdentifier: "SectionHeader")
collectionView.registerClass(UICollectionReusableView.self, forSupplementaryViewOfKind: UICollectionElementKindSectionFooter, withReuseIdentifier: "SectionFooter")
view.addSubview(collectionView)
// cell是否允许高亮
func collectionView(collectionView: UICollectionView, shouldHighlightItemAtIndexPath indexPath: NSIndexPath) -> Bool {
return true
}
// cell已经进入高亮状态
func collectionView(collectionView: UICollectionView, didHighlightItemAtIndexPath indexPath: NSIndexPath) {
print("didHighlightItemAtIndexPath")
}
// cell已经结束高亮状态
func collectionView(collectionView: UICollectionView, didUnhighlightItemAtIndexPath indexPath: NSIndexPath) {
print("didUnhighlightItemAtIndexPath")
}
// cell是否允许选中
func collectionView(collectionView: UICollectionView, shouldSelectItemAtIndexPath indexPath: NSIndexPath) -> Bool {
return true
}
// cell是否允许取消选中
func collectionView(collectionView: UICollectionView, shouldDeselectItemAtIndexPath indexPath: NSIndexPath) -> Bool {
return true
}
// cell被选中
func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) {
print("didSelectItemAtIndexPath")
}
// cell取消选中
func collectionView(collectionView: UICollectionView, didDeselectItemAtIndexPath indexPath: NSIndexPath) {
print("didDeselectItemAtIndexPath")
}
// 即将有cell显示
func collectionView(collectionView: UICollectionView, willDisplayCell cell: UICollectionViewCell, forItemAtIndexPath indexPath: NSIndexPath) {
print("willDisplayCell")
}
// 即将有组头或组尾显示
func collectionView(collectionView: UICollectionView, willDisplaySupplementaryView view: UICollectionReusableView, forElementKind elementKind: String, atIndexPath indexPath: NSIndexPath) {
print("willDisplaySupplementaryView")
}
// 有cell不在屏幕上显示了
func collectionView(collectionView: UICollectionView, didEndDisplayingCell cell: UICollectionViewCell, forItemAtIndexPath indexPath: NSIndexPath) {
print("didEndDisplayingCell")
}
// 有组头或组尾不在屏幕上显示了
func collectionView(collectionView: UICollectionView, didEndDisplayingSupplementaryView view: UICollectionReusableView, forElementOfKind elementKind: String, atIndexPath indexPath: NSIndexPath) {
print("didEndDisplayingSupplementaryView")
}
// 是否允许显示菜单
func collectionView(collectionView: UICollectionView, shouldShowMenuForItemAtIndexPath indexPath: NSIndexPath) -> Bool {
return true
}
// 允许实现那个菜单方法
func collectionView(collectionView: UICollectionView, canPerformAction action: Selector, forItemAtIndexPath indexPath: NSIndexPath, withSender sender: AnyObject?) -> Bool {
return true
}
// 菜单方法的具体实现
func collectionView(collectionView: UICollectionView, performAction action: Selector, forItemAtIndexPath indexPath: NSIndexPath, withSender sender: AnyObject?) {
}
// 重新布局的时候调用
func collectionView(collectionView: UICollectionView, transitionLayoutForOldLayout fromLayout: UICollectionViewLayout, newLayout toLayout: UICollectionViewLayout) -> UICollectionViewTransitionLayout {
print("transitionLayoutForOldLayout")
let transitionLayout = UICollectionViewTransitionLayout(currentLayout: fromLayout, nextLayout: toLayout)
transitionLayout.transitionProgress = 1.5
return transitionLayout
}
// 设置每个cell的尺寸
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize {
if indexPath.row % 2 == 0{
return CGSizeMake(30, 30)
} else {
return CGSizeMake(50, 50)
}
}
// 设置每一组的内边距
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAtIndex section: Int) -> UIEdgeInsets {
return UIEdgeInsetsMake(20, 5, 10, 5)
}
// 返回每一组的行距
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAtIndex section: Int) -> CGFloat {
return 10
}
// 返回每组item之间的间距
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumInteritemSpacingForSectionAtIndex section: Int) -> CGFloat {
return 10
}
// 返回每一组的组尾尺寸
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForFooterInSection section: Int) -> CGSize {
return CGSizeMake(view.frame.size.width, 80)
}
// 返回每一组的组头尺寸
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, referenceSizeForHeaderInSection section: Int) -> CGSize {
return CGSizeMake(view.frame.size.width, 200)
}
// 必须实现 返回cell个数
func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 40
}
// 必须实现 返回每个cell 复用机制
func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCellWithReuseIdentifier("Cell", forIndexPath: indexPath)
cell.backgroundColor = UIColor.brownColor()
return cell
}
// 返回有几组
func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
return 2
}
// 返回组头或者组尾视图,同样用复用机制
func collectionView(collectionView: UICollectionView, viewForSupplementaryElementOfKind kind: String, atIndexPath indexPath: NSIndexPath) -> UICollectionReusableView {
let reusableView = collectionView.dequeueReusableSupplementaryViewOfKind(kind, withReuseIdentifier: "SectionHeader", forIndexPath: indexPath)
if kind == UICollectionElementKindSectionHeader {
reusableView.backgroundColor = UIColor.blackColor()
} else {
reusableView.backgroundColor = UIColor.blueColor()
}
return reusableView
}
原文:http://www.cnblogs.com/Alex-sk/p/5567838.html