之前一直在使用UITableView,一直想找个机会好好使用一下collectionView。今天自己尝试使用了一下,并且有炫酷效果哦,写篇文章总结一下,希望对想要使用的你有所帮助。
1.首先我们直接来创建一个collectionView对象
data:image/s3,"s3://crabby-images/12f8e/12f8e6ef4b1d7c1da75f3d500ea46773343a4c13" alt=""
这里需要注意两点
a.Frame值 这个可以根据自己的需要设置
b.collectionViewLayout: 这个参数是UICollectionView用来进行展示item布局的 我们最常使用的是流水布局
注: 这里的布局参数类是一个抽象类,不能初始化对象,我们在开发过程中一般使用它的子类UICollectionViewFlowLayout 来设置
//1.1 常用流水布局
UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc]init];
2.我们可以指定代理对象
data:image/s3,"s3://crabby-images/e4fe8/e4fe895aecf8d5816e7e90e8eb9cb6ee87f3cbe0" alt=""
此时类比UITableView 我们就要遵守代理协议,实现数据源方法
data:image/s3,"s3://crabby-images/08492/084928309b59945adbb97c47e82a976e2c4c260c" alt=""
到了这一步看似差不多可以了,不过这里有一个特别注意的点,就是UiCollectionView在使用的时候必须注册cell
data:image/s3,"s3://crabby-images/f5f54/f5f54df9c9df4d74bf8cf0431135be927b2c39fd" alt=""
这个时候我们就可以运行一下看看效果了。
data:image/s3,"s3://crabby-images/a92fd/a92fd583a03f02122caeea5c7b49ce3d7de64543" alt=""
以上就是简单使用UICollectionView,不过在工作中会有相对复杂的需求,不过这些看似高级的使用 也是在基础之上进行了特殊的设置。我们先把上面的代码放上来,大家可以参照一下。
data:image/s3,"s3://crabby-images/f9dec/f9decc460e06df0d0e160610fe4f826367fe08b9" alt=""
如果我们需要自己设置每一个cell的展示样式和大小设置 可以通过修改布局参数UICollectionViewFllowLayout的对象参数来设置。
data:image/s3,"s3://crabby-images/02006/02006c6a56535b2701a895ecccd4faeff3682a00" alt=""
1.要自己写一个布局参数类 继承自流水布局 UICollectionViewFllowLayout
2.当cell的位置相对屏幕中心改变时 重新约束cell
3.相关代码如下:
data:image/s3,"s3://crabby-images/e5936/e5936a5aae796ecc89c0ac3cf5a28602802c9e3c" alt=""
4.除了上述的计算之外 必须在自定义的约束类中设置一个属性
data:image/s3,"s3://crabby-images/c2147/c2147e634186c0c99aeeefbddb2acbda28e5c7a8" alt=""
以上就是炫酷效果的实现了,如果你觉得那里有错误的地方,欢迎指教。邮箱zihanvip520@163.com。
网友评论