iOS - SDWebImage的简单使用

LOGO
前言:在我们日常的开发中我们通常会使用SDWebImage来实现UIImageView加载来自互联网的远程图片
官方介绍:一个具有缓存支持的异步映像下载程序
关键词:缓存、异步
一:SDWebImage安装说明:

安装方式两种
1、直接cocoapods安装 在文件夹生成的podfile文件中添加pod 'SDWebImage' 终端cd + 文件位置 然后pod install即可.
2、直接下载SDWebImage,然后将文件夹拖拽到本地项目即可.
SDWebImage的github:https://github.com/rs/SDWebImage

二:功能简介

1、一个添加了web图片加载和缓存管理的UIImageView分类
2、一个异步图片下载器
3、一个异步的内存加磁盘综合存储图片并且自动处理过期图片
4、支持动态gif图
5、支持webP格式的图片
6、后台图片解压处理
7、确保同样的图片url不会下载多次
8、确保伪造的图片url不会重复尝试下载
9、确保主线程不会阻塞

三:SDWebImage实现缓存的步骤
图片来自https://blog.csdn.net/larryluoshuai/article/details/68061592

1、当我们需要获取网络图片的时候,我们首先需要的便是URL,获得URL后我们SDWebImage实现的并不是直接去请求网路,而是检查图片缓存中有没有和URl相关的图片,如果有则直接返回image,如果没有则进行下一步。
2、当图片缓存中没有图片时,SDWebImage依旧不会直从网络上获取,而是检查沙盒中是否存在图片,如果存在,则把沙盒中对应的图片存进image缓存中,然后按着第一步的判断进行。
3、如果沙盒中也不存在,则显示占位图,然后根据图片的下载队列缓存判断是否正在下载,如果下载则等待,避免二次下载。如果不存则创建下载队列,下载完毕后将下载操作从队列中清除,并且将image存入图片缓存中。!
4、刷新UI(当然根据实际情况操作)将image存入沙盒缓存。

四:SDWebImage基本使用

1、下载图片并显示(内存缓存&磁盘缓存)

1、下载图片并显示(内存缓存&磁盘缓存)
/*
     第一个参数:图片的url地址
     第二个参数:设置的占位图片
     */
    [self.headIcon sd_setImageWithURL:[NSURL URLWithString:topicItem.profile_image] 
                    placeholderImage:[[UIImage imageNamed:@"defaultUserIcon"] circleImage] 
                    completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
        self.headIcon.image = [image circleImage] ;
    }] ;

2、下载图片显示并计算下载进度(内存缓存&磁盘缓存&下载进度)

    -(void)download
    {        /*
         第一个参数:图片的url地址
         第二个参数:设置的占位图片
         第三个参数:下载图片选项(策略)
         第四个参数:进度回调block
            receivedSize:已经下载的数据大小
            expectedSize:图片的总大小
         第五个参数:completed图片下载结束回调(成功|失败)
            image:下载后得到的图片,如果下载失败,那么image的值为nil
            error:错误信息,如果失败,则error有值
            cacheType:图片来源(枚举:内存缓存|磁盘缓存|直接下载)
            imageURL:下载图片的url
         */
    
[self.imageView sd_setImageWithURL:[NSURL URLWithString:topicItem.gifFistFrame] placeholderImage:[UIImage imageNamed:@"imageBackground"] options:SDWebImageProgressiveLoad progress:^(NSInteger receivedSize, NSInteger expectedSize, NSURL * _Nullable targetURL) {
            if (!expectedSize)  return ;
            
            topicItem.pictureProgress = 1.0 * receivedSize / expectedSize ;
            //进度是在子线程中完成的 所以要回到主线程
            dispatch_async(dispatch_get_main_queue(), ^{
                [self.progressView setProgress:topicItem.pictureProgress animated:YES] ;
            }) ;
            
        } completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
            
//            [self.progressView performAction:M13ProgressViewActionSuccess animated:YES];
            self.progressView.hidden = YES ;
            switch (cacheType) {                
        case SDImageCacheTypeNone:                    
          NSLog(@"直接下载");                    
          break;                
        case SDImageCacheTypeDisk:                    
          NSLog(@"磁盘缓存");                    
          break;                
        case SDImageCacheTypeMemory:                    
          NSLog(@"内存缓存");                    
          break;                
        default:                    
          break;
            }
//            NSLog(@"当前是非WIFI状态下,动图不会自动播放") ;
        }] ;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343