0

我有一个通过 ASP.NET 呈现的 HTML 页面。当我通过 HtmlRenderer.PdfSharp 生成 PDF 时,图像在 PDF 中显示为红色 X(缺少图像),而 HTML 的其余部分则正确显示。图像不是链接,它们是二进制对象。

private void PdfFormat(string _body, ref MemoryStream _stream)
{
    Bitmap bitmap = new Bitmap(790, 1800);
    Graphics g = Graphics.FromImage(bitmap);
    XGraphics xg = XGraphics.FromGraphics(g, new XSize(bitmap.Width, bitmap.Height));

    TheArtOfDev.HtmlRenderer.PdfSharp.HtmlContainer container = new TheArtOfDev.HtmlRenderer.PdfSharp.HtmlContainer();
    container.SetHtml(_body);

    PdfDocument pdf = new PdfDocument();
    PdfPage page = new PdfPage();
    XImage img = XImage.FromGdiPlusImage(bitmap);
    pdf.Pages.Add(page);
    XGraphics xgr = XGraphics.FromPdfPage(pdf.Pages[0]);
    container.PerformLayout(xgr);
    container.PerformPaint(xgr);
    xgr.DrawImage(img, 0, 0);
    pdf.Save(_stream, false);
}
4

2 回答 2

0

问题出在解码的正文中,而不是在 pdf 生成器中。将关闭此问题并打开一个新问题。

于 2020-06-22T05:27:32.523 回答
-1

您可以使用 html2canvas,这肯定会解决您的问题。

const doc = new jsPDF();
        var canvasElement = document.createElement('canvas');
         html2canvas(this.$refs.content, { canvas: canvasElement 
           }).then(function (canvas) {
         const img = canvas.toDataURL("image/jpeg", 0.8);
         doc.addImage(img,'JPEG',30,20);
         doc.save("pdfName.pdf");
        });

不要忘记导入:

import jsPDF from 'jspdf' 
import html2canvas from "html2canvas"
于 2020-06-19T08:55:54.230 回答