更新3: 问题 加载慢!
(一时间给的处理负载过大,要分散)在下载图片,判断状态后 对每个cell对图片灰置图片处理保存,影响了主线程的操作
:上拉加载时,无法上下滑动tableview 无法点击cell
: 去除对每一个图片对灰置保存,只保存彩色,在需要灰色时在灰置,
    需求: 类似QQ列表的头像加载刷新,判断在线离线状态改变头像,以及彩色头像灰色处理,下载图片+获取在线状态需要连网--再改变头像
问题:由于cell的复用以及下拉刷新数据每次加载10条数据,会出现头像赋值不正确,位置偏移大小不同的变化
原因:由于cell的重复调用,加载数据方法已经赋值方法也在重复的调用,所以头像加载 在线状态判断好后,网络延迟,
(个人开始yy:启动时的cell和赋值结束的cell可能不是同一个)
修改:当cell开始调用的时候,给当前的cell赋tag值,加载结束判断是不是自己的tag:不是了跳过是了赋值。反正可以解决问题 避免头像的重复加载,更换:由于每次进来都要重新加载一组新的头像,并没有做本地化处理;
此处理会影响主线程操作:在控制器中添加一个可变的字典dict ; dict= {@"0":image,@"1":image,@"2":image,@"3":@"default",@"lasttime":@"0/1/2"}
0是离线的image;1在线;2忙碌;3有值(使用默认头像,不存入字典);lasttime 记录上一次的状态,刷新时首先显示上一次的状态值,刷新状态后:对比上一次,
如果和上一次不一样了在更换;
//头像灰化处理
//置灰
+(UIImage*)createGrayCopy:(UIImage*)source{
int width = source.size.width;
int height = source.size.height;
CGColorSpaceRef colorSpace =CGColorSpaceCreateDeviceGray();
CGContextRef context =CGBitmapContextCreate(nil,
width,
height,
,// bits per component
,
colorSpace,
kCGBitmapByteOrderDefault);
CGColorSpaceRelease(colorSpace);
if(context ==NULL) {
return nil;
}
CGContextDrawImage(context,
CGRectMake(,, width, height), source.CGImage);
UIImage*grayImage = [UIImage imageWithCGImage:CGBitmapContextCreateImage(context)];
CGContextRelease(context);
return grayImage;
}

  //下载图片
//根据uid 取出相应的字典
NSMutableDictionary * dicc = arrayAllImage[model.uid];
//判断是否保存过图片
if (dicc[@""]) {
//之前保存过值
cell.imageview.image = dicc[@""]; if ([dicc[lasttime] isEqualToString:@""]) {
cell.busyOr.hidden = NO; }else{
cell.busyOr.hidden = YES; } }else{ //没有的话 下载 保存,设置在线状态 0离线灰色头像 1在线2忙碌彩色头像
if ([model.status isEqualToString:@""]) {
[cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:[UIImage imageNamed:HeadPortraitDoctor]]; dicc =[NSMutableDictionary dictionary]; [dicc setObject:cell.imageview.image forKey:@""]; [dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid]; cell.busyOr.hidden = YES;//隐藏 忙碌状态
}
else if([model.status isEqualToString:@""]){ [cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:nil];
//不在线
cell.busyOr.hidden = YES; dicc =[NSMutableDictionary dictionary];
if (cell.imageview.image) { cell.imageview.image = [UIImage createGrayCopy:cell.imageview.image];
}else{ cell.imageview.image = graimage;
[dicc setObject:graimage forKey:@""];
} [dicc setObject:cell.imageview.image forKey:@""];
[dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid]; }
else if([model.status isEqualToString:@""]){
//忙碌
[cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:[UIImage imageNamed:HeadPortraitDoctor]]; dicc =[NSMutableDictionary dictionary];
[dicc setObject:cell.imageview.image forKey:@""];
[dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid];
cell.busyOr.hidden = NO;
} } if(!ScrollerYesNo){
//给图片标记
cell.imageview.tag = indexPath.row+; [[GetUrlSession shareUrlconnection]connetion:[NSString stringWithFormat:@"%@?uid=%@&port=%@",searchOnlineStatusGet,model.uid,model.port] Haget:^(NSDictionary *data, NSError *error, NSHTTPURLResponse *response) { NSString* onlineStatue = [NSString stringWithFormat:@"%@",data[@"status"]]; dispatch_async(dispatch_get_main_queue(), ^{ NSMutableDictionary * diccc = [NSMutableDictionary dictionary];
[diccc setDictionary: arrayAllImage[model.uid]]; //判断当前的状态。 以及是否上一次的状态值
if ([onlineStatue isEqualToString:@""] && ![onlineStatue isEqualToString:diccc[lasttime]]) { UIImageView *lastImageView = [self.view viewWithTag:indexPath.row+]; if (![lastImageView isEqual:cell.imageview]) { return ;
} //在线
[cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:[UIImage imageNamed:HeadPortraitDoctor]]; [dicc setObject:cell.imageview.image forKey:@""]; [dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid]; cell.busyOr.hidden = YES;
}else if([onlineStatue isEqualToString:@""] && ![onlineStatue isEqualToString:diccc[lasttime]]){
//不在线
cell.busyOr.hidden = YES; UIImageView *lastImageView = [self.view viewWithTag:indexPath.row+]; if (![lastImageView isEqual:cell.imageview]) { return ;
} [cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:nil];
if (cell.imageView.image) {
cell.imageview.image = [UIImage createGrayCopy:cell.imageview.image];
}else{
cell.imageview.image = graimage;
}
[dicc setObject:cell.imageview.image forKey:@""];
[dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid]; }
else if([onlineStatue isEqualToString:@""] && ![onlineStatue isEqualToString:diccc[lasttime]] ){
//忙碌 UIImageView *lastImageView = [self.view viewWithTag:indexPath.row+]; if (![lastImageView isEqual:cell.imageview]) { return ;
} //在线
[cell.imageview sd_setImageWithURL:[NSURL URLWithString:model.headimage] placeholderImage:[UIImage imageNamed:HeadPortraitDoctor]];
[dicc setObject:cell.imageview.image forKey:@""];
[dicc setObject:@"" forKey:lasttime];
[arrayAllImage setObject:dicc forKey:model.uid];
cell.busyOr.hidden = NO;
} }); }]; }

iOS tableViewCell 在cell赋值、网络加载照片位置偏移大小错乱,做一个类似qq列表的tableview 更新3的更多相关文章

  1. IOS空数据页面,网络加载失败以及重新登陆View的封装(不需要继承)

    一.问题 对于B2C和B2B项目的开发者,可能会有一个订单列表为空,或者其他收藏页面为空,用户token失效,判断用户要重新登陆,以及后台服务错误等提示.本篇课文,看完大约10分钟. 原本自己不想写空 ...

  2. [置顶] iOS学习笔记47——图片异步加载之EGOImageLoading

    上次在<iOS学习笔记46——图片异步加载之SDWebImage>中介绍过一个开源的图片异步加载库,今天来介绍另外一个功能类似的EGOImageLoading,看名字知道,之前的一篇学习笔 ...

  3. SwiftUI - 一步一步教你使用UIViewRepresentable封装网络加载视图(UIActivityIndicatorView)

    概述 网络加载视图,在一个联网的APP上可以讲得上是必须要的组件,在SwiftUI中它并没有提供如 UIKit 中的UIActivityIndicatorView直接提供给我们调用,但是我们可以通过 ...

  4. iOS网络加载图片缓存与SDWebImage

    加载网络图片可以说是网络应用中必备的.如果单纯的去下载图片,而不去做多线程.缓存等技术去优化,加载图片时的效果与用户体验就会很差. 一.自己实现加载图片的方法 tips: *iOS中所有网络访问都是异 ...

  5. iOS网络加载图片缓存策略之ASIDownloadCache缓存优化

    iOS网络加载图片缓存策略之ASIDownloadCache缓存优化   在我们实际工程中,很多情况需要从网络上加载图片,然后将图片在imageview中显示出来,但每次都要从网络上请求,会严重影响用 ...

  6. iOS最笨的办法实现无限轮播图(网络加载)

    iOS最笨的办法实现无限轮播图(网络加载) 简单的做了一下: 使用方法: 把 请求返回的 图片地址(字符串类型)放进数组中就行 可以使用SDWebImage(我就是用的这个)等..需要自己导入并引用, ...

  7. iOS简单音乐实现、React-Native完整项目、仿闲鱼京东列表分页、语音识别、网络加载过度动画等源码

    iOS精选源码 iOS快速入手语音识别.听写.评测.播报 网络加载数据的过渡动画(仿简书网页) iOS 封装跑马灯和轮播效果 crash防护组件,适用常见常用的数组,字典等crash保护 iOS:高仿 ...

  8. ios -网络加载json和本地加载json

    1网络加载json的时候,要在模型的实现文件里写: - (void)setValue:(id)value forKey:(NSString *)key { } 2本地加载json的时候,要在模型的实现 ...

  9. android快捷开发之Retrofit网络加载框架的简单使用

    大家都知道,安卓最大的特点就是开源化,这自然会产生很多十分好用的第三方API,而基本每一个APP都会与网络操作和缓存处理机制打交道,当然,你可以自己通过HttpUrlConnection再通过返回数据 ...

随机推荐

  1. 说说css中pt、px、em、rem都扮演了什么角色

    前段时间,终于仔仔细细的把pt.px.em.rem了解了一遍,简单整理了一下做个记录. pt.px.em.rem都是什么 pt单位名称为点(Point),绝对长度单位.现在网页中出现得很少甚至不出现, ...

  2. 利用VGG19实现火灾分类(附tensorflow代码及训练集)

    源码地址 https://github.com/stephen-v/tensorflow_vgg_classify 1. VGG介绍 1.1. VGG模型结构 1.2. VGG19架构 2. 用Ten ...

  3. get和post请求及函数调用模式

    1.get和post请求的应用场景? get: 1.get请求获取(查询)数据 2.请求url长度比较短 3.可以被缓存 4.请求url可以作为浏览器书签 5.可以被保存在浏览器记录中 6.请求参数在 ...

  4. 《java.util.concurrent 包源码阅读》14 线程池系列之ScheduledThreadPoolExecutor 第一部分

    ScheduledThreadPoolExecutor是ThreadPoolExecutor的子类,同时实现了ScheduledExecutorService接口. public class Sche ...

  5. mssql执行计划查看的一些知识

    在MSSQL中,查看较慢语句的执行计划,就是一个比较直观的方式, 如果查看执行计划呢: 1.从右到左,从上到下的顺序阅读执行计划2.执行计划中每个图标代表一个运算符,总开销为100%3.数据从右向左在 ...

  6. 显示mysql线程和kill线程的命令

    show processlist;//显示哪些线程正在运行. kill id //kill线程   通常在表被锁的时候用.   show processlist;显示哪些线程正在运行.您也可以使用my ...

  7. PHP随手记1--内置函数date

    1. date_default_timezone_set date_default_timezone_set — 设定用于一个脚本中所有日期时间函数的默认时区 在php中只用 mktime() 函数时 ...

  8. linux安装redis(转)

    一.Redis介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多 ...

  9. 探究PHP底层

    探究PHP底层 1.PHP是什么?   PHP 指的是我们从外面看到的一套完整的系统.这听起来有点糊涂,但其实并不复杂(PHP4 内部结构图).从功能上来分:我们可以分为三部分: 1. 解释器部分(Z ...

  10. oracle和mysql几点差异对比

    Oracle与mysql差异性总结 之前有个项目是用oracle数据库进行开发,需要把数据库改成mysql,遇到了一些地方需要注意的,就简单记了下来. 备注: 再把oracle转成mysql的时候,表 ...