前言:
在IOS下通过URL读一张网络图片并不像Asp.net那样可以直接把图片路径放到图片路径的位置就ok,
而是需要我们通过一段类似流的方式去加载网络图片,接着才能把图片放入图片路径显示。
这里找了一段代码是用来加载图片:
-(UIImage *) getImageFromURL:(NSString *)fileURL {
//NSLog(@"执行图片下载函数");
UIImage * result;
NSData * data = [NSData dataWithContentsOfURL:[NSURL URLWithString:fileURL]];
result = [UIImage imageWithData:data];
return result;
}
通过这个方法处理后可以得到一个UIImage,这样就可以放入UI界面的UIImageView了。
/*-----------------------------------------------切入主题-----------------------------------------------*/
在APP开发中,加载网络图片中大多是以一连串的形式去加载图片,所以当图片多的话,线程就会卡死= =!
所以,考虑到用户体验,这里需要找一种方法去异步加载图片!
关于图片异步加载这个思路,其实我也不太懂,于是借鉴了网上一个开源的项目SDWebImage去对UIImageView进行扩展,
最终优化网络图片的加载,使之获得两个新特性:
1.多图片异步加载。
2.加载完图片会用一个图片管理器去进行缓存。
其中最重要的一段代码如下:
- (void)setImageWithURL:(NSURL *)url refreshCache:(BOOL)refreshCache placeholderImage:(UIImage *)placeholder
{
// Remove in progress downloader from queue
self.image = placeholder;
if (url)
{
if ([[CustomObject sharedCustomObject] isExistImage:url]) {
NSLog(@"存在图片");
self.image = [[CustomObject sharedCustomObject]getImage:url];
}
else{
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
NSData * data = [[NSData alloc]initWithContentsOfURL:url];
UIImage *image = [[UIImage alloc]initWithData:data];
if (data != nil) {
dispatch_async(dispatch_get_main_queue(), ^{
[[CustomObject sharedCustomObject] addImage:image key:url];
self.image = image;
});
}
});
}
}
}
可以直接传入一个NSURL的图片路径对象对图片进行加载,若加载不为空则把图片缓存放入图片管理器单例保存起来,下一次再调用这个方式时会判断URL是否存在去读缓存。
这样异步加载,缓存图片的任务就完成了。
实例源码可以戳这里。OK。
主动用心,工作努力,坚持学习,坦诚分享,正面乐观,心存感恩