UIImageview + afnetworking 下载图片并缓存图片。
但在某些情况下,服务器图像 = 15mb。所以我需要根据一些因素对它们进行压缩并使其达到 1mb,然后需要缓存它们。
另一方面,SDWebImageCache 让您定义自己的缓存并存储它们
是否有任何内置机制用于下载、编辑然后保存到缓存中?
[SDWebImageDownloader.sharedDownloader downloadImageWithURL:imageURL
options:0
progress:^(NSInteger receivedSize, NSInteger expectedSize)
{
// progression tracking code
}
completed:^(UIImage *image, NSData *data, NSError *error, BOOL finished)
{
if (image && finished)
{
// do something with image
}
}];
然后使用 [[SDImageCache sharedImageCache] storeImage:myImage forKey:myCacheKey]
除了做这样的事情还有其他选择吗?
您使用 SDWebImage
的场景是正确的。
出于编辑目的,您需要将委托(delegate)设置为 SDWebImageManager
对象并实现必要的方法:
// Set delegate
[SDWebImageManager sharedManager].delegate = self;
// Implement delegate method
- (UIImage *)imageManagerSDWebImageManager *)imageManager
transformDownloadedImageUIImage *)image
withURLNSURL *)imageURL {
UIImage scaledImage = ... // Make scale based on 'image' object
return scaledImage;
}
请注意,此方法在图像下载后立即调用,但在将其存储到内存缓存之前以及调用完成 block 之前。
此方法的文档:
Allows to transform the image immediately after it has been downloaded and just before to cache it on disk and memory. NOTE: This method is called from a global queue in order to not to block the main thread.
之后,您将能够在您的问题中使用 SDWebImageDownloader
和 SDImageCache
:
[SDWebImageDownloader.sharedDownloader downloadImageWithURL:imageURL
options:0
progress:^(NSInteger receivedSize, NSInteger expectedSize) {
// progression tracking code
}
completed:^(UIImage *image, NSData *data, NSError *error, BOOL finished) {
if (image && finished) {
[[SDImageCache sharedImageCache] storeImage:image forKey:myCacheKey];
}
}];
然后就可以使用SDImageCache
类的方法来管理缓存了:
- (NSOperation *)queryDiskCacheForKeyNSString *)key doneSDWebImageQueryCompletedBlock)doneBlock;
- (void)removeImageForKeyNSString *)key fromDiskBOOL)fromDisk withCompletionSDWebImageNoParamsBlock)completion;
如果您需要最大数据大小的图像缩放算法,请查看 this回答。
关于ios - 下载图像编辑图像然后缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31500960/
欢迎光临 OGeek|极客世界-中国程序员成长平台 (https://ogeek.cn/) | Powered by Discuz! X3.4 |