我正在创建一个应用程序,通过社交媒体平台分享图像,特别是在WhatsApp上。我尝试使用UIActivityViewController
但是在显示工作表时它没有显示WhatsApp选项。我在网上搜索并找到了以下代码:这显示了显示工作表时的WhatsApp选项,但选择WhatsApp选项会导致应用程序崩溃。这是代码:
let controller = UIDocumentInteractionController()
let path = NSSearchPathForDirectoriesInDomains(.DocumentDirectory,.UserDomainMask, true)
let documentDir = path[0] as String
let imgPath=documentDir.stringByAppendingPathComponent("tmp_flag.png")
let imageURL = NSURL.fileURLWithPath(imgPath)
println("Image path :\(imageURL)")
controller.delegate = self
controller.UTI = "net.whatsapp.image"
controller.URL = imageURL!
controller.presentOpenInMenuFromRect(CGRectZero, inView: self.view, animated: true)
有人能在某处发现任何错误吗?如果没有,有没有人知道如何让它工作?
答案 0 :(得分:2)
您需要使controller
成为该类的成员变量,因为必须保留controller
。
答案 1 :(得分:1)
在Swift 3中使用此代码
@IBAction func whatsappShareWithImages(_ sender: AnyObject) {
let urlWhats = "whatsapp://app"
if let urlString = urlWhats.addingPercentEncoding(withAllowedCharacters:CharacterSet.urlQueryAllowed) {
if let whatsappURL = URL(string: urlString) {
if UIApplication.shared.canOpenURL(whatsappURL as URL) {
if let image = UIImage(named: "whatsappIcon") {
if let imageData = UIImageJPEGRepresentation(image, 1.0) {
let tempFile = URL(fileURLWithPath: NSHomeDirectory()).appendingPathComponent("Documents/whatsAppTmp.wai")
do {
try imageData.write(to: tempFile, options: .atomic)
self.documentInteractionController = UIDocumentInteractionController(url: tempFile)
self.documentInteractionController.uti = "net.whatsapp.image"
self.documentInteractionController.presentOpenInMenu(from: CGRect.zero, in: self.view, animated: true)
} catch {
print(error)
}
}
}
} else {
print("Cannot open whatsapp")
}
}
}
}
在您的应用**plist**
<key>LSApplicationQueriesSchemes</key>
<array>
<string>whatsapp</string>
</array>
您还可以参考小应用程序参考:https://github.com/nithinbemitk/iOS-Whatsapp-Share
答案 2 :(得分:0)
我想分享迷你类,以便在 Whatsapp , Instagram , < em> Facebook 和活动,可能会对某人有所帮助。
/* Common steps to use these codes */
// 1- Download FBSharekit for sharing on Facebook
// 2- Copy and Paste the following text to your "info.plist" (anywhere)
/*
<key>FacebookAppID</key>
<string>08760425023140553</string> //This is a mock id, you must add your own real app id else it never will work
<key>FacebookDisplayName</key>
<string>DoYourBest</string> //Add your real app name here
<key>LSApplicationQueriesSchemes</key>
<array>
<string>whatsapp</string>
<string>instagram</string>
<string>fbapi</string>
<string>fb-messenger-share-api</string>
<string>fbauth2</string>
<string>fbshareextension</string>
</array>
*/
import FBSDKShareKit
class ShareHelper: NSObject {
static func shareImageViaWhatsapp(image: UIImage, onView: UIView) {
let urlWhats = "whatsapp://app"
if let urlString = urlWhats.addingPercentEncoding(withAllowedCharacters:CharacterSet.urlQueryAllowed) {
if let whatsappURL = URL(string: urlString) {
if UIApplication.shared.canOpenURL(whatsappURL as URL) {
guard let imageData = image.pngData() else { debugPrint("Cannot convert image to data!"); return }
let tempFile = URL(fileURLWithPath: NSHomeDirectory()).appendingPathComponent("Documents/whatsAppTmp.wai")
do {
try imageData.write(to: tempFile, options: .atomic)
self.documentInteractionController = UIDocumentInteractionController(url: tempFile)
self.documentInteractionController.uti = "net.whatsapp.image"
self.documentInteractionController.presentOpenInMenu(from: CGRect.zero, in: onView, animated: true)
} catch {
self.callAlertView(title: NSLocalizedString("information", comment: ""),
message: "There was an error while processing, please contact our support team.",
buttonText: "Close", fromViewController: topViewController!)
return
}
} else {
self.callAlertView(title: NSLocalizedString("warning", comment: ""),
message: "Cannot open Whatsapp, be sure Whatsapp is installed on your device.",
buttonText: "Close", fromViewController: topViewController!)
}
}
}
}
static func shareImageViaInstagram(image: UIImage, onView: UIView) {
let urlWhats = "instagram://app"
if let urlString = urlWhats.addingPercentEncoding(withAllowedCharacters:CharacterSet.urlQueryAllowed) {
if let whatsappURL = URL(string: urlString) {
if UIApplication.shared.canOpenURL(whatsappURL as URL) {
guard let imageData = image.pngData() else { debugPrint("Cannot convert image to data!"); return }
let tempFile = URL(fileURLWithPath: NSHomeDirectory()).appendingPathComponent("Documents/fitbestPhoto.igo")
do {
try imageData.write(to: tempFile, options: .atomic)
self.documentInteractionController = UIDocumentInteractionController(url: tempFile)
self.documentInteractionController.uti = "com.instagram.exclusivegram"
self.documentInteractionController.presentOpenInMenu(from: CGRect.zero, in: onView, animated: true)
} catch {
self.callAlertView(title: NSLocalizedString("information", comment: ""),
message: "There was an error while processing, please contact our support team.",
buttonText: "Close", fromViewController: topViewController!)
return
}
} else {
self.callAlertView(title: NSLocalizedString("warning", comment: ""),
message: "Cannot open Instagram, be sure Instagram is installed on your device.",
buttonText: "Close", fromViewController: topViewController!)
}
}
}
}
static func shareImageViaFacebook(image: UIImage, fromViewController: UIViewController) {
let sharePhoto = FBSDKSharePhoto()
sharePhoto.image = image
sharePhoto.isUserGenerated = true
let content = FBSDKSharePhotoContent()
content.photos = [sharePhoto]
let dialog = FBSDKShareDialog()
dialog.delegate = (fromViewController as! FBSDKSharingDelegate)
dialog.fromViewController = fromViewController
dialog.shareContent = content
dialog.mode = .shareSheet
dialog.show()
}
static func shareImageViaActivity(image: UIImage, onView: UIViewController) {
let vc = UIActivityViewController(activityItems: [image], applicationActivities: [])
// so that iPads won't crash
if UIDevice.currentDevice().userInterfaceIdiom == .Pad {
if let popoverController = vc.popoverPresentationController {
popoverController.sourceView = onView.view
popoverController.sourceRect = CGRect(x: onView.view.bounds.midX, y: onView.view.bounds.maxY, width: 0, height: 0)
popoverController.permittedArrowDirections = []
}
}
// exclude some activity types from the list (optional)
onView.present(vc, animated: true)
}
}
注意 = self.callAlertView(params...)
是一种用于调用自定义UIAlertViewController的方法,因此您可以将其删除并在其中放置自己的逻辑代码。