TableView_图片异步加载 KVO

TableView 异步下载图片

ImageDownloader.h

#pragma mark - 声明block

//1,声明block

typedef void(^Result) (UIImage *img);

@interface ImageDownloaderViewController : UIViewController

#pragma mark - 声明方法

//block 做参数

//ImageDownloader 允许外界指定URL,提供 开始下载 和 取消下载 功能,并提供delegate或block将图?片传递给外界。

+ (void)imageDownloaderWithUrlStr:(NSString *)urlStr result:(Result)result;

ImageDownloader.m

+ (void)imageDownloaderWithUrlStr:(NSString *)urlStr result:( Result)result

{

NSURL *url = [NSURL URLWithString:urlStr];

NSURLRequest *request = [NSURLRequest requestWithURL:url];

[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue new]autorelease] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {

//把请求的二进制数据 转成图片

UIImage *image = [UIImage imageWithData:data];

//回到主线程调用

dispatch_sync(dispatch_get_main_queue(), ^{

//调用block

result(image);

});

}];

}

TableViewController.m

//加载数据

- (void)loadDataAndShow

{

NSURL *url = [NSURL URLWithString:URL_NEW];

NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];

[request setHTTPMethod:@"GET"];

__block NewsTableViewController *weakSelf = self;

NSOperationQueue *queue = [[NSOperationQueue new] autorelease];

//建立连接,

[NSURLConnection sendAsynchronousRequest:request queue:queue completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {

NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];

//取大字典数据

//从key为result的数组中 取字典

//在此循环完成 即图片赋值完成

for (NSDictionary *dic in dict[@"result"]) {

//创建模型

News *new = [News new];

NSLog(@"模型创建,图片 开始下载");

//此时 图片开始下载

[new setValuesForKeysWithDictionary:dic];

[weakSelf.allDataMutableArray addObject:new];

[new release];

}

//回主线程

dispatch_sync(dispatch_get_main_queue(), ^{

//先刷新UI再拿到图片

[weakSelf.tableView reloadData];

NSLog(@" 刷新UI");

});

}];

}

- (void)didReceiveMemoryWarning {

[super didReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

#warning Incomplete method implementation.

// Return the number of rows in the section.

return _allDataMutableArray.count;

}

//显示Cell

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

{

NSLog(@"  显示 一个 cell");

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"new" forIndexPath:indexPath];

// Configure the cell...

News *new = _allDataMutableArray[indexPath.row];

cell.textLabel.text = new.movieName;

cell.detailTextLabel.text = new.movieId;

//如果图片数据请求下来,就赋值显示。如果没有,就监听

if (new.imageData != nil) {

cell.imageView.image = new.imageData;

}else{

NSLog(@" 图片没请求下来---》》》监听 ");

//KVO (1,注册监听)设置监听图片数据

//new 被监听

//self  监听者

//keypath  监听属性

//options   监听旧值 还是 新值

//控制器 观察 -》模型(在控制器中观察)

[new addObserver:self forKeyPath:@"imageData" options:NSKeyValueObservingOptionNew context:indexPath];

}

return cell;

}

#pragma mark - (2,实现回调方法)  KVO 监听被执行的方法,对象属性变化,即调用

//tableView 通过KVO观察 下载数据 及时更新页面

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context

{

//判断标志

if ([keyPath isEqualToString:@"imageData"]) {

//1, 获取新图片数据

UIImage *newImageData = change[NSKeyValueChangeNewKey];

//2, 获取cell

NSIndexPath *indexPath = (NSIndexPath *)context;

UITableViewCell *cell = [self.tableView cellForRowAtIndexPath:indexPath];

cell.imageView.image = newImageData;

//3, 刷新当前行

[self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];

//4,取消监听

[object removeObserver:self forKeyPath:keyPath];

NSLog(@"(监听值变化)拿到图片了。。。。。。");

}

}

//模型.h

@interface News : NSObject

@property(nonatomic,copy)NSString *movieId;

@property(nonatomic,copy)NSString *movieName;

@property(nonatomic,copy)NSString *pic_url;

//Model类注意事项:

//1、除了包含必要的数据外,还要包含?一个ImageDownloader对象。

//2、包含?一个image。

//3、包含?一个图?片是否正在下载的BOOL值。(?用于判断是否需要开始 下载)

@property(nonatomic,retain) UIImage *imageData;

//模型.m

#pragma mark - 重写pic_url 的 setter

//为了能正确显示图片,Model类应该提供图片获取功能(Model通过 ImageDownloader下载图片,供cell使用)

- (void)setPic_url:(NSString *)pic_url

{

if (_pic_url != pic_url) {

[_pic_url release];

_pic_url = [pic_url retain];

//

//使用block 异步加载图片

__block News *weakNews = self;

[ImageDownloaderViewController imageDownloaderWithUrlStr:self.pic_url result:^(UIImage *img) {

//将block 显示到imageView上

//在这使用,就在这实现(模型中实现block)

weakNews.imageData = img;

NSLog(@"--------------拿到图片,赋值显示 NEws");

}];

}

}

时间: 2024-10-06 11:39:18

TableView_图片异步加载 KVO的相关文章

图片异步加载 ,KVO

图片异步下载类目: .h #import <UIKit/UIKit.h> typedef void (^ImageBlock)(UIImage *img); @interface UIImage (ImageDown) //第一个参数获得一个url的字符串(图片) //第二参数 block块是用来将解析出来的image进行第二次赋值 +(UIImage *)imageDownWithUrlString:(NSString *)urlString imageBlock:(ImageBlock)i

Android-Universal-Image-Loader 图片异步加载类库的使用(超详细配置)

这个图片异步加载并缓存的类已经被很多开发者所使用,是最常用的几个开源库之一,主流的应用,随便反编译几个火的项目,都可以见到它的身影. 可是有的人并不知道如何去使用这库如何进行配置,网上查到的信息对于刚接触的人来说可能太少了,下面我就把我使用过程中所知道的写了下来,希望可以帮助自己和别人更深入了解这个库的使用和配置. GITHUB上的下载路径为:https://github.com/nostra13/Android-Universal-Image-Loader ,下载最新的库文件,并且导入到项目的

【转】Android-Universal-Image-Loader 图片异步加载类库的使用(超详细配置)

Android-Universal-Image-Loader 原文地址:http://blog.csdn.net/vipzjyno1/article/details/23206387 这个图片异步加载并缓存的类已经被很多开发者所使用,是最常用的几个开源库之一,主流的应用,随便反编译几个火的项目,都可以见到它的身影. 可是有的人并不知道如何去使用这库如何进行配置,网上查到的信息对于刚接触的人来说可能太少了,下面我就把我使用过程中所知道的写了下来,希望可以帮助自己和别人更深入了解这个库的使用和配置.

Android图片异步加载之Android-Universal-Image-Loader

将近一个月没有更新博客了,由于这段时间以来准备毕业论文等各种事务缠身,一直没有时间和精力沉下来继续学习和整理一些东西.最近刚刚恢复到正轨,正好这两天看了下Android上关于图片异步加载的开源项目,就顺便整理记录下来,作为这一个多月来博客的重新开火做饭吧.从今天起我会陆续恢复博客的更新,也希望大家继续支持. 今天要介绍的是Github上一个使用非常广泛的图片异步加载库Android-Universal-Image-Loader,该项目的功能十分强大,可以说是我见过的目前功能最全.性能最优的图片异

Android图片异步加载之Android-Universal-Image-Loader类库的使用

Android开发中我们会经常遇到图片过多或操作不当造成Out of Memory异常,有时虽然是解决了这个问题但却会影响程序的运行效率,例如:当用户在快速滑动滚动条的过程中,我们程序在仍在艰难的加载服务器端的图片,这样给用户造成了极不好的体验.其实网络上关于图片的异步加载和缓存的讲解很多,但是其实,写一个这方面的程序还是比较麻烦的,要考虑多线程,缓存,内存溢出等很多方面,针对这一广大开发者都会遇到的问题,一些牛人们已经帮我们解决了这一问题,今天我为大家介绍一款很流行的开源类库,可以很很好的解决

简单的ListView中item图片异步加载

前言: 在android开发当中,从目标地址获取图片往往都是采用异步加载的方法.当完全加载完图片后在进行显示,也有些是直接将加载的图片一点一点的显示出来. 这两个区别只是对流的处理不同而已.现在就讲讲当图片被完全获取到后在显示的方法. 一,效果图:       初始化:                                                   获取后:                         1.1,效果思路: 初始化的时候默认ImageView显示一张白色的图

Android新浪微博客户端(七)——ListView中的图片异步加载、缓存

原文出自:方杰|http://fangjie.sinaapp.com/?p=193转载请注明出处 最终效果演示:http://fangjie.sinaapp.com/?page_id=54该项目代码已经放到github:https://github.com/JayFang1993/SinaWeibo 一.ListView的图片异步加载 我们都知道对每一个Weibo Item都有用户头像,而且每一条微博还可能带有图片.如果在加载列表的同时加载图片,这样有几个缺点,第一很费事,界面卡住,用户体验很不

Android编程之图片(异步)加载类

应某人之请,写一篇关于图片加载类.其实,网上有很多这样的类,而且比较推崇的是来自google中开源中的一篇.他写的比较好了,而且注意了内存优化,下面贴出它的图片下载类: [java] view plaincopy /* * Copyright (C) 2010 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not 

Android性能优化之实现双缓存的图片异步加载工具(LruCache+SoftReference) - 拿来即用

之前在郭大神的博客看到使用LruCache算法实现图片缓存的.这里仿效他的思路,自己也写了一个. 并加入ConcurrentHashMap<String, SoftReference<Bitmap>>去实现二级缓存,因为ConcurrentHashMap是多个锁的线程安全,支持高并发.很适合这种频繁访问读取内存的操作. 下面整个思路是,使用了系统提供的LruCache类做一级缓存, 大小为运行内存的1/8,当LruCache容量要满的时候,会自动将系统移除的图片放到二级缓存中,但为