UICollectionViewLayout
来源:互联网 发布:人工智能电影排名 编辑:程序博客网 时间:2024/04/29 14:53
UICollectionViewLayout是UICollectionView的大脑和中枢,它负责了将各个cell、Supplementary View和Decoration Views进行组织,为它们设定各自的属性,包括但不限于:
- 位置
- 尺寸
- 透明度
- 层级关系
- 形状
- 等等等等…
- Layout决定了UICollectionView是如何显示在界面上的。在展示之前,一般需要生成合适的UICollectionViewLayout子类对象,并将其赋予CollectionView的collectionViewLayout属性。关于详细的自定义UICollectionViewLayout和一些细节,我将写在之后一篇笔记中。
Apple为我们提供了一个最简单可能也是最常用的默认layout对象,UICollectionViewFlowLayout。Flow Layout简单说是一个直线对齐的layout,最常见的Grid View形式即为一种Flow Layout配置。上面的照片架界面就是一个典型的Flow Layout。
- 首先一个重要的属性是itemSize,它定义了每一个item的大小。通过设定itemSize可以全局地改变所有cell的尺寸,如果想要对某个cell制定尺寸,可以使用-collectionView:layout:sizeForItemAtIndexPath:方法。
间隔 可以指定item之间的间隔和每一行之间的间隔,和size类似,有全局属性,也可以对每一个item和每一个section做出设定:
- @property (CGSize) minimumInteritemSpacing
- @property (CGSize) minimumLineSpacing
- -collectionView:layout:minimumInteritemSpacingForSectionAtIndex:
- -collectionView:layout:minimumLineSpacingForSectionAtIndex:
滚动方向 由属性scrollDirection确定scroll view的方向,将影响Flow Layout的基本方向和由header及footer确定的section之间的宽度
- UICollectionViewScrollDirectionVertical
- UICollectionViewScrollDirectionHorizontal
Header和Footer尺寸 同样地分为全局和部分。需要注意根据滚动方向不同,header和footer的高和宽中只有一个会起作用。垂直滚动时section间宽度为该尺寸的高,而水平滚动时为宽度起作用,如图。
- @property (CGSize) headerReferenceSize
- @property (CGSize) footerReferenceSize
- -collectionView:layout:referenceSizeForHeaderInSection:
- -collectionView:layout:referenceSizeForFooterInSection:
缩进
- @property UIEdgeInsets sectionInset;
- -collectionView:layout:insetForSectionAtIndex:
一个UICollectionView的实现包括两个必要部分:UICollectionViewDataSource和UICollectionViewLayout,和一个交互部分:UICollectionViewDelegate。而Apple给出的UICollectionViewFlowLayout已经是一个很强力的layout方案了。
1 0
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- UICollectionViewLayout
- 快速定位crash的炫酷方式
- 时间戳的格式,直接影响时间戳的正确与否
- 42、微信-添加新朋友列表适配器
- Linux常用命令
- dimension适配
- UICollectionViewLayout
- 43、微信-好友详情页面FriendMsgActivity
- 44、公共页面PublicActivity
- JAVA基础(20) ExecutorService线程池讲解
- 320. Generalized Abbreviation
- 为Nginx 创建 Windows 的服务程序
- 查看当前目录路径 pwd
- 45、微信-从通讯录添加好友
- php var_dump 打印不全,且中文乱码解决方法