0

我正在使用集合视图来显示“卡片”。当用户单击其中一张卡片时,视图会随着翻转动画而改变(通过在 didSelectItemAtIndexPath 中调用的函数)。如果用户触摸这些卡片中的另一张,他们可以单击另一张卡片,旧卡片将翻转回旧视图,新卡片将翻转到新视图。或者,他们可以再次单击原始卡并将其翻转回来。

问题

这很好用,除了当滚动到滚动视图中的卡片时,其他卡片似乎被翻转了。例如,我翻转集合视图中的第一张卡片(索引:0)。这翻转很好。我向下滚动,索引 9 的单元格出现翻转。

我试过的

我环顾四周,虽然我可以看到很多与 UICollectionView 和滚动有关的问题,但我无法弄清楚哪些是相同的,哪些不是。我还使用 NSLog 来确定是否已通过程序选择并翻转了随机翻转的视图卡,但它们没有。他们只是看起来。

我真的坚持这个想法。有人有什么想法吗?是因为我创建细胞的方式吗?在我的 viewDidLoad 中,我正在使用:(其中 cellImage 是我的单元格自定义类)

[self.collectionView registerClass:[cellImage class] forCellWithReuseIdentifier:@"MY_CELL"];

在我的 cellForItemAtIndexPath 中:

- (UICollectionViewCell *)collectionView:(UICollectionView *)cv cellForItemAtIndexPath:(NSIndexPath *)indexPath; {
cellImage *cell = [cv dequeueReusableCellWithReuseIdentifier:@"MY_CELL" forIndexPath:indexPath];
cell.imageView.image = [UIImage imageNamed:[imageArray objectAtIndex:indexPath.item]];
[cell.label addSubview:cell.imageView];
cell.label.backgroundColor = [UIColor whiteColor];
cell.label.layer.borderColor =  [UIColor grayColor].CGColor;
cell.label.layer.borderWidth  = 1.0f;

return cell;
}

有人有什么想法吗?如果您需要更多代码,请给我留言,谢谢!

4

2 回答 2

1

在配置可重用单元 ( cellForItemAtIndexPath) 的方法中,您必须明确设置这两种状态。否则回收的单元格将不会自行更新。

image = isFlipped ? backImage : cardImage;

您应该有一个数据模型,可以可靠地返回阵列中任何卡片的当前翻转状态。

于 2013-09-09T18:23:58.020 回答
0

您可以覆盖- (void)prepareForReuse自定义 UICollectionViewCell 的方法以在重用之前将单元格返回到默认状态。

于 2013-09-09T18:25:37.740 回答