iOS-CollectionView 瀑布流实现 及 cell重
demo中采用的大都是工装图,毕竟我是喜欢工装的农民工。(猜猜哪个是我)
最近在用CollectionView写一个可以自动识别文字和图片高度的瀑布流。
在cell中根据当前cell宽度用Masonry设置image的宽、高的时候,在没有滑动界面的时候是没问题的。如图所示:
图1 图2但是当我滑动Collectionview,就发现报错,并且图片显示也出现问题,宽度跟cell宽度并不一样:
图3 图4报错:
Try this:
(1) look at each constraint and try to figure out which you don't expect;
(2) find the code that added the unwanted constraint or constraints and fix it.
MASLayoutConstraint:0x6000000b0c80 UIImageView:0x7fe9f6f4f1e0.height == 65.9022
MASLayoutConstraint:0x6040000a9b40 UIImageView:0x7fe9f6f4f1e0.height == 177.5
根据打印结果大概知道是设置了两次UIimageview的高度,出现了约束冲突,但从代码上看来我只设置了一次,网上查了下类似的问题,但是解决办法都是说设置约束的优先级priority(),我设置之后虽然不报错,但是图片显示还是有问题。
最后发现是因为cell复用,复用的cell中的imgView控件仍含有之前设置的约束,所以就产生冲突了。
知道了问题在哪就好办了,在cell中设置image的时候,先取得imgView的所有约束,然后删除,最后重新设置约束,就没问题了。(本来想做个判断,只在复用的cell中删除约束,但暂时还不知道如何拿到复用的cell,所以就直接对所有cell进行操作)代码如下:
图5修改之后图片显示就没问题了
图6当然,取消cell复用也是可以的,但是当数据量过多的时候,内存会过大,所以不考虑这种方法了。
另附瀑布流demo地址:CollectionView瀑布流