Swift Custom Response Serializer随机返回图像

时间:2014-12-19 23:35:36

标签: swift uiimage afnetworking afnetworking-2 alamofire

我目前正在使用Alamofire从服务器获取Json数据/ url-images。我还使用此tutorial创建了一个自定义响应序列化程序,可根据请求将url图像转换为UIImages。

一切正常,我可以将服务器中的所有图像加载到UIImageView中。然后,用户可以从左向右滑动,以便像照片库一样查看每个图像。

我遇到的问题是我的自定义响应以不同的顺序返回图像。

因此,显示的每张图片的初始顺序都不正确。有人知道我该怎么解决这个问题吗?

我能够使它发挥作用的唯一方法是我循环0 ... 4。但我需要遍历整个NSMutableArray。

var pages = NSArray()

var mutable_pages = NSMutableArray()
var pageImages: [UIImage] = []

override func viewDidLoad() {
    super.viewDidLoad()

    self.fetchPages()

}

func fetchPages() {
    Alamofire.request(.GET, "http://www.myurl.com/api/pages.json").responseJSON() {
    (_, _, data, _) in

       self.pages = data!.valueForKey("page_url") as NSArray!

       self.mutable_pages = NSMutableArray(array: self.pages)

        ###fetch json images and convert nsdata to image
        ###for some odd reason the order doesn't change if i do. (i < 4)
        for var i = 0; i < self.mutable_pages.count; i++ {
            let urlString: NSString = self.mutable_pages[i] as NSString
            var imgURL: NSURL = NSURL(string: urlString)!

            ###So far the images are in the order that I want
            Alamofire.request(.GET, imgURL).responseImage() {
                (request, _, image, error) in

                if error == nil && image != nil {
                    dispatch_async(dispatch_get_main_queue(), {

                        ###Somehow the images get appended at a random order, why?
                        self.pageImages.append(image!)
                    })
                }
            }

        }
    }
}

CUSTOM RESPONSE

extension Alamofire.Request {
  class func imageResponseSerializer() -> Serializer {
    return { request, response, data in
      if data == nil {
        return (nil, nil)
      }

      let image = UIImage(data: data!, scale: UIScreen.mainScreen().scale)

      return (image, nil)
  }
}

###This returns the images in a different order...
  func responseImage(completionHandler: (NSURLRequest, NSHTTPURLResponse?, UIImage?, NSError?) -> Void) -> Self {
    return response(serializer: Request.imageResponseSerializer(), completionHandler: { (request, response, image, error) in
      completionHandler(request, response, image as? UIImage, error)
    })
  }
}

1 个答案:

答案 0 :(得分:2)

  

不知何故,图像以随机顺序附加,为什么?

因为异步请求或异步调度的块无法保证顺序。

不是将图像附加到数组中,而是应该根据相应的页面将它们键入字典(例如pages[i] = image)(顺便说一句,它更容易使用{{1} }})。

甚至更好,只能使用AFNetworking的for i in 0..<pages.count { ... }类别按需请求图片。