我有一个自定义UICollectionViewCell
,可以使用AlamofireImage(2.4)获取图像。它下载OK,但它似乎没有放入缓存。
我有一个带有全局缓存的swift文件。
import Foundation
import Alamofire
import AlamofireImage
// AlamofireImage cache with 30 MB cache
let imageCache = AutoPurgingImageCache(
memoryCapacity: 30 * 1024 * 1024,
preferredMemoryUsageAfterPurge: 20 * 1024 * 1024
)
收集单元格如下所示。它使用af_setImageWithURL
下载图像,并在回调中将此图像设置在单元格上后将其放入全局缓存中。
import UIKit
import Alamofire
import AlamofireImage
class MyCatCell: UICollectionViewCell {
@IBOutlet weak var fancyImage: UIImageView!
var imageURL: String?
func configureCell(uri: String?) {
imageURL = uri
resetCell()
loadImage()
}
func resetCell() {
fancyImage.af_cancelImageRequest()
fancyImage.image = nil
}
func loadImage() {
guard imageURL != nil else {
return
}
if let image = imageCache.imageWithIdentifier(imageURL!) {
// set image from cache
print("image from cache")
fancyImage.image = image
} else {
// get image and cache it
let url = NSURL(string: imageURL!)!
fancyImage.af_setImageWithURL(
url,
placeholderImage: nil,
filter: nil,
imageTransition: .CrossDissolve(0.5),
completion: { response in
if response.result.isSuccess {
print("response.result.isSuccess \(self.imageURL!)")
// store this in the image cache
imageCache.addImage(response.result.value!, withIdentifier: self.imageURL!)
}
}
)
}
}
}
图像在单元格中设置,print("response.result.isSuccess \(self.imageURL!)")
触发(因此回调正在运行),但print("image from cache")
永远不会触发。 imageCache.imageWithIdentifier(imageURL!)
始终为nil
。当我使用相同的URL再次加载此单元格时,它会再次下载图像。知道为什么这不起作用吗?
答案 0 :(得分:0)
我发现我只需要增加缓存的大小。我下载的图像比我预测的要大,缓存填充得太快,然后清除。
// AlamofireImage cache with 60 MB cache
let imageCache = AutoPurgingImageCache(
memoryCapacity: 60 * 1024 * 1024,
preferredMemoryUsageAfterPurge: 20 * 1024 * 1024
)
如果您定期使用 imageCache.memoryUsage ,则可以看到您的缓存已满。
Print('Image cache size = \(imageCache.memoryUsage)')