2011-09-27 05:28:16 +09:00
|
|
|
'use strict';
|
2011-09-15 09:34:29 +09:00
|
|
|
|
2017-02-10 00:53:52 +09:00
|
|
|
// In production, the bundled pdf.js shall be used instead of SystemJS.
|
2017-05-11 08:28:18 +09:00
|
|
|
Promise.all([System.import('pdfjs/display/api'),
|
|
|
|
System.import('pdfjs/display/global'),
|
2017-07-30 05:47:46 +09:00
|
|
|
System.import('pdfjs/display/network'),
|
2017-05-11 08:28:18 +09:00
|
|
|
System.resolve('pdfjs/worker_loader')])
|
2017-02-10 00:53:52 +09:00
|
|
|
.then(function (modules) {
|
2017-09-05 21:47:14 +09:00
|
|
|
var api = modules[0], global = modules[1], network = modules[2];
|
|
|
|
api.setPDFNetworkStreamClass(network.PDFNetworkStream);
|
|
|
|
|
2015-12-17 06:03:06 +09:00
|
|
|
// In production, change this to point to the built `pdf.worker.js` file.
|
2017-07-30 05:47:46 +09:00
|
|
|
global.PDFJS.workerSrc = modules[3];
|
2015-12-17 06:03:06 +09:00
|
|
|
|
|
|
|
// Fetch the PDF document from the URL using promises.
|
|
|
|
api.getDocument('helloworld.pdf').then(function (pdf) {
|
|
|
|
// Fetch the page.
|
|
|
|
pdf.getPage(1).then(function (page) {
|
|
|
|
var scale = 1.5;
|
|
|
|
var viewport = page.getViewport(scale);
|
2011-09-15 09:34:29 +09:00
|
|
|
|
2015-12-17 06:03:06 +09:00
|
|
|
// Prepare canvas using PDF page dimensions.
|
|
|
|
var canvas = document.getElementById('the-canvas');
|
|
|
|
var context = canvas.getContext('2d');
|
|
|
|
canvas.height = viewport.height;
|
|
|
|
canvas.width = viewport.width;
|
2011-09-15 09:34:29 +09:00
|
|
|
|
2015-12-17 06:03:06 +09:00
|
|
|
// Render PDF page into canvas context.
|
|
|
|
var renderContext = {
|
|
|
|
canvasContext: context,
|
|
|
|
viewport: viewport
|
|
|
|
};
|
|
|
|
page.render(renderContext);
|
|
|
|
});
|
2012-04-13 00:23:38 +09:00
|
|
|
});
|
2011-09-15 09:34:29 +09:00
|
|
|
});
|