2016-05-25 12 views
0

Momentan verwende ich Alamofire für Netzwerkanfragen. Wie kann ich ein Bild direkt in ein Fotoalbum herunterladen, das bereits mit der PHPhotoLibrary von Photos.framework existiert?Bild direkt in ein Fotoalbum herunterladen

P.S .: Ich habe nichts dagegen, eine Lösung mit NSURLSession von selbst zu haben.

Überlegungen: Die Datei kann nicht vorübergehend auf der Festplatte gespeichert werden. Ich möchte die Daten im Speicher und speichern Sie sie einmal auf der Festplatte mit der Photos.framework.

Antwort

0

Ich finde es selbst heraus. Ich implementierte es mit einer dataTaskWithRequest von NSURLSession.

Zunächst dachte ich mit der NSData(contentsOfURL:), aber die contentsOfURL Methode kehrt nicht zurück, bis die gesamte Datei übertragen wird. Es sollte nur für lokale Dateien und nicht für Remote-Dateien verwendet werden. Wenn Sie einen großen Inhalt laden und das Gerät eine langsame Verbindung hat, wird die Benutzeroberfläche blockiert.

// Avoid this! 
let originalPhotoData = NSData(contentsOfURL: NSURL(string: "http://photo.jpg")!) 

So ist es möglich, den Inhalt in eine NSData mit einer Datenaufgabe zu laden. Eine Lösung kann wie:

let request = NSMutableURLRequest(URL: NSURL(string: urlString.URLString)!) 
request.allHTTPHeaderFields = [ 
    "Content-Type": "image/jpeg" 
] 
let task = NSURLSession.sharedSession().dataTaskWithRequest(request) { data, response, error in 
    if let e = error { 
     print(e.description) 
     return 
    } 
    guard let image = UIImage(data: data) else { 
     print("No image") 
     return 
    } 
    // Success 
    // Note: does not save into an album. I removed that code to be more concise. 
    PHPhotoLibrary.sharedPhotoLibrary().performChanges { 
     let creationRequest = PHAssetChangeRequest.creationRequestForAssetFromImage(image) 
    }, completionHandler: { (success : Bool, error : NSError?) -> Void in 
     if success == false, let e = error){ 
      print(e) 
     } 
    } 
} 
task.resume() 

Die Daten nur in der letzten Phase ist, aber Sie können stattdessen auf die Daten zugreifen und sehen Sie die Fortschritte mit Hilfe eines Sitzungs delegieren.

class Session: NSObject, NSURLSessionDelegate, NSURLSessionTaskDelegate, NSURLSessionDataDelegate { 

    let configuration = NSURLSessionConfiguration.defaultSessionConfiguration() 
    let queue = NSOperationQueue.mainQueue() 
    var session = NSURLSession() 

    var buffer = NSMutableData() 
    var expectedContentLength = 0 

    override init() { 
     super.init() 
     session = NSURLSession(configuration: configuration, delegate: self, delegateQueue: queue) 
    } 

    func dataTaskWithRequest(request: NSURLRequest) -> NSURLSessionDataTask { 
     // The delegate is only called if you do not specify a completion block! 
     return session.dataTaskWithRequest(request) 
    } 

    func URLSession(session: NSURLSession, dataTask: NSURLSessionDataTask, didReceiveResponse response: NSURLResponse, completionHandler: (NSURLSessionResponseDisposition) -> Void) { 
     buffer = NSMutableData() 
     expectedContentLength = Int(response.expectedContentLength) 
     print("Expected content length:", expectedContentLength) 
     completionHandler(NSURLSessionResponseDisposition.Allow) 
    } 

    func URLSession(session: NSURLSession, dataTask: NSURLSessionDataTask, didReceiveData data: NSData) { 
     buffer.appendData(data) 
     let percentageDownloaded = Float(buffer.length)/Float(expectedContentLength) 
     print("Progress: ", percentageDownloaded) 
    } 

    func URLSession(session: NSURLSession, task: NSURLSessionTask, didCompleteWithError error: NSError?) { 
     print("Finished with/without error \(error)") 
     // Use the buffer to create the UIImage 
    } 

}