我目前正在使用 Alamofire 从服务器获取 Json 数据/url-images。
一切正常,我可以将服务器中的所有 url-images 加载到 UIImageView 中。然后,用户可以从左向右滑动,以便像照片库一样查看每个图像。
目前,当我获取数据时,我循环遍历我的 NSArray,将每个 url 转换为图像,然后将每个图像附加到 UIImage[] 中。
首次启动时,通过 NSArray 循环真的会减慢我的应用程序的速度,有没有办法加快这个过程?或者更好/更快的方式将网址转换为背景中的图像?
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)
###THIS IS REALLY SLOW, IS THERE A FASTER SOLUTION
for var i = 0; i < self.mutable_pages.count; i++ {
###Construct the imgUrl to get an image URL for the pages
let urlString: NSString = self.mutable_pages[i] as NSString
var imgURL: NSURL = NSURL(string: urlString)!
var imgData: NSData = NSData(contentsOfURL: imgURL)!
###append each image into UIImage
self.pageImages.append(UIImage(data: imgData)!)
}
}
}