0

我有一个与打开 PDF 文件相关的项目。这是在Info.plist. 当我收到电子邮件中的 PDF 附件时,我可以将手指放在 PDF 附件上,然后在我的应用程序中“打开”。在我的AppDelegate中,我添加了以下内容:

func application(app: UIApplication, openURL url: NSURL, options: [String : AnyObject]) -> Bool {
    incomingTransfer = URL
    return true
}

incomingTransfer是 aGlobal Variable在另一个中声明ViewController为 a NSURL。这ViewController也有一个UIWebViewincomingTransfer负载,我可以看到新的 PDF 文件。我的目标是有一个按钮,允许用户将传入的 PDF 保存为 PDF。我遇到了麻烦。我以为我已经弄清楚了,但它根本没有保存为 PDF,而是保存为String. 有人能帮助我吗?我的目标是将传入的 PDF 文件作为 PDF 保存到应用程序内存中,最好是DocumentDirectory. 我很难将 Objective C 转换为 Swift。我保存它的原始代码是:

    let html = String(incomingFileTransfer)
    let fmt = UIMarkupTextPrintFormatter(markupText: html)

    let render = UIPrintPageRenderer()
    render.addPrintFormatter(fmt, startingAtPageAtIndex: 0)

    let page = CGRect(x: 0, y: 0, width: 595.2, height: 841.8) // A4, 72 dpi
    let printable = CGRectInset(page, 0, 0)

    render.setValue(NSValue(CGRect: page), forKey: "paperRect")
    render.setValue(NSValue(CGRect: printable), forKey: "printableRect")

    let pdfData = NSMutableData()
    UIGraphicsBeginPDFContextToData(pdfData, CGRectZero, nil)

    for i in 1...render.numberOfPages() {

        UIGraphicsBeginPDFPage();
        let bounds = UIGraphicsGetPDFContextBounds()
        render.drawPageAtIndex(i - 1, inRect: bounds)
    }

    UIGraphicsEndPDFContext();

    recipeFileName = fileName.text!

    print("File Name Entered: \(recipeFileName)")

    let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0]

    pdfData.writeToFile("\(documentsPath)/\(recipeFileName).pdf", atomically: true)
4

1 回答 1

1

我想到了。我创建了一个class名为“PDFFile”。在“PDFFile”中有两个variables,命名为var name: Stringvar url: NSURL。在我的 'IncomingTransfer'ViewController中,我有 'save'button创建并保存具有键入名称的新文件,UITextField并将 my 中指定的incomingURLAppDelegate分配给url variable. 然后将两者都保存到PDFFile使用NSCoding. 然后我从 PDFFile数据中UITableView为其设置一个。当用户单击 时,我创建了一个,然后使用. 这会使用指定的变量从 a 加载 PDF ,从.dataSourceClass arraysegueUITableViewCellViewControllerUIWebViewWebViewurlRequesturlNSCoding

AppDelegate代码:

// Allows incoming file access (PDF)
func application(app: UIApplication, openURL url: NSURL, options: [String : AnyObject]) -> Bool {

    // Transfer incoming file to global variable to be read

    if url != "" {

        // Load from Mail App

        incomingFileTransfer = url

        incomingStatus = "Incoming"

    } else {

        // Regular Load

        print("App Delegate: No incoming file")

        incomingFileTransfer = nil

    }        

    return true
}

IncomingFile 代码和保存button代码:

// MARK: Properties
var file: PDFFile?

// MARK: Actions
// Save Button
let name = fileName.text ?? ""

let url = incomingFileTransfer

file = PDFFile(name: name, url: url)


// MARK: NSCoding
func saveFiles() {

    let isSuccessfulSave = NSKeyedArchiver.archiveRootObject(pdfFiles, toFile: PDFFile.ArchiveURL.path!)

    if !isSuccessfulSave {

        print("Failed to save PDF file")

    }

}

稍后查看保存的传入 PDFViewController代码: // MARK: Properties @IBOutlet weak var pdfItemWebView: UIWebview!

var incomingURL: NSURL!

// Within ViewDidLoad
    if let file = file {

        pdfFileName.text = file.name

        incomingURL = file.url

        print("Saved URL: \(incomingURL)")

        print("Pending load...")

        let request = NSURLRequest(URL: incomingURL!)

        pdfItemWebView.loadRequest(request)

    }

这很复杂,但对我有用。可能有更简单的方法,但这是我想出来的,它可以满足我的需要。

于 2015-12-08T18:34:45.887 回答