美文网首页
ios UICollectionView

ios UICollectionView

作者: songsongchen | 来源:发表于2016-03-24 11:06 被阅读632次

    针对于UICollectionView的使用方法与UITableView类似

    UICollectionViewLayout

    UICollectionViewLayout决定了UICollectionView如何显示在界面上,Apple提供了一个最简单的默认layout对象:UICollectionViewFlowLayout。

    Flow Layout是一个Cells的线性布局方案,并具有页面和页脚。其可定制的内容如下:

    itemSize属性

    设定全局的Cell尺寸,如果想要单独定义某个Cell的尺寸,可以使用下面方法:

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath

    minimumLineSpacing属性

    设定全局的行间距,如果想要设定指定区内Cell的最小行距,可以使用下面方法:

    - (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout minimumLineSpacingForSectionAtIndex:(NSInteger)section

    minimumInteritemSpacing属性

    设定全局的Cell间距,如果想要设定指定区内Cell的最小间距,可以使用下面方法:

    - (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout minimumInteritemSpacingForSectionAtIndex:(NSInteger)section;

    scrollDirection属性

    设定滚动方向,有UICollectionViewScrollDirectionVertical和UICollectionViewScrollDirectionHorizontal两个值。

    headerReferenceSize属性与footerReferenceSize属性

    设定页眉和页脚的全局尺寸,需要注意的是,根据滚动方向不同,header和footer的width和height中只有一个会起作用。如果要单独设置指定区内的页面和页脚尺寸,可以使用下面方法:

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForFooterInSection:(NSInteger)section

    sectionInset属性

    设定全局的区内边距,如果想要设定指定区的内边距,可以使用下面方法:

    - (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section;

    然后需要实现三种类型的委托:UICollectionViewDataSource, UICollectionViewDelagate和UICollectionViewDelegateFlowLayout

    因为UICollectionViewDelegateFlowLayout实际上是UICollectionViewDelegate的一个子协议,它继承了UICollectionViewDelegate,所以只需要在声明处写上UICollectionViewDelegateFlowLayout就行了。


    UICollectionViewDataSource

    - (NSInteger)numberOfSectionsInCollectionView:(UICollectionView*)collectionView

    返回collection view里区(section)的个数,如果没有实现该方法,将默认返回1

    - (NSInteger)collectionView:(UICollectionView*)collectionView numberOfItemsInSection:(NSInteger)section

    返回指定区(section)包含的数据源条目数(number of items),该方法必须实现:

    - (UICollectionViewCell*)collectionView:(UICollectionView*)collectionView cellForItemAtIndexPath:(NSIndexPath*)indexPath

    返回某个indexPath对应的cell,该方法必须实现:

    UICollectionViewCell结构上相对比较简单,由下至上:

         a.首先是cell本身作为容器view

         b. 然后是一个大小自动适应整个cell的backgroundView,用作cell平时的背景

         c.再其次是selectedBackgroundView,是cell被选中时的背景

         d.最后是一个contentView,自定义内容应被加在这个view上


    为collection view添加一个补充视图(页眉或页脚)

    - (UICollectionReusableView*)collectionView:(UICollectionView*)collectionView viewForSupplementaryElementOfKind:(NSString*)kind atIndexPath:(NSIndexPath*)indexPath

    设定页眉的尺寸

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section:

    设定页脚的尺寸

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForFooterInSection:(NSInteger)section:

    添加页眉和页脚以前需要注册类和标识:

    - (void)registerClass:(Class)viewClass forSupplementaryViewOfKind:(NSString*)elementKind withReuseIdentifier:(NSString*)identifier:


    UICollectionViewDelegateFlowLayout

    设定指定Cell的尺寸

    - (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath:

    设定collectionView(指定区)的边距

    - (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section;

    设定指定区内Cell的最小行距,也可以直接设置UICollectionViewFlowLayout的minimumLineSpacing属性

    - (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout minimumLineSpacingForSectionAtIndex:(NSInteger)section

    设定指定区内Cell的最小间距,也可以直接设置UICollectionViewFlowLayout的minimumInteritemSpacing属性

    - (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout minimumInteritemSpacingForSectionAtIndex:(NSInteger)section;


    UICollectionViewDelegate

    当指定indexPath处的item被选择时触发

    - (void)collectionView:(UICollectionView*)collectionView didSelectItemAtIndexPath:(NSIndexPath*)indexPath

    注意:当你删除或添加元素时,一定要更新numberOfItemsInSection的返回情况。

    当指定indexPath处的item被取消选择时触发,仅在允许多选时被调用

    - (void)collectionView:(UICollectionView*)collectionView didDeselectItemAtIndexPath:(NSIndexPath*)indexPath

    下面是三个和高亮有关的方法:

    - (BOOL)collectionView:(UICollectionView*)collectionView shouldHighlightItemAtIndexPath:(NSIndexPath*)indexPath

    - (void)collectionView:(UICollectionView*)collectionView didHighlightItemAtIndexPath:(NSIndexPath*)indexPath

    - (void)collectionView:(UICollectionView*)collectionView didUnhighlightItemAtIndexPath:(NSIndexPath*)indexPath

    事件的处理顺序如下:

       a.手指按下

       b.shouldHighlightItemAtIndexPath (如果返回YES则向下执行,否则执行到这里为止)

       c.didHighlightItemAtIndexPath (高亮) 

       d.手指松开

       e.didUnhighlightItemAtIndexPath (取消高亮)

       f.shouldSelectItemAtIndexPath (如果返回YES则向下执行,否则执行到这里为止)

       g.didSelectItemAtIndexPath (执行选择事件)

    相关文章

      网友评论

          本文标题:ios UICollectionView

          本文链接:https://www.haomeiwen.com/subject/hfdrlttx.html