2015-12-14 13 views
5

için bir iOS payı uzantısı oluşturmak için:Aşağıdaki kodu kullanarak kişileri paylaşmak için bir iOS payı uzantısı oluşturmak çalışıyorum kişiler

let contactType = "public.vcard" 

override func viewDidLoad() { 
    let items = extensionContext?.inputItems 
    var itemProvider: NSItemProvider? 

    if items != nil && items!.isEmpty == false { 
     let item = items![0] as! NSExtensionItem 
     if let attachments = item.attachments { 
      if !attachments.isEmpty { 
       itemProvider = attachments[0] as? NSItemProvider 
      } 
     } 
    } 

    if itemProvider?.hasItemConformingToTypeIdentifier(contactType) == true { 
     itemProvider?.loadItemForTypeIdentifier(contactType, options: nil) { item, error in 
      if error == nil { 
       print("item: \(item)") 
      } 
     } 
    } 
} 

aşağıdaki çıktıyı alıyorum:

item: Optional(<42454749 4e3a5643 4152440d 0a564552 53494f4e 3a332e30 0d0a5052 4f444944 3a2d2f2f 4170706c 6520496e 632e2f2f 6950686f 6e65204f 5320392e 322f2f45 4e0d0a4e 3a42656e 6e657474 3b436872 69733b3b 3b0d0a46 4e3a2043 68726973 20204265 6e6e6574 74200d0a 54454c3b 74797065 3d484f4d 453b7479 70653d56 4f494345 3b747970 653d7072 65663a28 36313529 c2a03432 352d3637 31390d0a 454e443a 56434152 440d0a>) 

Bir kesme noktası belirlerseniz, bu öğenin bir tür NSSecureCoding olduğunu görüyorum. Sorum şu, bunu bir CNContact'a nasıl dönüştürebilirim?

cevap

4

Aldığınız ürün NSData türünde.

if itemProvider?.hasItemConformingToTypeIdentifier(contactType) == true { 
    itemProvider?.loadItemForTypeIdentifier(contactType, options: nil) { item, error in 
     if error == nil { 
      if let data = item as? NSData, let vCardString = String(data: data, encoding: NSUTF8StringEncoding) { 
       print(vCardString) 
      } 
     } 
    } 
} 
+0

çalıştı Müthiş için

let uttypeContact = kUTTypeContact as String if itemProvider.hasItemConformingToTypeIdentifier(uttypeContact) { itemProvider.loadItemForTypeIdentifier(uttypeContact, options: nil, completionHandler: { (data, error) in if error == nil { do { if let data = data as? NSData { let contact = try CNContactVCardSerialization.contactsWithData(data) print(contact) } } catch {} } }) } 

[Güncelleme] , teşekkür ederim. – atmospherelabs

+0

Ben yaptım ama serbest kalma zamanında sıkışmış. Uygulama doğrulama başarısız oldu ve hatayı gösterdi: ** Geçersiz Info.plist. Paket içindeki 'NSExtensionActivationRule' anahtarının değeri geçersiz ** Eğer aynı şeyi geçmiş olsaydınız lütfen bana yardımcı olun. Şimdiden teşekkürler .. –

+0

@BhavinTrivedi Bu sorunla karşılaşmadım. Lütfen sorununuz için yeni bir soru ekleyin. – joern

0
Swift 3'e @joern arasında

Güncelleme cevap::

: Eylem Uzatılması Ayrıca

if itemProvider.hasItemConformingToTypeIdentifier(kUTTypeContact as String) { 

    itemProvider.loadItem(forTypeIdentifier: kUTTypeContact as String, options: nil, completionHandler: { (contact, error) in 
      if let contactData = contact as? Data, let vCardString = String(data: contactData, encoding: .utf8) { 
       print(vCardString) 
      } 
    }) 
} 

Eğer OperationQueue eklemeniz gerekir vCard Dize almak için String için çevrilmesi gereklidir

if itemProvider.hasItemConformingToTypeIdentifier(kUTTypeContact as String) { 

    itemProvider.loadItem(forTypeIdentifier: kUTTypeContact as String, options: nil, completionHandler: { (contact, error) in 
     OperationQueue.main.addOperation { 
      if let contactData = contact as? Data, let vCardString = String(data: contactData, encoding: .utf8) { 
       print(vCardString) 
      } 
     } 
    }) 
} 
İlgili konular