UIImageView图片加载的几种方式

UIImageView图片加载很常用...所以我们需要每个人都熟练掌握网络图片加载的方式和用法.....其实我说这些都是废话,但是** 大碗 **入场之前一般都有一段开场,小编在此装一下逼不过分....希望大家理解,,
废话不多说,,,,大家往下看

1、NSURLSessionDataTask
- (IBAction)dataTask:(UIButton *)sender {
    //1 准备url
    NSURL *url =[NSURL URLWithString:IMG_URL];
    //2 准备Session
    NSURLSession *session = [NSURLSession sharedSession];
    //3 准备会话
    NSURLSessionDataTask *task = [session dataTaskWithURL:url completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
        UIImage *image = [UIImage imageWithData:data];
        //在主线程刷新
        dispatch_async(dispatch_get_main_queue(), ^{
            self.aImageView.image = image;
        });
    }];
    [task resume];//执行
}
2、NSURLSessionDownloadTask
- (IBAction)downLoad:(UIButton *)sender {
    //准备URL
    NSURL *url = [NSURL URLWithString:IMG_URL];
    //准备Session
    NSURLSession *session =[NSURLSession sharedSession];
    //创建会话
    NSURLSessionDownloadTask *downLoadTask =[session downloadTaskWithURL:url completionHandler:^(NSURL * _Nullable location, NSURLResponse * _Nullable response, NSError * _Nullable error) {
        //打印临时文件
        NSLog(@"临时文件:%@",location);
        
        //根据下载存放到的本地路径的文件来创建data对象
        NSData *tempData = [NSData dataWithContentsOfURL:location];
        UIImage *image =[UIImage imageWithData:tempData];
        //刷新UI
        dispatch_async(dispatch_get_main_queue(), ^{
            self.aImageView.image = image;
        });
    }];
    //启动任务
    [downLoadTask resume];
    //打印临时文件夹
    NSString *temp = NSTemporaryDirectory();
    NSLog(@"%@",temp);
}

小伙伴们看了以上内容此时你是什么心情呢? 不要激动~~~~~~精彩的还在后面呢!下面见哥赠送一份 由于本人从小学开始就死了语文老师,,,如有错误 还请谅解 咱们继续。

3、封装Delegate 方法对UIImageView图片加载
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
@protocol ImageDownLoadDelegate <NSObject>
//图片加载完成之后代理对象执行此方法 将解析好的图片传出去
//@param image 下载完的图片对象
-(void)imageDownLoadFanishLoadingImage:(nonnull UIImage *)image;
@end

@interface ImageDownLoad : NSObject
//这是一个封装下载图片的方法 urlString 网址字符串 delegate 将图片传送出去的对象
+(void)downLoadImageWithURLString:(nonnull NSString *)urlString delegate:(nonnull id<ImageDownLoadDelegate>)delegate;
@end

.m中实现+(void)downLoadImageWithURLString:(nonnull NSString *)urlString delegate:(nonnull id<ImageDownLoadDelegate>)delegate;方法

#import "ImageDownLoad.h"

@implementation ImageDownLoad
+(void)downLoadImageWithURLString:(nonnull NSString *)urlString delegate:(nonnull id<ImageDownLoadDelegate>)delegate{
    //准备URL
    NSURL *url =[NSURL URLWithString:urlString];
    //准备Session对象
    NSURLSession *session =[NSURLSession sharedSession];
    //创建下载对象
    NSURLSessionDownloadTask *downLoadTask = [session downloadTaskWithURL:url completionHandler:^(NSURL * _Nullable location, NSURLResponse * _Nullable response, NSError * _Nullable error) {
        //获取图片对象
        UIImage *image =[UIImage imageWithData:[NSData dataWithContentsOfURL:location]];
        if (delegate != nil && [delegate respondsToSelector:@selector(imageDownLoadFanishLoadingImage:)]) {
            //让代理在主线程内执行图片的方法 确保UI正常显示
            dispatch_async(dispatch_get_main_queue(), ^{
            [delegate imageDownLoadFanishLoadingImage:image];
        });
        }
    }];
    //执行任务
    [downLoadTask resume];
}

ViewController.m中进行调用

- (IBAction)delegate:(UIButton *)sender {
    NSLog(@"delegate");
    [ImageDownLoad downLoadImageWithURLString:IMG_URL delegate:self];  //类调用
}

实现协议里面的方法-----

-(void)imageDownLoadFanishLoadingImage:(UIImage *)image{
    self.aImageView.image = image;
}

见哥是一个肤浅的人,,,, 嘿嘿 ....所以写出来的东西都是都很容易接受,,,,这还是局废话 咱们继续

3、封装Block 方法对UIImageView图片加载
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
//这是一个能够传递image对象的Block image是解析完成的image对象 用于回调
typedef void(^ImageDownLoadBlock)(UIImage *__nonnull image);

@interface ImageDownLoad : NSObject
//这是一个封装的解析图片的方法 使用Block经值传出去 能够传递image对象的回调函数urlString网址字符串
+(void)downLoadImageWithURLString:(nonnull NSString *)urlString andBlock:(ImageDownLoadBlock __nonnull)block;
@end

.m实现部分

+(void)downLoadImageWithURLString:(nonnull NSString *)urlString andBlock:(ImageDownLoadBlock __nonnull)block{
    
    NSString *hesderString = [urlString substringToIndex:4];
    if ([hesderString isEqualToString:@"http"]) {
        NSURLSession *session =[NSURLSession sharedSession];
        NSURLSessionDownloadTask *task = [session downloadTaskWithURL:[NSURL URLWithString:urlString] completionHandler:^(NSURL * _Nullable location, NSURLResponse * _Nullable response, NSError * _Nullable error) {
            UIImage *image  =[UIImage imageWithData:[NSData dataWithContentsOfURL:location]];
            dispatch_async(dispatch_get_main_queue(), ^{
                //使用Block将值传递出去
                block(image);
            });
        }];
        [task resume];
    }else{
        //抛出异常
        @throw [NSException exceptionWithName:@"ImageDownLoad Error" reason:@"Your urlString mayBe an Illegal string" userInfo:nil];
    }
}

ViewVontroller.m调用

- (IBAction)block:(UIButton *)sender {
    NSLog(@"block");
    [ImageDownLoad downLoadImageWithURLString:IMG_URL andBlock:^(UIImage * _Nonnull image) {
        self.aImageView.image = image;
    }];
}

下面介绍完最后一种方法之后,睡觉 ,昨天失眠 做梦梦见自己结婚 激动之下醒了 然后就没有结果了。。。。。

5、SDWebImage 第三方

导入头文件import "UIImageView+WebCache.h" 一行代码搞定 一下是其中几种方法 供参考

    [cell.imageView sd_setImageWithURL:<#(NSURL *)#> placeholderImage:<#(UIImage *)#>]
    [cell.imageView sd_setImageWithURL:<#(NSURL *)#> placeholderImage:<#(UIImage *)#> completed:<#^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL)completedBlock#>]
    [cell.imageView sd_setImageWithURL:<#(NSURL *)#> placeholderImage:<#(UIImage *)#> options:<#(SDWebImageOptions)#>]
    [cell.imageView sd_setImageWithURL:<#(NSURL *)#> placeholderImage:<#(UIImage *)#> options:<#(SDWebImageOptions)#> completed:<#^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL)completedBlock#>]
    [cell.imageView sd_setImageWithURL:<#(NSURL *)#> placeholderImage:<#(UIImage *)#> options:<#(SDWebImageOptions)#> progress:<#^(NSInteger receivedSize, NSInteger expectedSize)progressBlock#> completed:<#^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL)completedBlock#>]
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容

  • 218.241.181.202 wxhl60 123456 192.168.10.253 wxhl66 wxhl6...
    CYC666阅读 1,357评论 0 6
  • 抬头望着头上灰蒙蒙的天空,猛吸一口气,不同于青草和湿润的气息,这里的空气凌冽而干燥。 故乡的天总是蓝的,记忆中...
    青和临曦阅读 259评论 0 0
  • 依然记得高中同学问你最想去的大学是哪,当时很随意的说复旦大学。是的,那时候年少轻狂,却是我内心真正的想法。大学,没...
    二二二二二宁阅读 349评论 1 3
  • - (BOOL)textView:(UITextView *)textView shouldChangeTextI...
    iOS乐乐阅读 88评论 0 1