AlamofireImage Collection 单元在下载后将图像放入 AutoPurgingImageCache
AlamofireImage Collection cell puts image in AutoPurgingImageCache after download
我有一个自定义 UICollectionViewCell
,它使用 AlamofireImage (2.4) 获取图像。下载正常,但是好像没有放入缓存。
我的全局缓存有一个 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 再次加载此单元格时,它只是再次下载图像。知道为什么这不起作用吗?
我发现我只需要将缓存的大小变大即可。我正在下载的图像比我预期的要大,而且缓存填满的速度太快,然后就被清除了。
// 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)')
我有一个自定义 UICollectionViewCell
,它使用 AlamofireImage (2.4) 获取图像。下载正常,但是好像没有放入缓存。
我的全局缓存有一个 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 再次加载此单元格时,它只是再次下载图像。知道为什么这不起作用吗?
我发现我只需要将缓存的大小变大即可。我正在下载的图像比我预期的要大,而且缓存填满的速度太快,然后就被清除了。
// 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)')