zoukankan      html  css  js  c++  java
  • Colletion View 简单的备忘

    UIColletionView

    这篇只是做UIColletionView的常用属性、代理方法和数据源方法的备忘,之后做一些自定义布局,增加删除动画等。

    UIColletionViewFlowLayout的常用属性和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)
    

     一般简单的布局使用原生的flowlayout就行,常用属性:

    • itemSize:每个cell的尺寸。
    • headerReferenceSize:组头的尺寸。
    • footerReferenceSize:组尾的尺寸。
    • scrollDirection:滚动方向。
    • minimumLineSpacing:每一行的距离。
    • minimumInteritemSpacing:每个cell之间的距离。
    • sectionInset:组的内边距。

    一般collection view的必须设置的属性和方法:

    • delegate:代理,可以监听事件。
    • dataSource:数据源,提供一些collection view要用的数据
    • registerClass(_, forCellWithReuseIdentifier:):注册Cell,实现复用机制。
    • registerClass(_, forSupplementaryViewOfKind: , withReuseIdentifier:):注册组头或组尾,也是可以复用的。

    Delegate

    高亮: 

        // 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")
        }
    

     显示(iOS8):

        // 即将有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
        }
    

    DelegateFlowLayout

        // 设置每个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)
        }
    

    DataSource

        // 必须实现 返回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
        }
    
  • 相关阅读:
    C#中WinForm程序退出方法技巧(转载)
    webbrowser访问网站禁止弹窗
    (转载)ASP.NET三大核心对象及基础功能解析
    webBrowser调用外部js文件和js函数(转载)
    java IO流
    java线程状态,优先级
    java线程
    Collection接口,Map接口
    序列化和反序列化
    JsonUtil自定义
  • 原文地址:https://www.cnblogs.com/Alex-sk/p/5567838.html
Copyright © 2011-2022 走看看