UITableVewCell的移动删除

本文介绍了一个自定义UITableViewCell类实现侧滑删除功能的方法。通过添加长按手势并根据手势状态进行不同操作,如开始时旋转cell,移动过程中捕获快照,结束时根据坐标值决定是否触发删除回调。

如何实现UITableViewCell的侧滑删除功能呢?很简单的思路

给cell添加一个长按手势,然后根据手势的状态,在开始的时候给旋转三十度

在移动过程中,捕获快照

在结束的时候判断坐标值,给VIewController发一个删除cell的回调,同时TableView reloadData就可以了

@interface CustomTableViewCell ()
{
    UIView *snapView;
}
@end

@implementation CustomTableViewCell

- (void)awakeFromNib {
    _containerView.layer.cornerRadius=4;
    
    _shadowView.layer.shadowColor=[UIColor blackColor].CGColor;
    _shadowView.layer.shadowOffset=CGSizeMake(2, 2);
    _shadowView.layer.shadowOpacity=0.5;
    _shadowView.layer.shadowRadius=5;
    
    UILongPressGestureRecognizer *longPress = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(handleLongpressGesture:)];
    [self.contentView addGestureRecognizer:longPress];

}

- (void)handleLongpressGesture:(UILongPressGestureRecognizer *)gesture
{
    
    CGPoint startPoint = CGPointZero;
    switch (gesture.state) {
        case UIGestureRecognizerStateBegan:
        {
            snapView = [_containerView snapshotViewAfterScreenUpdates:NO];
            startPoint = [gesture locationInView:self.contentView];
            //重设layer锚点
            snapView.layer.anchorPoint = CGPointMake(startPoint.x/snapView.layer.frame.size.width-0.1, startPoint.y/snapView.layer.frame.size.height-0.1);
            snapView.frame = _containerView.frame;
            snapView.transform = CGAffineTransformMakeRotation(M_PI/30);
            [self.contentView addSubview:snapView];
             self.containerView.hidden = YES;
            self.shadowView.hidden = YES;
            break;
        }
        case UIGestureRecognizerStateChanged:
        {
            CGPoint changePoint = [gesture locationInView:self.contentView];
            [UIView animateWithDuration:0.05 animations:^{
                snapView.layer.position = changePoint;
            }];
            break;
        }
        case UIGestureRecognizerStateEnded:
        {
            NSLog(@"ended");
            CGPoint endPoint = [gesture locationInView:self.contentView];
            if (endPoint.x>self.contentView.bounds.size.width-50) {
                if (self.cellBlock) {
                    self.cellBlock(YES, _cellIndex);
                }
            }else
            {
                if (self.cellBlock) {
                    self.cellBlock(NO, _cellIndex);
                }
            }
            [snapView removeFromSuperview];
            self.containerView.hidden = NO;
            self.shadowView.hidden = NO;
            
            
            break;
        }
        default:
            break;
    }
}


ViewController

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    CustomTableViewCell *cell = (CustomTableViewCell *)[tableView dequeueReusableCellWithIdentifier:@"customCell"];
    cell.cellIndex = indexPath;
    cell.cellBlock = ^(BOOL isDelete, NSIndexPath *index){
        if (isDelete) {
            
            [_mTableView beginUpdates];
            rowCount--;
            [_mTableView deleteRowsAtIndexPaths:@[index] withRowAnimation:UITableViewRowAnimationRight];
            [_mTableView endUpdates];
            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
                [_mTableView reloadData];
            });
           
        }
    };
    cell.selectionStyle = UITableViewCellSelectionStyleNone;
    return cell;
}

运行结果


【EI复现】基于主从博弈的新型城镇配电系统产消者竞价策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于主从博弈理论的新型城镇配电系统中产消者竞价策略的研究,结合IEEE33节点系统,利用Matlab进行仿真代码实现。该研究聚焦于电力市场环境下产消者(既生产又消费电能的主体)之间的博弈行为建模,通过构建主从博弈模型优化竞价策略,提升配电系统运行效率与经济性。文中详细阐述了模型构建思路、优化算法设计及Matlab代码实现过程,旨在复现高水平期刊(EI收录)研究成果,适用于电力系统优化、能源互联网及需求响应等领域。; 适合人群:具备电力系统基础知识和一定Matlab编程能力的研究生、科研人员及从事能源系统优化工作的工程技术人员;尤其适合致力于电力市场博弈、分布式能源调度等方向的研究者。; 使用场景及目标:① 掌握主从博弈在电力系统产消者竞价中的建模方法;② 学习Matlab在电力系统优化仿真中的实际应用技巧;③ 复现EI级别论文成果,支撑学术研究或项目开发;④ 深入理解配电系统中分布式能源参与市场交易的决策机制。; 阅读建议:建议读者结合IEEE33节点标准系统数据,逐步调试Matlab代码,理解博弈模型的变量设置、目标函数构建与求解流程;同时可扩展研究不同市场机制或引入不确定性因素以增强模型实用性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值