1⃣️
UICollectionView与UITableView的
区别:布局
UICollectionView与UITableView的
共同点:循环利用
—> UITableView继承UISCrollView
注意:
—> UICollectionView 初始化必需要传入布局
UICollectionViewLayout
UICollectionViewFlowLayout 流水布局:九宫格布局
—> UICollectionViewCell必需要注册
—> 必须自定义cell
方法抽取的原则:高聚合,低耦合.
—> 对于项目功能的模块,实行抽取方法
—> 对于设置属性的模块,可使用以下方式⬇️
2⃣️
当系统的方法无法知足咱们的需求的时候,咱们就能够
自自定义类,重写方法,达到一些效果.
思路:
照片浏览布局:1.(流水布局)在拖动的时候,在原来基础上从新计算下布局
2.在原来功能上再添加功能,须要自定义流水布局
🚀
自定义UICollectionView布局.了解5个方法
⭐️- (void)prepareLayout;
何时调用:一开始布局就会调用,UICollectionView刷新的时候也会调用
做用:计算全部的cell布局,条件:cell布局固定
⭐️- (nullable NSArray<__kindof UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect;
做用:返回每一个cell布局,
给定一个区域,就返回这个区域内全部cell布局
容许一次性返回全部cell布局
分析:
UICollectionViewLayoutAttributes:描述cell的布局
每个cell对应UICollectionViewLayoutAttributes
只要拿到UICollectionViewLayoutAttributes,拿到cell
⭐️- (BOOL)shouldInvalidateLayoutForBoundsChange:(CGRect)newBounds;
Invalidate:刷新
是否容许在拖动的时候刷新布局
谨慎使用,YES:只要一滚动就会布局
⭐️- (CGPoint)targetContentOffsetForProposedContentOffset:(CGPoint)proposedContentOffset withScrollingVelocity:(CGPoint)velocity;
何时调用:手动拖动UICollectionView,当手指离开的时候,就会调用
做用:返回UICollectionView最终的偏移量
proposedContentOffset:最终的偏移量
⭐️- (CGSize)collectionViewContentSize;
—>个人总结:
UICollectionView与UIScrollView比较:
UICollectionView建立的同时必需要初始化布局
这里选择UICollectionViewFlowLayout流水布局
↘️所须要的两个对象
UICollectionView *collectionView;
UICollectionViewFlowLayout *layout;
↘️在layout中,设置布局的一些属性
itemSize:collectionView中的每一个模型尺寸
scrollDirection:滚动方向
sectionInset:设置额外滚动区域
......
建立collectionView对象并同时传入布局layout,
↘️设置collectionView属性
设置collectionView的相关属性:位置,背景色,.....
↘️注意
UICollectionView和UIScrollView的不一样之处就体如今布局,
UICollectionView初始化时须要布局且UICollectionView内的控件彻底根据布局的设置来显示,不须要去设置滚动区域.
UIScrollView须要去根据控件的多少来设置内容滚动区域contentSize.
👉UITableView继承自UIScrollView