文档章节

UICollection要点

d
 dadage456
发布于 2017/01/17 11:03
字数 554
阅读 1
收藏 0

一、

UICollectionView 要点

  • UICollectionLayout布局方法的执行顺序
  • UICollectionLayout实现自定义布局要点
  • UICollect这里是列表文本ionViewLayoutAttributes实现自定义布局属性要点
  • 重新计算布局属性
  • 自动对齐到网格
int a=b;

1、UICollectionView 构成

  • Cells
  • Supplementary Views 追加视图(类似Header 或则 Footer)
  • Decoration Views 装饰视图(用作背景展示)

2、布局方法的执行顺序

  1. prepareLayout()
  2. -(CGSize)collectionViewContentSize
  3. -(NSArray *)layoutAttributesForElementsInRect:(CGRect)rect

3、自定义UICollectionLayout实现自定义布局

主要继承UICollectionLayout以下方法,实现布局自定义。

  • -(void)prepareLayout

    开始布局前,调用的方法。可以用来一次把所有的布局属性放到一个NSArray中。

  • -(CGSize)collectionViewContentSize

    返回CollectionView的内容尺寸

  • -(NSArray *)layoutAttributesForElementsInRect:(CGRect)rect

    1. 返回rect中的所有元素的布局属性
    2. 返回的是包含UICollectionViewLayoutAttributes的NSArray
    3. UICollectionViewLayoutAttributes可以是Cell追加视图装饰视图
    4. 不要返回所有的属性,只显示Rect相交的属性。节省性能。
  • -(BOOL)shouldInvalidateLayoutForBoundsChange:(CGRect)newBounds

    YES : 边界发生变化,刷新布局。
    不要直接返回YES,判断UICollectionView的frame改变时再返回YES。

  • -(UICollectionViewLayoutAttributes _)layoutAttributesForItemAtIndexPath:(NSIndexPath _)indexPath

    返回对应于indexPath的位置的Cell的布局属性

  • -(UICollectionViewLayoutAttributes _)layoutAttributesForSupplementaryViewOfKind:(NSString _)kind atIndexPath:(NSIndexPath *)indexPath

    返回对应于indexPath的位置的追加视图的布局属性

  • -(UICollectionViewLayoutAttributes * )layoutAttributesForDecorationViewOfKind:(NSString_)decorationViewKind atIndexPath:(NSIndexPath _)indexPath

    返回对应于indexPath的位置的装饰视图的布局属性

4、自定义UICollectionViewLayoutAttributes

主要用来布局cell、追加视图、装饰视图里面的指定子元素。

  • 实现NSCopying协议?
  • 实现-(BOOL)isEqual:(id)object父类方法?
  • 在cell、追加视图、装饰视图中,实现-(void)applyLayoutAttributes:(UICollectionViewLayoutAttributes *)layoutAttributes方法,具体布局指定元素。
  • 在Layout类中实现以下方法?
    • +(Class)layoutAttributesClass

5、重新计算布局

  • invalidateLayout:执行布局方法,从-(void)prepareLayout方法开始重新计算布局。

6、切换布局

注意:切换的2个布局必须已经实现了 -(UICollectionViewLayoutAttributes _)layoutAttributesForItemAtIndexPath:(NSIndexPath _)indexPath方法。否则会报错。

  • setCollectionViewLayout:animated:

7、动画效果

  • initialLayoutAttributesForAppearingItemAtIndexPath:
  • initialLayoutAttributesForAppearingSupplementaryElementOfKind:atIndexPath:
  • initialLayoutAttributesForAppearingDecorationElementOfKind:atIndexPath:
  • finalLayoutAttributesForDisappearingItemAtIndexPath:
  • finalLayoutAttributesForDisappearingSupplementaryElementOfKind:atIndexPath:
  • finalLayoutAttributesForDisappearingDecorationElementOfKind:atIndexPath:

8、DEMO与参考

© 著作权归作者所有

共有 人打赏支持
上一篇: UICollection要点
下一篇: UICollection要点
d
粉丝 0
博文 10
码字总数 5374
作品 0
青岛
私信 提问
万物有源_Android自动化测试框架UIAutomator原理浅析

简介 UIAutomator是一个Android自动化测试框架,是谷歌在Android4.1版本发布时推出的一款用Java编写的UI测试框架,它只能用于UI即黑盒方面的测试。所以UIAutomator只能运行在Android4.1之后的...

维他ViTa
03/16
0
0
关联选择器--MBContactPicker

MBContactPicker 是基于 UICollection View 的 iOS 风格的关联选择工具库,实现类似 iOS 7 的本地邮件关联选择器的功能。

叶秀兰
2014/01/04
240
0
BMYCircularProgressPullToRefresh

BMYCircularProgressPullToRefresh 是下拉刷新,带有圆形进程视图,类似 Beamly iOS 应用。 此版本的下拉刷新特性可以再 UITableViews 和 UICollection 上使用,灵感来源于 Sam Vermette's S...

叶秀兰
2014/07/22
482
0
CombinationPickerController

CombinationPickerController 是图片选择器,使用 uicollection 视图。CombinationPickerController 可以选择单个图片,可以自定义你的相机,默认只支持人像。CombinationPickerController 兼...

叶秀兰
2014/08/27
510
0
ios UIcollection显示图片

xcode 7.3.1 UIcollection创建的item,cell来加载图片,加载到24个才会显示图片,怎么让他加载一个就显示一个图片

zxcasdqwe123
2016/08/18
42
0

没有更多内容

加载失败,请刷新页面

加载更多

Mac java多版本控制

vim ~/.bash_profile ORACLE_JAVA_6_HOME="/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents/Home"ORACLE_JAVA_7_HOME="/Library/Java/JavaVirtualMachines/jdk1.7.0_80.jdk/Contents......

晨猫
7分钟前
0
0
[转载]Qlist的用法

QList是一种表示链表的模板类。 QList是Qt的一种泛型容器类。它以链表方式存储一组值,并能对这组数据进行快速索引,还提供了快速插入和删除等操作。 QList、QLinkedList和QVector提供的操作...

shzwork
7分钟前
0
0
谷歌的JavaScript编写风格中 13点值得我们注意的!

  对于那些还不熟悉JavaScript的编写风格的人,谷歌提供了编写JavaScript的编写风格指南,谷歌风格指南 其中列出了编写干净、可理解代码的最佳风格实践。   对于编写有效的JavaScript来说...

peakedness丶
21分钟前
1
0
Spring Boot2中配置HTTPS

1.生成证书 使用jdk,jre中的keytool.exe生成自签名的证书,需要配置JAVA_HOME和path环境变量,即jdk的环境变量。命令如下: keytool -genkey -alias tomcat -storetype PKCS12 -keyalg RSA ...

voole
28分钟前
2
0
Spring Cloud Alibaba 新版本发布:众多期待内容整合打包加入!

在Nacos 1.0.0 Release之后,Spring Cloud Alibaba也终于发布了最新的版本。该版本距离上一次发布,过去了整整4个月!下面就随我一起看看,这个大家期待已久的版本都有哪些内容值得我们关注。...

程序猿DD
31分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部