2016-11-05 1 views
2

Ich erstelle einen QR-Code im laufenden Betrieb und speichere ihn als UIImage. Jetzt möchte ich in der Lage sein, es zu senden, um die UIActivityViewController verwenden, aber irgendwie versagt es:Senden eines On-the-Fly-QR-Codes UIImage von AirDrop schlägt fehl

func generateQRCode(from string: String) -> UIImage? { 
    let data = string.data(using: String.Encoding.ascii) 

    if let filter = CIFilter(name: "CIQRCodeGenerator") { 
     filter.setValue(data, forKey: "inputMessage") 
     let transform = CGAffineTransform(scaleX: 3, y: 3) 

     if let output = filter.outputImage?.applying(transform) { 
      return UIImage(ciImage: output) 
     } 
    } 

    return nil 
} 

Und dann bin ich die Funktion aufrufen und speichern Sie es als UIImage:

let image = generateQRCode(from: "Create my Code") 
imgQRCode.image = image 

Der Export Taste verwendet die folgende Aktion:

@IBAction func shareButtonClicked(sender: UIButton) { 

     let objectsToShare = [imgQRCode.image!] as [AnyObject] 
     let activityVC = UIActivityViewController(activityItems: objectsToShare, applicationActivities: nil) 

     activityVC.popoverPresentationController?.sourceView = sender 
     self.present(activityVC, animated: true, completion: nil) 

} 

nach der Auswahl der App via AirDrop auf meinem Mac senden stürzt

2016-11-05 23:29:15.912242 Ordnung[3945:888442] CGContextScaleCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 

Nov 5 23:29:15 Ordnung [3945]: CGContextScaleCTM: ungültiger Kontext 0x0. Wenn Sie das Backtrace sehen möchten, legen Sie die Umgebungsvariable CG_CONTEXT_SHOW_BACKTRACE fest.

2016-11-05 23:29:15.912396 Ordnung[3945:888442] CGContextTranslateCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
Nov 5 23:29:15 Ordnung[3945] <Error>: CGContextTranslateCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
2016-11-05 23:29:15.912584 Ordnung[3945:888442] CGContextConcatCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
Nov 5 23:29:15 Ordnung[3945] <Error>: CGContextConcatCTM: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
2016-11-05 23:29:15.912692 Ordnung[3945:888442] CGContextDrawImage: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
Nov 5 23:29:15 Ordnung[3945] <Error>: CGContextDrawImage: invalid context 0x0. If you want to see the backtrace, please set CG_CONTEXT_SHOW_BACKTRACE environmental variable. 
2016-11-05 23:29:15.927580 Ordnung[3945:888442] [AirDrop] Sender kSFOperationEventErrorOccured { 
    Error = "Error Domain=SFOperation Code=-5 \"Die \U00dcbertragung ist fehlgeschlagen, da du eine ung\U00fcltige Datei senden wolltest.\" UserInfo={NSLocalizedDescription=Die \U00dcbertragung ist fehlgeschlagen, da du eine ung\U00fcltige Datei senden wolltest.}"; 
    SessionID = 76FBE80074FC; 
} 

Hat jemand eine Idee, wie man das erledigt?

Beifall Maik

Antwort

6

Es scheint, ich brauche das Bild auf eine etwas andere Art und Weise zur Verfügung zu stellen, so den QR-Code Generation zu verändern auf diese Weise das Problem löst, indem ein CGImage Erstellen vor der UIImage zu erstellen:

func generateQRCode(from string: String) -> UIImage? { 
    let ciContext = CIContext() 
    let data = string.data(using: String.Encoding.ascii) 

    if let filter = CIFilter(name: "CIQRCodeGenerator") { 
     filter.setValue(data, forKey: "inputMessage") 
     let transform = CGAffineTransform(scaleX: 3, y: 3) 
     let upScaledImage = filter.outputImage?.applying(transform) 


     let cgImage = ciContext.createCGImage(upScaledImage!, 
               from: upScaledImage!.extent) 
     qrcodeImage = UIImage(cgImage: cgImage!) 
     return qrcodeImage 
    } 
    return nil 
} 

Und zusätzlich sollten Sie eine PNG oder JPG-Darstellung des Bildes verwenden:

func share() { 
    let png = UIImagePNGRepresentation(qrcodeImage) 
    let vc = UIActivityViewController(activityItems: [png!], applicationActivities: []) 
    present(vc, animated: true) 
} 
+0

Sie haben meinen Tag gerettet! Vielen Dank! – DeZigny