图片缓存下载

作者: 打电话记错号码的人 | 来源:发表于2016-09-21 09:16 被阅读76次

作品链接:
http://www.jianshu.com/users/1e0f5e6f73f6/top_articles

  • 1.自定义NSOperation下载图片思路 – 无沙盒缓存
   1.根据图片的url去images中取图片,存在,将图片显示到cell上
   2.如果不存在,显示占位符
   3.根据图片的url查看operations中存不存在下载操作,存在下载
   4.不存在,创建下载操作放到operations中
   5.下载完毕,保存沙盒,将操作从operations中移除,将图片放入images中
   6.刷新表格
   
  • 2.自定义NSOperation下载图片思路 – 有沙盒缓存
 1.根据图片的url去images中取图片,存在,将图片显示到cell上
 2.如果不存在,检查沙盒中存不存在对应的图片,存在,将图片显示到cell上
 3.如果不存在,显示占位符
 4.根据图片的url查看operations中存不存在下载操作,存在下载
 5.不存在,创建下载操作放到operations中
 6.下载完毕,保存沙盒,将操作从operations中移除,将图片放入images中
 7.刷新表格
  • 3.有沙盒缓存代码实现
PHAPP *app = self.apps[indexPath.row];
UIImage *image = [self.images objectForKey:app.icon];
    if (image) {
        cell.imageView.image = image;
    }else
    {
        //缓存路径  搜索路径 YES 能完整展开路径
        NSString *caches = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];
        
        //文件名
        NSString *fileName = [app.icon lastPathComponent];
        
        //拼接文件全路径
        NSString *fullPtah = [caches stringByAppendingPathComponent:fileName];
//        NSLog(@"%@",fullPtah);
        
        NSData *data = [NSData dataWithContentsOfFile:fullPtah];
        data = nil; // 沙盒缓存为空
        if (data) {
            UIImage *image = [UIImage imageWithData:data];
             cell.imageView.image = image;
            //保存到内存缓存  写入字典
            [self.images setObject:image forKey:app.icon];
        }else
        {
            // 占位图片
            cell.imageView.image = [UIImage imageNamed:@"占位图片"];
            // 操作缓存 如果图片在操作缓存,就不用下载了
            NSBlockOperation *op = self.operations[app.icon];
            if (op == nil) {
                NSBlockOperation *download = [NSBlockOperation blockOperationWithBlock:^{
                    NSURL *url = [NSURL URLWithString:app.icon];
                    NSData *data = [NSData dataWithContentsOfURL:url];
                    
                    if (data == nil) { // 容错性 data没有值移除返回
                        [self.operations removeObjectForKey:app.icon];
                        return ;
                    }
                    UIImage *image = [UIImage imageWithData:data];
                    
                    [NSThread sleepForTimeInterval:2.0];
                    
                    //保存到内存缓存  写入字典
                    [self.images setObject:image forKey:app.icon];
                    
                    NSLog(@"%zd",indexPath.row);
                    
                    //保存到沙盒
                    [data writeToFile:fullPtah atomically:YES];

                   // 回到主线程,刷新UI界面
                    [[NSOperationQueue mainQueue]addOperationWithBlock:^{
                       // cell.imageView.image = image;
                        // 刷新选中图片的那一行
                        [tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationNone];
                    }];
                    
                     [self.operations removeObjectForKey:app.icon];
                }];
                
                [self.queue addOperation:download];
                //操作缓存
                self.operations[app.icon] = download;
            }
        }
    }



相关文章

  • 多线程03

    SDWebImage框架详解 下载图片并显示: 下载图片/显示图片/内存缓存/磁盘缓存 下载图片\内存缓存\磁盘缓...

  • SDWebImage框架的基本使用

    基本使用 1)下载图片并显示(内存缓存&磁盘缓存) 2)下载图片显示并计算下载进度(内存缓存&磁盘缓存&下载进度)...

  • iOS中SDWebImage框架浅析

    下载图片并显示 下载图片并计算下载进度 使用SDWebImageManager单例下载 同时做内存缓存和图片缓存可...

  • 架构&框架

    图片缓存 怎样设计一个图片缓存框架 图片管理者模块:内存缓存模块、磁盘缓存模块、网络图片下载模块 图片处理:图片解...

  • iOS多图片下载

    iOS多图片下载、在cell里面下载图片、做了缓存优化。 (app.icon是图片地址) // 先从内存缓存中取出...

  • iOS多图下载案例(二)

    利用缓存优化后 //UI很不流畅-》开子线程下载//图片重复下载-》缓存//内存缓存-》磁盘缓存//documen...

  • SDWebImage不缓存图片和不播放Gif

    不缓存图片问题: 使用SDWebImageManager的downloadImage函数下载图片时不缓存图片到沙盒...

  • 图片下载缓存思路

    自定义NSOperation下载图片思路 – 无沙盒缓存 自定义NSOperation下载图片思路 – 有沙盒缓存

  • SDImageCache

    SDImageCache提供了对图片的内存缓存、异步磁盘缓存、图片缓存查询等功能,下载过的图片会被缓存到内存,也可...

  • SDWebImage实现图片展示、缓存、清除缓存

    1.图片显示 2.图片缓存 3.检测缓存照片 4.清理图片缓存 5.下载路径与原理:

网友评论

    本文标题:图片缓存下载

    本文链接:https://www.haomeiwen.com/subject/coxaettx.html