我正在尝试替换单元格的默认编辑模式行为。
我不希望红色圆圈与线左附件视图出现。
进入编辑模式后,我需要它向左移动内容视图&显示我的删除按钮。
到目前为止,我拥有的(自定义UITableViewCell)覆盖:
-(void) setEditing:(BOOL)editing animated:(BOOL)animated
{
/* don't call super */
// [super setEditing:editing animated:animated];
_isEditing = editing;
CGFloat newContentViewX = 0.0f;
UIColor *newDeleteButtonColor = [UIColor clearColor];
if ( _isEditing )
{
newContentViewX = -40.0f;
newDeleteButtonColor = [UIColor redColor];
}
if ( animated )
{
[UIView animateWithDuration:0.5f
delay:0.0f
options:UIViewAnimationOptionCurveEaseInOut
animations:^
{
self.contentView.x = newContentViewX; //change frame.origin.x
_deleteButton.backgroundColor = newDeleteButtonColor;
}
completion:nil];
}
else
{
self.contentView.x = newContentViewX; //change frame.origin.x
_deleteButton.backgroundColor = newDeleteButtonColor;
}
}
-(BOOL) editing
{
return _isEditing;
}&这就是结果:


上面的代码很好用!直到它开始滚动&内容视图被重置。回到第一张图片。编辑标志没有持久化我的内容视图框架更改。
我增加了这一行:
[cell setEditing:_tableView.isEditing animated:NO];在cellForRowAtIndexPath中&尽管它正确地调用和设置了编辑模式,但我的内容视图仍然处于原始位置,而不是更新后的位置。
youtube短片解释问题:Youtube链接
还有人有这个问题吗?
发布于 2013-07-13 02:57:40
您的问题是,UITableView正在使用您从cellForRowAtIndexPath返回的单元格“有益地”设置适当的状态布局。
处理此问题的最简单方法是重写单元格类中的-layoutSubviews。
- (void)layoutSubviews
{
if (self.editing)
{
CGRect bounds = self.bounds;
// do your custom layout
}
else
[super layoutSubviews];
}这应该能解决很多问题。
发布于 2013-07-12 13:29:57
不要篡改内容视图框架。只需创建按钮并将其设置为editingAccessoryView,演示文稿将为您完成。
发布于 2013-12-22 22:31:44
您似乎受到了UITableView如何将setEditting消息传递给其子单元格的副作用。docs声明TV将此消息发送到可见单元格(仅)。因此,当一个新的/退出队列的单元变得可见时,它就没有setEditting消息,因此就有了_editting=NO。因此,您需要在tableView:cellForRowAtIndexPath:_editting=YES中测试和设置单元格的_editting=YES,然后使用所需的delete按钮获得滚动行为。
https://stackoverflow.com/questions/17615996
复制相似问题