我需要在iOS下共享/打开一些不同的文件,例如iCloud的图像或iBooks的pdf.文本和图像有几个例子,但在其他方面没什么...
我创造了自己的UIActivityItemProvider; 简化版本:
class MyItemProvider: UIActivityItemProvider {
override func item() -> AnyObject {
self.placeholderItem
}
override func activityViewController(activityViewController: UIActivityViewController, dataTypeIdentifierForActivityType activityType: String?) -> String {
return kUTTypePDF as String
}
func activityViewControllerPlaceholderItem(activityViewController: UIActivityViewController) -> AnyObject {
return self.placeholderItem
}
}
Run Code Online (Sandbox Code Playgroud)
并开始分享如下:
let myPDF = NSData(contentsOfURL: NSBundle.mainBundle().URLForResource("testpdf", withExtension: "pdf")) {
let activityVC = UIActivityViewController(activityItems: [MyItemProvider(placeHolder: myPDF)], applicationActivities: nil)
self.presentViewController(activityVC, animated: true, completion: nil)
Run Code Online (Sandbox Code Playgroud)
我期待一个像以下一样的共享:
但我得到的只是:
有什么建议?
小智 23
**
**
我花了很多时间思考如何在从URL加载的UIWebView中共享PDF文件,比如" http://youPdfFile.pdf "
几天后,我发现了我认为最合适的方式:
1)PDF必须首先保存在文件系统中.例如,这可以在加载UIWebView之后完成:
class yourViewController: UIViewController{
var documentPathToLoad = "http://youPdfFile.pdf"
...
func webViewDidFinishLoad(_ webView: UIWebView) {
if yourWebView.isLoading {
// still loading
return
}
//Save the pdf document to file system
savePdf()
}
func savePdf(){
let fileManager = FileManager.default
let paths = (NSSearchPathForDirectoriesInDomain((.documentDirectory, .userDomainMask, true)[0] as NSString).appendingPathComponent("documento.pdf")
let pdfDoc = NSData(contentsOf:URL(string: documentPathToLoad)!)
fileManager.createFile(atPath: paths as String, contents: pdfDoc as Data?, attributes: nil)
}
}
Run Code Online (Sandbox Code Playgroud)
2)读取保存的文件,然后共享.这个方法适用于Swift 3.0.1:
func loadPDFAndShare(){
let fileManager = FileManager.default
let documentoPath = (self.getDirectoryPath() as NSString).appendingPathComponent("documento.pdf")
if fileManager.fileExists(atPath: documentoPath){
let documento = NSData(contentsOfFile: documentoPath)
let activityViewController: UIActivityViewController = UIActivityViewController(activityItems: [documento!], applicationActivities: nil)
activityViewController.popoverPresentationController?.sourceView=self.view
present(activityViewController, animated: true, completion: nil)
}
else {
print("document was not found")
}
}
Run Code Online (Sandbox Code Playgroud)
您必须在 UIActivityViewController 中为 pdf 支持的应用程序选项传递pdf 文件 url。
func btnTapped() {
if let pdf = Bundle.main.url(forResource: "yourPdfFileName", withExtension: "pdf", subdirectory: nil, localization: nil) {
self.sharePdf(path: pdf)
}
}
func sharePdf(path:URL) {
let fileManager = FileManager.default
if fileManager.fileExists(atPath: path.path) {
let activityViewController: UIActivityViewController = UIActivityViewController(activityItems: [path], applicationActivities: nil)
activityViewController.popoverPresentationController?.sourceView = self.view
self.present(activityViewController, animated: true, completion: nil)
} else {
print("document was not found")
let alertController = UIAlertController(title: "Error", message: "Document was not found!", preferredStyle: .alert)
let defaultAction = UIAlertAction.init(title: "ok", style: UIAlertAction.Style.default, handler: nil)
alertController.addAction(defaultAction)
UIViewController.hk_currentViewController()?.present(alertController, animated: true, completion: nil)
}
}
Run Code Online (Sandbox Code Playgroud)
现有答案演示了如何使用本地文件的 URL 共享 PDF。但是,如果您不想,则不必创建文件。另一种方法是使用Data您的 PDF 文件的表示。
假设您PDFKit用于在 UI 中显示 PDF。这意味着您将处理PDFKit.PDFDocument具有dataRepresentation()方法的类。此方法返回Data可以传递给UIActivityViewController初始化程序的内容。
这段代码适用于我共享文件。当然,该文件必须已经创建:
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *fullPath = [documentsDirectory stringByAppendingPathComponent:[NSString stringWithFormat:@"%@.pdf", @"FileName"]];
NSURL *URL = [NSURL fileURLWithPath:fullPath];
NSArray *activityItems = [NSArray arrayWithObjects:URL, nil];
UIActivityViewController *activityViewController = [[UIActivityViewController alloc] initWithActivityItems:activityItems applicationActivities:nil];
[self presentViewController:activityViewController animated:YES completion:nil];
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
12652 次 |
| 最近记录: |