以编程方式将按钮添加到集合视图单元

时间:2013-04-04 20:52:59

标签: ios objective-c xcode uicollectionview uicollectionviewcell

我在Xcode 4.6中有一个应用程序。在一个视图控制器中,我有一个集合视图。通过用户与视图的交互将单元格添加到视图中。这很好用。然后我想为每个单元格添加一个按钮(以编程方式),允许删除单元格。我希望按钮位于每个单元格的右上角。问题是按钮出现在集合视图第一行中所有单元格的每个单元格内的所需位置(同样,右上角),但随后出现在第一行之后所有单元格的单元格之外。见下图:enter image description here

我的按钮创建方法是:

-(CollectionViewCellButton *)makeDeleteButtonForCell:(UICollectionViewCell *)cell
{
  CollectionViewCellButton *button = [CollectionViewCellButton buttonWithType:UIButtonTypeCustom];
  CGSize newImageSize = CGSizeMake(cell.frame.size.width/2.5, cell.frame.size.height/2.5);
  UIImage *image = [SeeYourAlbumViewController imageWithImage:[UIImage imageNamed:@"delete"] scaledToSize:newImageSize];

  CGFloat width = image.size.width;
  CGFloat height = image.size.height;
  CGFloat X = cell.frame.size.width - width;
  CGFloat Y = cell.frame.origin.y;

  button.frame = CGRectMake(X, Y, width, height);
  [button setImage:image forState:UIControlStateNormal];
  [button addTarget:self
           action:@selector(deleteCollectionViewCell:)
   forControlEvents:UIControlEventTouchUpInside];

  return button;

}

在我的单元格创建方法中调用上述方法如下:

-(UICollectionViewCell *)collectionView:(UICollectionView *)collectionView
             cellForItemAtIndexPath:(NSIndexPath *)indexPath
{
  UICollectionViewCell *cell = [collectionView
                              dequeueReusableCellWithReuseIdentifier:@"newCell"
                              forIndexPath:indexPath];

  //CALLED HERE!!
  CollectionViewCellButton *cellButton = [self makeDeleteButtonForCell:cell]; 

  cellButton.indexPath = indexPath;
  [cell addSubview:[self.pictures objectAtIndex:indexPath.row]]; 
  [cell addSubview:cellButton];

  return cell;
}

任何人都可以提出我可能做错的建议吗?

1 个答案:

答案 0 :(得分:1)

该按钮被添加为单元格的子视图。它应该使用单元格的坐标系(边界)而不是单元格的超视图(框架)的坐标系。在您的情况下,因为按钮位于单元格集的顶部

CGFloat Y = 0;