ios – 如何使用照片框架快速浏览照片库

我有一个应用程序,为我的应用程序上的每张票创建一个独特的照片库.我需要弄清楚如何遍历该库,以便我可以一次一个地将图像上传到服务器.我在youtube上关注了这些教程. ( Video)我目前正在使用Swift作为我的语言.我的最终目标是拥有类似下面的伪代码.
//I need the following for loop example
for photo in gallery
{
    uploadToServer(photo)
}

//this function works already

func uploadToServer(photo:UIImage)
{
    callRest
    postPhoto
}

这是我的代码到目前为止无法弄清楚如何循环.他们虽然.

let fetchOptions = PHFetchOptions()
fetchOptions.predicate = nspredicate(format: "title = %@",self.albumName)?
let collection:PHFetchResult = PHAssetCollection.fetchAssetCollectionsWithType(.Album,subtype: .Any,options: fetchOptions)

if let first_Obj:AnyObject = collection.firstObject{
    //found the album
    self.assetCollection = collection.firstObject as PHAssetCollection
    self.albumFound = true
}
else { albumFound = false }
var i = collection.count
self.photoAssets = PHAsset.fetchAssetsInAssetCollection(self.assetCollection,options: nil)


self.photoAssets.enumerateObjectsUsingBlock{(object: AnyObject!,count: Int,stop: UnsafeMutablePointer<ObjCBool>) in

    if object is PHAsset{
        let asset = object as PHAsset
        println("Inside  If object is PHAsset,This is number 1")

        let imageSize = CGSize(width: asset.pixelWidth,height: asset.pixelHeight)

        /* For faster performance,and maybe degraded image */
        let options = PHImageRequestOptions()
        options.deliveryMode = .FastFormat

        imageManager.requestimageForAsset(asset,targetSize: imageSize,contentMode: .AspectFill,options: options,resultHandler: {
                (image,info)->Void in

                self.photo = image

                var defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
                var server = defaults.objectForKey("imageServer") as String!
                var error: NSError? = nil

                var imageData = UIImageJPEGRepresentation(self.photo,90)
                var url = NSURL(string: server)
                var request = NSMutableuRLRequest(URL: url!)
                request.HTTPMethod = "POST"
                //request.setValue("multipart/form-data",forHTTPHeaderField: "Content-Type")
                request.HTTPBody = imageData

                var response: NSURLResponse? = nil

                let reply = NSURLConnection.sendSynchronousRequest(request,returningResponse:&response,error:&error)

                let results = Nsstring(data:reply!,encoding:NSUTF8StringEncoding)
                println("API Response: \(results)")

                /*
                /* The image is Now available to us */
                self.sendPhotos(image)
                println("enum for image,This is number 2")*/


        })
    }
}

解决方法

所以经过Matt的一些研究和指导,我已经弄明白了.这是如何做到这一点.确保在主线程上执行此操作,因此必须设置options.synchronous = true.如果由于某种原因它没有任何照片的价值.
func getSyncPhotos()
{
    self.albumName = String(self.ticket_id!)

    let fetchOptions = PHFetchOptions()
    fetchOptions.predicate = nspredicate(format: "title = %@",self.albumName)?
    let collection:PHFetchResult = PHAssetCollection.fetchAssetCollectionsWithType(.Album,options: fetchOptions)

    if let first_Obj:AnyObject = collection.firstObject{
        //found the album
        self.assetCollection = collection.firstObject as PHAssetCollection
        self.albumFound = true
    }
    else { albumFound = false }
    var i = collection.count
    self.photoAssets = PHAsset.fetchAssetsInAssetCollection(self.assetCollection,options: nil)
    let imageManager = PHCachingImageManager()

    self.photoAssets.enumerateObjectsUsingBlock{(object: AnyObject!,stop: UnsafeMutablePointer<ObjCBool>) in

        if object is PHAsset{
            let asset = object as PHAsset
            println("Inside  If object is PHAsset,This is number 1")

            let imageSize = CGSize(width: asset.pixelWidth,height: asset.pixelHeight)

            /* For faster performance,and maybe degraded image */
            let options = PHImageRequestOptions()
            options.deliveryMode = .FastFormat
            options.synchronous = true
            imageManager.requestimageForAsset(asset,resultHandler: {
                     image,info in
                    self.photo = image!
                    /* The image is Now available to us */
                    self.sendPhotos(self.photo)
                    println("enum for image,This is number 2")


            })
        }
    }
}

func sendPhotos(uploadImage:UIImage)
{

    var defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
    var server = defaults.objectForKey("imageServer") as String!
    var error: NSError? = nil

    var imageData = UIImageJPEGRepresentation(uploadImage,90)
    var url = NSURL(string: server)
    var request = NSMutableuRLRequest(URL: url!)
    request.HTTPMethod = "POST"
    //request.setValue("multipart/form-data",forHTTPHeaderField: "Content-Type")
    request.HTTPBody = imageData

    var response: NSURLResponse? = nil

    let reply = NSURLConnection.sendSynchronousRequest(request,error:&error)

    let results = Nsstring(data:reply!,encoding:NSUTF8StringEncoding)
    println("API Response: \(results)")
}

相关文章

UITabBarController 是 iOS 中用于管理和显示选项卡界面的一...
UITableView的重用机制避免了频繁创建和销毁单元格的开销,使...
Objective-C中,类的实例变量(instance variables)和属性(...
从内存管理的角度来看,block可以作为方法的传入参数是因为b...
WKWebView 是 iOS 开发中用于显示网页内容的组件,它是在 iO...
OC中常用的多线程编程技术: 1. NSThread NSThread是Objecti...