2. scrollToRowAtIndexPath: atScrollPosition: animated:的使用。

问题: UITabelView 使用scrollToRowAtIndexPath: atScrollPosition: animated:时 滚动列表 没有滚动到我们想滚动的位置。

在开发IM 系统时,遇到一个问题。自己发送消息时,聊天信息滚动到最下面,但是有时只滚动一部分,并没有

达到我们想要的效果。为什么有的时候可以有的时候不可以。原来发送消息后,后台会返回一个消息发送成功的

回调,在回调中更新消息的状态,由于scrollToRowAtIndexPath 滚动动画需要一定时间,收到回调更新消息的时候滚动

动画还没有完成,导致的这个问题。

解决方法:在回调用中延迟更新消息的状态。

 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^
{
    //解决单独刷新某一cell,tableView 上下滚动闪的问题
    [UIView performWithoutAnimation:^
    {
        NSInteger row = [weakSelf.messageArray indexOfObject:tempModel];
        NSIndexPath* indexPath = [NSIndexPath indexPathForRow:row  inSection:0];
        [weakSelf.chatTable reloadRowsAtIndexPaths: [NSArray arrayWithObjects:indexPath,nil]  withRowAnimation:UITableViewRowAnimationNone];
     }];
});

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值