angular jspaf

import { Component, OnInit } from '@angular/core';
import * as jsPDF from 'jspdf';
import html2canvas from "html2canvas";

@Component({
  selector: 'app-desigin',
  templateUrl: './desigin.component.html',
  styleUrls: ['./desigin.component.css']
})
export class DesiginComponent implements OnInit {

  constructor() { }
  ngOnInit() {

  }
  btn() {

    var target:any = document.getElementsByClassName("right-aside")[0];
    console.log(target)
    target.style.background = "#FFFFFF";

    console.log(html2canvas);
    console.log(jsPDF);
    html2canvas(target).then(function (canvas) {

          console.log(12)
          var contentWidth = canvas.width;
          var contentHeight = canvas.height;

          //一頁pdf顯示html頁面生成的canvas高度;
          var pageHeight = contentWidth / 592.28 * 841.89;
          //未生成pdf的html頁面高度
          var leftHeight = contentHeight;
          //頁面偏移
          var position = 0;
          //a4紙的尺寸[595.28,841.89],html頁面生成的canvas在pdf中圖片的寬高
          var imgWidth = 595.28;
          var imgHeight = 592.28/contentWidth * contentHeight;

          var pageData = canvas.toDataURL('image/jpeg', 1.0);

          var pdf = new jsPDF('', 'pt', 'a4');

          //有兩個高度須要區分,一個是html頁面的實際高度,和生成pdf的頁面高度(841.89)
          //當內容未超過pdf一頁顯示的範圍,無需分頁
          if (leftHeight < pageHeight) {
            pdf.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight );
          } else {
            while(leftHeight > 0) {
              pdf.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)
              leftHeight -= pageHeight;
              position -= 841.89;
              //避免添加空白頁
              if(leftHeight > 0) {
                pdf.addPage();
              }
            }
          }
          pdf.save("content.pdf");
          // 轉base64
          var datauri = pdf.output('dataurlstring')
          var base64 = datauri.substring(28);
          console.log(base64);
        }
    )

  }

}
相關文章
相關標籤/搜索