I would like to save images into the cache in TableViewcontroller. I wrote the following code, but cacheImage is always nil.
@property (nonatomic,strong)NSCache *imageCache;
@synthesize imageCache;
- (void)viewDidLoad
{
[super viewDidLoad];
self.imageCache = [[NSCache alloc] init];
}
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];
cell.textLabel.text = [[tableData objectAtIndex:indexPath.row] valueForKey:@"name"];
cell.textLabel.font = [UIFont fontWithName:@"BebasNeue" size:24];
cell.textLabel.textColor = [UIColor whiteColor];
UIImage *cachedImage = [imageCache objectForKey:@"indexObject"];
if (cachedImage) {
dispatch_async(dispatch_get_main_queue(), ^{
cell.imageView.image = cachedImage;
});
}
else {
NSString *imageURLString=[[tableData objectAtIndex:indexPath.row] valueForKey:@"picture"];
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
NSURL *url = [NSURL URLWithString:imageURLString];
NSData *data = [[NSData alloc] initWithContentsOfURL:url];
UIImage *tmpImage = [[UIImage alloc] initWithData:data];
dispatch_async(dispatch_get_main_queue(), ^{
UITableViewCell *newsCell = [self.grillMenuTable cellForRowAtIndexPath:indexPath];
[imageCache setObject:tmpImage forKey:@"indexObject"];
if (newsCell)
{
newsCell.imageView.image=tmpImage;
[newsCell setNeedsLayout];
}
});
});
}
return cell;
}
I used the following code as Joe advise, but still cell.imageview.image always nil.
NSString *imageURLString=[[tableData objectAtIndex:indexPath.row] valueForKey:@"picture"];
[[DLImageLoader sharedInstance] loadImageFromUrl:imageURLString
completed:^(NSError *error, UIImage *imgData) {
cell.imageView.image = imgData;
}];
Here is the tutorial you can follow. Without Using any third party. https://sweettutos.com/2015/12/31/swift-how-to-asynchronously-download-and-cache-images-without-relying-on-third-party-libraries/
Don't try to reinvent the wheel. You should use an external library to do that, there are some great examples. Take a look at SDWebImage, it does exactly what you want.
Using it, you can forget queues, manually caching... Just import the header:
and, in your
tableView:cellForRowAtIndexPath:
method, you can just set the image into theUIImageView
with thesetImageWithURL:
(or any of its variants: with placeholders, etc.) method provided by the library:That's all. The library takes care of everything for you. If you want to somehow manage the cache behind this and configure it, you can, using the
SDWebImageManager
class (more info in the GitHub page).