使用PDF.js生成pdf的缩略图

时间:2017-06-14 14:27:10

标签: javascript php pdfjs

我想使用PDF.js从pdf文件生成缩略图,但它不像只有一个文件的其他js,所有需要在项目中包含js的都是写:

<script src="any.js"></script>

如何在我的项目中使用PDF.js?我在后端使用PHP。

2 个答案:

答案 0 :(得分:8)

基于helloworld example

&#13;
&#13;
function makeThumb(page) {
  // draw page to fit into 96x96 canvas
  var vp = page.getViewport(1);
  var canvas = document.createElement("canvas");
  canvas.width = canvas.height = 96;
  var scale = Math.min(canvas.width / vp.width, canvas.height / vp.height);
  return page.render({canvasContext: canvas.getContext("2d"), viewport: page.getViewport(scale)}).promise.then(function () {
    return canvas;
  });
}

PDFJS.getDocument("//cdn.mozilla.net/pdfjs/tracemonkey.pdf").promise.then(function (doc) {
  var pages = []; while (pages.length < doc.numPages) pages.push(pages.length + 1);
  return Promise.all(pages.map(function (num) {
    // create a div for each page and build a small canvas for it
    var div = document.createElement("div");
    document.body.appendChild(div);
    return doc.getPage(num).then(makeThumb)
      .then(function (canvas) {
        div.appendChild(canvas);
    });
  }));
}).catch(console.error);
&#13;
<script src="//npmcdn.com/pdfjs-dist/build/pdf.js"></script>
&#13;
&#13;
&#13;

答案 1 :(得分:0)

我想通了,比例不是参数。参数是需要设置比例尺的对象。

function makeThumb(page) {
    // draw page to fit into 96x96 canvas
    var vp = page.getViewport({ scale: 1, });
    var canvas = document.createElement("canvas");
    var scalesize = 1;
    canvas.width = vp.width * scalesize;
    canvas.height = vp.height * scalesize;
    var scale = Math.min(canvas.width / vp.width, canvas.height / vp.height);
    console.log(vp.width, vp.height, scale);
    return page.render({ canvasContext: canvas.getContext("2d"), viewport: page.getViewport({ scale: scale }) }).promise.then(function () {
        return canvas; 
    });
}