J'ai une vue de collection qui affiche des images, certaines d'entre elles sont mises en cache et correctement récupérées, mais d'autres ne le sont pas. La vue de collection affiche deux cellules au carré par ligne.Mise en cache avec alamofireimages
Je n'arrive pas à comprendre pourquoi parfois les images sont extraites du cache et d'autres fois doivent être téléchargées à nouveau.
ici où je mettre en cache les images:
class DataImage {
static let sharedManager = DataImage()
let decoder = ImageDecoder()
let photoCache = AutoPurgingImageCache(
memoryCapacity: 100 * 1024 * 1024,
preferredMemoryUsageAfterPurge: 60 * 1024 * 1024
)
//MARK: - Image Downloading
func getNetworkImage(urlString: String, completion: (UIImage -> Void)) -> (ImageRequest) {
let queue = decoder.queue.underlyingQueue
let request = Alamofire.request(.GET, urlString)
let imageRequest = ImageRequest(request: request)
imageRequest.request.response(
queue: queue,
responseSerializer: Request.imageResponseSerializer(),
completionHandler: { response in
guard let image = response.result.value else {
return
}
let decodeOperation = self.decodeImage(image) { image in
completion(image)
self.cacheImage(image, urlString: urlString)
}
imageRequest.decodeOperation = decodeOperation
}
)
return imageRequest
}
func decodeImage(image: UIImage, completion: (UIImage -> Void)) -> DecodeOperation {
let decodeOperation = DecodeOperation(image: image, decoder: self.decoder, completion: completion)
self.decoder.queue.addOperation(decodeOperation)
return decodeOperation
}
//MARK: - Image Caching
func cacheImage(image: Image, urlString: String) {
photoCache.addImage(image, withIdentifier: urlString)
}
func cachedImage(urlString: String) -> Image? {
print("image: \(photoCache.imageWithIdentifier(urlString))")
return photoCache.imageWithIdentifier(urlString)
}
}
et voici la classe Cell:
class StoreCell: UICollectionViewCell {
@IBOutlet weak var title: UILabel!
@IBOutlet weak var storyImage: UIImageView!
@IBOutlet weak var subTitle: UILabel!
@IBOutlet weak var cost: UILabel!
var imageFilename: String!
var request: ImageRequest!
var dataImage = DataImage()
func configure() {
self.layer.cornerRadius = 3.0
reset()
loadImage()
}
func reset() {
storyImage.image = nil
request?.cancel()
}
func loadImage() {
let stringURL = "https://........\(imageFilename)"
if self.storyImage.image == nil {
if let image = dataImage.cachedImage(stringURL) {
self.storyImage.image = image
} else {
request = dataImage.getNetworkImage(stringURL) { image in
self.storyImage.image = image
self.storyImage.runImageTransition(.CrossDissolve(0.2), withImage: image)
}
}
}
}
}
hey, avez-vous réussi à résoudre ce problème? quel était le problème ici? Merci! – user3766930
Non, je ne l'ai pas fait. De toute façon avec Swift 3, la requête imageRequest.request vous donnera une erreur. – Giovanni