私は現時点では断りません、なぜ私は取得しようとしているときに毎回無限になっているのかわかりません。私は正しい画像データと識別子を渡しています。画像サイズ:(2826.0、3722.0)および識別子として文字列ます。http:ときcachedImageためwww.somelink.com/DT199.jpg画像がAlamofireImageにキャッシュされないのはなぜですか?
印刷ここでcacheImage機能のために少しのコード
let photoCache = AutoPurgingImageCache(
memoryCapacity: 100 * 1024 * 1024,
preferredMemoryUsageAfterPurge: 60 * 1024 * 1024
)
func cacheImage(image: Image, urlString: String) {
print("Image size: \(image.size) and string as identifier: \(urlString)")
self.photoCache.addImage(image, withIdentifier: urlString)
}
func cachedImage(urlString: String) -> Image? {
print("What is url? : \(urlString)")
print("What we are actually returning? : \(self.photoCache.imageWithIdentifier(urlString))")
return self.photoCache.imageWithIdentifier(urlString)
}
印刷です私はそれを取得しようとしています:URLは何ですか? :http:www.somelink.com/DT199.jpg私たちが実際に返すものは:nil
なぜそれが起こっているのか分かりません。以前に何度か試してみましたが、それは完全に機能しました。私はこれらの関数についても読んでいますが、画像がキャッシュにあるかどうかを知ることができるブール値の応答を返しません。
その後、私はダウンロードマネージャーを使ってみましたが、まったく別のことは起こりません。もし誰かが私を助けることができますか?ここにコードがあります
let imageDownloader = ImageDownloader(
configuration: ImageDownloader.defaultURLSessionConfiguration(),
downloadPrioritization: .FIFO,
maximumActiveDownloads: 15,
imageCache: AutoPurgingImageCache()
)
let downloader = imageDownloader
Alamofire.request(.GET, request, headers: headers)
.responseJSON { response in
if let JSON = response.result.value {
self.imagesArray = NSMutableArray()
self.imagesArray = JSON["results"] as! NSMutableArray
for results in self.imagesArray{
let URLRequest = NSURLRequest(URL: NSURL(string:results["url"] as! String)!)
downloader.downloadImage(URLRequest: URLRequest, filter: nil, completion: { response in
if response.response?.statusCode == 200{
print("In the house fetching url: \(results["url"] as! String)")
let image = response.result.value
print("Size of image: \(image?.size)")
let returnValue = downloader.imageCache?.addImage(image!, withIdentifier: results["url"] as! String)
print("return status: \(returnValue)")
if results .isEqual(self.imagesArray.lastObject){
self.activityIndicatorView.stopAnimating()
self.activityIndicatorView.hidden = true
let fic = self.imagesArray.firstObject
print("getting image for this url : \(fic!["url"] as! String)")
var imageC = UIImage()
imageC = (downloader.imageCache?.imageWithIdentifier(fic!["url"] as! String))!
self.ssImage.image = imageC
print("Image : \(imageC.size))")
}
}
})
}
}
}