关于UICollectionView 插入子视图在其与cell之间的问题的解决

关于UICollectionView 插入子视图在其与cell之间的问题的解决,第1张

最近做带有背景游标的标签的时候,使用 UICollectionView 进行实现过程中,在其View中添加子视图,会盖住 Cell ,导致 Cell 展示出问题。而此时的想法目的是要将 view 作为 cell 的背景进行展示,百说不如一见,如下截图展示的当前问题:

进行了几次尝试之后,发现在 collectionView 没有显示的时候,是不会进行 cell视图 的渲染的,也就是说当前的 collectionView 中没有cell类别的子视图,此时直接加入子视图会在渲染cell类别子视图之前,而当 collectionView 可见的时候, collectionView 再去渲染显示 cell (推测系统可能使用insertView:Index:方法),此时让 cell 层级插入到了 UICollectionView 与刚刚加到 CollectionView 视图之间了,进而导致了当前的问题的发生。

知道原因了,再去解决这样的问题,就很方便了。我们可以将 View 的添加放在渲染 cell 之后,这样就能避免系统渲染 cell 影响我们视图的层级结构导致画面被遮挡的问题了。

在进行 CollectionView reload之后,我们可以强制 CollectionView 渲染界面,使用 layoutIfNeeded 进行界面的强制刷新,之后再去插入我们想加入的视图,这样就能将加入的视图放入到 UICollectionView 与 Cell 之间了,从而达到我们想要的效果。

uitableview cell 添加子视图xib为什么frame跟设置的不一样

有时候我们经常需要自定义tableView的cell,当cell里面的布局较为复杂时往往舍弃纯代码的方式而改用xib的方式进行自定义。当我们用纯代码的方式布局cell时,往往会在cell的initWithStyle: reuseIdentifier: 方法里面用纯代码进行布局,然后在外部VC的cellForRowAtIndexPath方法里面我们会这么写,假定自定义的cell为Cell,继承自UITableViewCell:

static NSString *CellIdentifier = @"Cell"

Cell *cell = (Cell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier]

if (!cell) {

cell = [[[Cell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]

}

cell.titleLabel.text = [self.dataList objectAtIndex:indexPath.row]

return cell

上述这么写完全没有问题,因为教科书跟各种教程都是这么写的,上述代码对cell进行了重用。但如果我们现在想用xib来布局呢?看到过不少代码是这么写的:

static NSString *CellIdentifier = @"Cell"

Cell *cell = (Cell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier]

if (!cell) {

cell = [[[NSBundle mainBundle] loadNibNamed:NSStringFromClass([Cell class])

owner:self

options:nil] objectAtIndex:0]

//cell = [[[Cell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]

}

cell.titleLabel.text = [self.dataList objectAtIndex:indexPath.row]return cell


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/7992652.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存