2016-05-31 19 views
2

私は現時点では断りません、なぜ私は取得しようとしているときに毎回無限になっているのかわかりません。私は正しい画像データと識別子を渡しています。画像サイズ:(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))") 

        } 


       } 


      }) 


     } 




     } 
     } 

答えて

1

画像を手動でキャッシュするには、前に使用したフォトキャッシュでimageDownloaderを初期化する必要があります。 AutoPurgingImageCacheは共有インスタンスではありません。 UIImageView + AlamofireImage.swift拡張子には、AutoPurgingImageCacheを1つ保持するaf_sharedImageDownloaderがあります。あなたのコード例に依存して

それは次のようになります。

let imageDownloader = ImageDownloader(
      configuration: ImageDownloader.defaultURLSessionConfiguration(), 
      downloadPrioritization: .FIFO, 
      maximumActiveDownloads: 15, 
      imageCache: self.photoCache 
     ) 
関連する問題