Подтвердить что ты не робот

Render Svg для Pdf с использованием jspdf

У меня возникли проблемы с отображением svg-элемента в pdf с помощью jspdf. Iam, используя плагин https://github.com/CBiX/svgToPdf.js/, чтобы сделать это.

Ниже мой код

// I recommend to keep the svg visible as a preview
var tmp = document.getElementById("chartContainer");
var svgDoc = tmp.getElementsByTagName("svg")[0];
var pdf = new jsPDF('p', 'pt', 'a4');
svgElementToPdf(svgDoc, pdf, {
scale: 72 / 96, // this is the ratio of px to pt units
removeInvalid: false // this removes elements that could not be translated to pdf from the source        svg
});
pdf.output('datauri'); // use output() to get the jsPDF buffer

Это просто пустой pdf. Пожалуйста, помогите

4b9b3361

Ответ 1

Вы можете сделать это с помощью canvg.

Шаг1: Получите код разметки "SVG" из DOM

var svg = document.getElementById('svg-container').innerHTML;

  if (svg)
    svg = svg.replace(/\r?\n|\r/g, '').trim();

Шаг 2: Используйте canvg, чтобы создать холст из svg.

  var canvas = document.createElement('canvas');
  canvg(canvas, svg);

Шаг 3: Создайте изображение с холста, используя .toDataURL()

  var imgData = canvas.toDataURL('image/png');
  // Generate PDF
  var doc = new jsPDF('p', 'pt', 'a4');
  doc.addImage(imgData, 'PNG', 40, 40, 75, 75);
  doc.save('test.pdf');

Проверьте демо здесь http://jsfiddle.net/Purushoth/hvs91vpq/193/

Canvg Repo: https://github.com/gabelerner/canvg