/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- / /* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */ 'use strict'; var WorkerProcessorHandler = { setup: function(handler) { var pdfDoc = null; handler.on("doc", function(data) { pdfDoc = new PDFDoc(new Stream(data)); }); handler.on("page_request", function(pageNum) { pageNum = parseInt(pageNum); var page = pdfDoc.getPage(pageNum); // The following code does quite the same as Page.prototype.startRendering, // but stops at one point and sends the result back to the main thread. var gfx = new CanvasGraphics(null); var start = Date.now(); var dependency = []; // Pre compile the pdf page and fetch the fonts/images. var IRQueue = page.getIRQueue(handler, dependency); console.log("page=%d - getIRQueue: time=%dms, len=%d", pageNum, Date.now() - start, IRQueue.fnArray.length); if (false /* show used commands */) { var cmdMap = {}; var fnArray = IRQueue .fnArray; for (var i = 0; i < fnArray.length; i++) { var entry = fnArray[i]; if (entry == "paintReadyFormXObject") { //console.log(preCompilation.argsArray[i]); } if (cmdMap[entry] == null) { cmdMap[entry] = 1; } else { cmdMap[entry] += 1; } } console.log("cmds", JSON.stringify(cmdMap)); } // Filter the dependecies for fonts. var fonts = {}; for (var i = 0; i < dependency.length; i++) { var dep = dependency[i]; if (dep.indexOf('font_') == 0) { fonts[dep] = true; } } handler.send("page", { pageNum: pageNum, IRQueue: IRQueue, depFonts: Object.keys(fonts) }); }, this); } }