NGromann / SwiftHtmlPdf

Generate HTML and PDF documents by using template html files and filling them with your data
MIT License
8 stars 3 forks source link

Images not working #8

Open jberkhei opened 1 year ago

jberkhei commented 1 year ago

Cannot get a base64 image to render nor an image on the local device. If I log the generated HTML and open in Safari both base64 & local images work. When I save this HTML to a pdf the images are not rendered

NGromann commented 1 year ago

Hi @jberkhei! Could you share the code snippet that you have tried? I just tried the following inside the example project:

<img src="" alt="example logo" />

This seems to be working. The image is shown in the top right:

Bildschirm­foto 2023-03-21 um 21 37 13 Bildschirm­foto 2023-03-21 um 21 37 05
jberkhei commented 1 year ago

That's in the preview mode, not the actual PDF. When PDF'd, images do not appear because UISimpleTextPrintFormatter does not support images. You need to use WKWebView instead. Example below:

import Foundation import WebKit

typealias ExportManagerCompletion = (NSData) -> Void

class ExportManager: NSObject, WKNavigationDelegate { var webView: WKWebView? = nil var completion: ExportManagerCompletion!

func exportPDF(html: String, completion: @escaping ExportManagerCompletion) throws {
    self.completion = completion

    let webView = WKWebView()
    webView.navigationDelegate = self
    webView.loadHTMLString(html, baseURL: nil)
    self.webView = webView
}
func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
    let formatter = webView.viewPrintFormatter()
    createPDF(formatter)
}

func createPDF(_ formatter: UIViewPrintFormatter) {
  let render = UIPrintPageRenderer()
  render.addPrintFormatter(formatter, startingAtPageAt: 0)

  let paperRect = CGRect(x: 0, y: 0, width: 595.2, height: 841.8)
  render.setValue(paperRect, forKey: "paperRect")
  let padding: CGFloat = 24
  let printableRect = paperRect.insetBy(dx: padding, dy: padding)
  render.setValue(printableRect, forKey: "printableRect")

  let pdfData = NSMutableData()
  UIGraphicsBeginPDFContextToData(pdfData, .zero, nil)
  for i in 0..<render.numberOfPages {
      UIGraphicsBeginPDFPage();
      render.drawPage(at: i, in: UIGraphicsGetPDFContextBounds())
  }
  UIGraphicsEndPDFContext();

  self.completion?(pdfData)
}

}

NGromann commented 1 year ago

The example I showed also works in the exported PDF:

Bildschirm­foto 2023-03-21 um 22 30 35

Could you share an example of the HTML including the base64 image?