iOS-CollectionView 瀑布流实现 及 cell重

2018-03-20  本文已影响0人  不作不死不舒服斯基

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瀑布流

上一篇 下一篇

猜你喜欢

热点阅读