2016-08-24 18 views
0

UIWebViewからPDFを作成できません。UIWebViewからPDFを作成

 let render = UIPrintPageRenderer();  
     /* 1. pdf from webView */ 
     render.addPrintFormatter(webView.viewPrintFormatter(), startingAtPageAtIndex: 0); 

     // 2. Assign paperRect and printableRect 

     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") 

     // 3. Create PDF context and draw 

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


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

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

     UIGraphicsEndPDFContext(); 

     // 4. Save PDF file 
     print("open \(path)"); 
     pdfData.writeToFile(path, atomically: true); 

すべてうまく動作しますが、HTML内の背景イメージを使用すると消えます。誰が何が間違っているのか分かりますか?

答えて

1

あなたのhtmlコードを作成する必要がまず第一に:

var html = "<html><head><meta charset='UTF-8'></head><body>hello from html </body></html>" 

次を使用してWebビューをインスタンス化する必要があるより:

あなたのViewControllerクラスを作成する必要があり、そのaftr
let webView = UIWebView(frame: self.view.bounds) 
self.view.addSubview(webView) 
webView.delegate = self 
webView.loadHTMLString(html, baseURL: nil) 
// webView.isUserInteractionEnabled = true 

UIWebViewDelegateを実装し、メソッドfunc webViewDidFinishLoad(_ webView: UIWebView) を実装し、最後にwebViewDidFinishLoadメソッド内に次のコードを追加します。

func webViewDidFinishLoad(_ webView: UIWebView) { 

    let render = UIPrintPageRenderer() 
    render.addPrintFormatter(webView.viewPrintFormatter(), startingAtPageAt: 0); 


    let page = CGRect(x: 0, y: 10, width: webView.frame.size.width, height: webView.frame.size.height) // take the size of the webView 
    let printable = page.insetBy(dx: 0, dy: 0) 
    render.setValue(NSValue(cgRect: page), forKey: "paperRect") 
    render.setValue(NSValue(cgRect: printable), forKey: "printableRect") 

    // 4. Create PDF context and draw 
    let pdfData = NSMutableData() 
    UIGraphicsBeginPDFContextToData(pdfData, CGRect.zero, nil) 
    for i in 1...render.numberOfPages { 

     UIGraphicsBeginPDFPage(); 
     let bounds = UIGraphicsGetPDFContextBounds() 
     render.drawPage(at: i - 1, in: bounds) 
    } 
    UIGraphicsEndPDFContext(); 
    let documentsPath = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0] 

    print(documentsPath) 

    pdfData.write(toFile: "\(documentsPath)/pdfName.pdf", atomically: true) 

    self.pdfPath = "\(documentsPath)/pdfName.pdf" 
    self.pdfTitle = "pdfName" 
    self.performSegue(withIdentifier: "showPDFSegue", sender: nil) 
    webView.removeFromSuperview() 
    self.loadingScreenViewController.view.removeFromSuperview() 
} 

ロジックを再開するには:webViewからpdfを生成するには、HTMLコードを準備し、WebViewを作成してWebView内にhtmlコードを挿入し、webView didFinishLoadingでhtmlコンテンツをPDF内に印刷する必要があります。 webViewの幅と高さが同じです。

関連する問題