pdf.js/examples/acroforms/forms.js

161 lines
5.1 KiB
JavaScript
Raw Normal View History

2011-12-20 11:00:50 +09:00
//
// Basic AcroForms input controls rendering
//
'use strict';
// Specify the PDF with AcroForm here
var pdfWithFormsPath = '../../test/pdfs/f1040.pdf';
2011-12-20 11:00:50 +09:00
var formFields = {};
2012-04-13 00:23:38 +09:00
function setupForm(div, content, viewport) {
2011-12-20 11:00:50 +09:00
function bindInputItem(input, item) {
if (input.name in formFields) {
var value = formFields[input.name];
if (input.type == 'checkbox') {
2011-12-20 11:00:50 +09:00
input.checked = value;
} else if (!input.type || input.type == 'text') {
2011-12-20 11:00:50 +09:00
input.value = value;
}
2011-12-20 11:00:50 +09:00
}
input.onchange = function pageViewSetupInputOnBlur() {
if (input.type == 'checkbox') {
2011-12-20 11:00:50 +09:00
formFields[input.name] = input.checked;
} else if (!input.type || input.type == 'text') {
2011-12-20 11:00:50 +09:00
formFields[input.name] = input.value;
}
2011-12-20 11:00:50 +09:00
};
}
function createElementWithStyle(tagName, item) {
var element = document.createElement(tagName);
var rect = PDFJS.Util.normalizeRect(
2012-04-13 00:23:38 +09:00
viewport.convertToViewportRectangle(item.rect));
element.style.left = Math.floor(rect[0]) + 'px';
element.style.top = Math.floor(rect[1]) + 'px';
element.style.width = Math.ceil(rect[2] - rect[0]) + 'px';
element.style.height = Math.ceil(rect[3] - rect[1]) + 'px';
2011-12-20 11:00:50 +09:00
return element;
}
function assignFontStyle(element, item) {
var fontStyles = '';
2012-04-13 00:23:38 +09:00
if ('fontSize' in item) {
fontStyles += 'font-size: ' + Math.round(item.fontSize *
viewport.fontScale) + 'px;';
2012-04-13 00:23:38 +09:00
}
2011-12-20 11:00:50 +09:00
switch (item.textAlignment) {
case 0:
fontStyles += 'text-align: left;';
break;
case 1:
fontStyles += 'text-align: center;';
break;
case 2:
fontStyles += 'text-align: right;';
break;
}
element.setAttribute('style', element.getAttribute('style') + fontStyles);
}
2012-04-13 00:23:38 +09:00
content.getAnnotations().then(function(items) {
for (var i = 0; i < items.length; i++) {
var item = items[i];
2014-02-22 22:46:13 +09:00
switch (item.subtype) {
2012-04-13 00:23:38 +09:00
case 'Widget':
if (item.fieldType != 'Tx' && item.fieldType != 'Btn' &&
item.fieldType != 'Ch') {
2012-04-13 00:23:38 +09:00
break;
}
2012-04-13 00:23:38 +09:00
var inputDiv = createElementWithStyle('div', item);
inputDiv.className = 'inputHint';
div.appendChild(inputDiv);
var input;
if (item.fieldType == 'Tx') {
input = createElementWithStyle('input', item);
2011-12-20 11:00:50 +09:00
}
2012-04-13 00:23:38 +09:00
if (item.fieldType == 'Btn') {
input = createElementWithStyle('input', item);
if (item.flags & 32768) {
input.type = 'radio';
// radio button is not supported
} else if (item.flags & 65536) {
input.type = 'button';
// pushbutton is not supported
} else {
input.type = 'checkbox';
}
}
if (item.fieldType == 'Ch') {
input = createElementWithStyle('select', item);
// select box is not supported
}
input.className = 'inputControl';
input.name = item.fullName;
input.title = item.alternativeText;
assignFontStyle(input, item);
bindInputItem(input, item);
div.appendChild(input);
break;
}
2011-12-20 11:00:50 +09:00
}
2012-04-13 00:23:38 +09:00
});
2011-12-20 11:00:50 +09:00
}
function renderPage(div, pdf, pageNumber, callback) {
2012-04-13 00:23:38 +09:00
pdf.getPage(pageNumber).then(function(page) {
var scale = 1.5;
var viewport = page.getViewport(scale);
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
var pageDisplayWidth = viewport.width;
var pageDisplayHeight = viewport.height;
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
var pageDivHolder = document.createElement('div');
pageDivHolder.className = 'pdfpage';
pageDivHolder.style.width = pageDisplayWidth + 'px';
pageDivHolder.style.height = pageDisplayHeight + 'px';
div.appendChild(pageDivHolder);
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
// Prepare canvas using PDF page dimensions
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
canvas.width = pageDisplayWidth;
canvas.height = pageDisplayHeight;
pageDivHolder.appendChild(canvas);
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
// Render PDF page into canvas context
var renderContext = {
canvasContext: context,
viewport: viewport
};
2014-02-22 22:46:13 +09:00
page.render(renderContext).promise.then(callback);
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
// Prepare and populate form elements layer
var formDiv = document.createElement('div');
pageDivHolder.appendChild(formDiv);
2011-12-20 11:00:50 +09:00
2012-04-13 00:23:38 +09:00
setupForm(formDiv, page, viewport);
});
2011-12-20 11:00:50 +09:00
}
// In production, the bundled pdf.js shall be used instead of RequireJS.
require.config({paths: {'pdfjs': '../../src'}});
require(['pdfjs/display/api'], function (api) {
// In production, change this to point to the built `pdf.worker.js` file.
PDFJS.workerSrc = '../../src/worker_loader.js';
// Fetch the PDF document from the URL using promises.
api.getDocument(pdfWithFormsPath).then(function getPdfForm(pdf) {
// Rendering all pages starting from first
var viewer = document.getElementById('viewer');
var pageNumber = 1;
renderPage(viewer, pdf, pageNumber++, function pageRenderingComplete() {
if (pageNumber > pdf.numPages) {
return; // All pages rendered
}
// Continue rendering of the next page
renderPage(viewer, pdf, pageNumber++, pageRenderingComplete);
});
2011-12-20 11:00:50 +09:00
});
});