2016-08-24 5 views
0

У меня возникла проблема с созданием PDF из UIWebView.Создать PDF из UIWebView

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

, чем вам нужно создать экземпляр веб-просмотра, используя следующие:

let webView = UIWebView(frame: self.view.bounds) 
self.view.addSubview(webView) 
webView.delegate = self 
webView.loadHTMLString(html, baseURL: nil) 
// webView.isUserInteractionEnabled = true 

aftr, что вам нужно сделать свой класс ViewController выполнить 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() 
} 

Итак, чтобы возобновить логику: Чтобы создать pdf-файл из webView, вам необходимо подготовить свой HTML-код, создать WebView и вставить HTML-код внутри webView, а в webView didFinishLoading распечатать содержимое html внутри pdf, используя та же ширина и высота webView.

Смежные вопросы