Refactor to execute IR on main thead by posting messages to itself
This commit is contained in:
parent
a3baea5fcb
commit
ac4a57e858
1
pdf.js
1
pdf.js
@ -5802,6 +5802,7 @@ var ColorSpace = (function() {
|
|||||||
return "DeviceCmykCS";
|
return "DeviceCmykCS";
|
||||||
break;
|
break;
|
||||||
case 'Pattern':
|
case 'Pattern':
|
||||||
|
console.log("ColorSpace Pattern");
|
||||||
// TODO: IMPLEMENT ME
|
// TODO: IMPLEMENT ME
|
||||||
|
|
||||||
// var baseCS = cs[1];
|
// var baseCS = cs[1];
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
<script type="text/javascript" src="../metrics.js"></script>
|
<script type="text/javascript" src="../metrics.js"></script>
|
||||||
<script type="text/javascript" src="../worker.js"></script>
|
<script type="text/javascript" src="../worker.js"></script>
|
||||||
<script type="text/javascript" src="../worker/message_handler.js"></script>
|
<script type="text/javascript" src="../worker/message_handler.js"></script>
|
||||||
|
<script type="text/javascript" src="../worker/handler.js"></script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
|
67
worker.js
67
worker.js
@ -60,31 +60,48 @@ var WorkerPDFDoc = (function() {
|
|||||||
|
|
||||||
this.pageCache = [];
|
this.pageCache = [];
|
||||||
|
|
||||||
this.worker = new Worker("../worker/boot.js");
|
var useWorker = false;
|
||||||
this.handler = new MessageHandler("main", {
|
|
||||||
"page": function(data) {
|
|
||||||
var pageNum = data.pageNum;
|
|
||||||
var page = this.pageCache[pageNum];
|
|
||||||
|
|
||||||
// Add necessary shape back to fonts.
|
|
||||||
var fonts = data.fonts;
|
|
||||||
for (var i = 0; i < fonts.length; i++) {
|
|
||||||
var font = fonts[i];
|
|
||||||
|
|
||||||
var fontFileDict = new Dict();
|
|
||||||
fontFileDict.map = font.file.dict.map;
|
|
||||||
|
|
||||||
var fontFile = new Stream(font.file.bytes, font.file.start,
|
|
||||||
font.file.end - font.file.start, fontFileDict);
|
|
||||||
font.file = new FlateStream(fontFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log("startRenderingFromPreCompilation:", "numberOfFonts", fonts.length);
|
|
||||||
page.startRenderingFromPreCompilation(data.preCompilation, data.fonts, data.images);
|
|
||||||
}
|
|
||||||
}, this.worker, this);
|
|
||||||
|
|
||||||
this.handler.send("doc", data);
|
if (useWorker) {
|
||||||
|
var worker = new Worker("../worker/boot.js");
|
||||||
|
} else {
|
||||||
|
// If we don't use a worker, just post/sendMessage to the main thread.
|
||||||
|
var worker = {
|
||||||
|
postMessage: function(obj) {
|
||||||
|
worker.onmessage({data: obj});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var handler = this.handler = new MessageHandler("main", worker);
|
||||||
|
handler.on("page", function(data) {
|
||||||
|
var pageNum = data.pageNum;
|
||||||
|
var page = this.pageCache[pageNum];
|
||||||
|
|
||||||
|
// Add necessary shape back to fonts.
|
||||||
|
var fonts = data.fonts;
|
||||||
|
for (var i = 0; i < fonts.length; i++) {
|
||||||
|
var font = fonts[i];
|
||||||
|
|
||||||
|
var fontFileDict = new Dict();
|
||||||
|
fontFileDict.map = font.file.dict.map;
|
||||||
|
|
||||||
|
var fontFile = new Stream(font.file.bytes, font.file.start,
|
||||||
|
font.file.end - font.file.start, fontFileDict);
|
||||||
|
font.file = new FlateStream(fontFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("startRenderingFromPreCompilation:", "numberOfFonts", fonts.length);
|
||||||
|
page.startRenderingFromPreCompilation(data.preCompilation, data.fonts, data.images);
|
||||||
|
}, this);
|
||||||
|
|
||||||
|
if (!useWorker) {
|
||||||
|
// If the main thread is our worker, setup the handling for the messages
|
||||||
|
// the main thread sends to it self.
|
||||||
|
WorkerHandler.setup(handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
handler.send("doc", data);
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor.prototype = {
|
constructor.prototype = {
|
||||||
@ -93,7 +110,7 @@ var WorkerPDFDoc = (function() {
|
|||||||
},
|
},
|
||||||
|
|
||||||
startRendering: function(page) {
|
startRendering: function(page) {
|
||||||
this.handler.send("page", page.page.pageNumber + 1);
|
this.handler.send("page_request", page.page.pageNumber + 1);
|
||||||
},
|
},
|
||||||
|
|
||||||
getPage: function(n) {
|
getPage: function(n) {
|
||||||
|
@ -9,82 +9,10 @@ importScripts('../pdf.js');
|
|||||||
importScripts('../fonts.js');
|
importScripts('../fonts.js');
|
||||||
importScripts('../crypto.js');
|
importScripts('../crypto.js');
|
||||||
importScripts('../glyphlist.js');
|
importScripts('../glyphlist.js');
|
||||||
|
importScripts('handler.js');
|
||||||
|
|
||||||
// Listen for messages from the main thread.
|
// Listen for messages from the main thread.
|
||||||
var pdfDoc = null;
|
var pdfDoc = null;
|
||||||
|
|
||||||
var handler = new MessageHandler("worker", {
|
var handler = new MessageHandler("worker", this);
|
||||||
"doc": function(data) {
|
WorkerHandler.setup(handler);
|
||||||
pdfDoc = new PDFDoc(new Stream(data));
|
|
||||||
console.log("setup pdfDoc");
|
|
||||||
},
|
|
||||||
|
|
||||||
"page": function(pageNum) {
|
|
||||||
pageNum = parseInt(pageNum);
|
|
||||||
console.log("about to process page", 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 fonts = [];
|
|
||||||
// TODO: Figure out how image loading is handled inside the worker.
|
|
||||||
var images = new ImagesLoader();
|
|
||||||
|
|
||||||
// Pre compile the pdf page and fetch the fonts/images.
|
|
||||||
var preCompilation = page.preCompile(gfx, fonts, images);
|
|
||||||
|
|
||||||
// Extract the minimum of font data that is required to build all required
|
|
||||||
// font stuff on the main thread.
|
|
||||||
var fontsMin = [];
|
|
||||||
for (var i = 0; i < fonts.length; i++) {
|
|
||||||
var font = fonts[i];
|
|
||||||
|
|
||||||
fontsMin.push({
|
|
||||||
name: font.name,
|
|
||||||
file: font.file,
|
|
||||||
properties: font.properties
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Handle images here.
|
|
||||||
|
|
||||||
console.log("about to send page", pageNum);
|
|
||||||
|
|
||||||
if (true /* show used commands */) {
|
|
||||||
var cmdMap = {};
|
|
||||||
|
|
||||||
var fnArray = preCompilation.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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// // Make a copy of the fnArray and show all cmds it has.
|
|
||||||
// var fnArray = preCompilation.fnArray.slice(0).sort();
|
|
||||||
// for (var i = 0; i < fnArray.length; true) {
|
|
||||||
// if (fnArray[i] == fnArray[i + 1]) {
|
|
||||||
// fnArray.splice(i, 1);
|
|
||||||
// } else {
|
|
||||||
// i++;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
console.log("cmds", JSON.stringify(cmdMap));
|
|
||||||
}
|
|
||||||
|
|
||||||
handler.send("page", {
|
|
||||||
pageNum: pageNum,
|
|
||||||
fonts: fontsMin,
|
|
||||||
images: [],
|
|
||||||
preCompilation: preCompilation,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
|
84
worker/handler.js
Normal file
84
worker/handler.js
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
/* -*- 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 WorkerHandler = {
|
||||||
|
setup: function(handler) {
|
||||||
|
var pdfDoc = null;
|
||||||
|
|
||||||
|
handler.on("doc", function(data) {
|
||||||
|
pdfDoc = new PDFDoc(new Stream(data));
|
||||||
|
console.log("setup pdfDoc");
|
||||||
|
});
|
||||||
|
|
||||||
|
handler.on("page_request", function(pageNum) {
|
||||||
|
pageNum = parseInt(pageNum);
|
||||||
|
console.log("about to process page", 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 fonts = [];
|
||||||
|
// TODO: Figure out how image loading is handled inside the worker.
|
||||||
|
var images = new ImagesLoader();
|
||||||
|
|
||||||
|
// Pre compile the pdf page and fetch the fonts/images.
|
||||||
|
var preCompilation = page.preCompile(gfx, fonts, images);
|
||||||
|
|
||||||
|
// Extract the minimum of font data that is required to build all required
|
||||||
|
// font stuff on the main thread.
|
||||||
|
var fontsMin = [];
|
||||||
|
for (var i = 0; i < fonts.length; i++) {
|
||||||
|
var font = fonts[i];
|
||||||
|
|
||||||
|
fontsMin.push({
|
||||||
|
name: font.name,
|
||||||
|
file: font.file,
|
||||||
|
properties: font.properties
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Handle images here.
|
||||||
|
|
||||||
|
console.log("about to send page", pageNum);
|
||||||
|
|
||||||
|
if (true /* show used commands */) {
|
||||||
|
var cmdMap = {};
|
||||||
|
|
||||||
|
var fnArray = preCompilation.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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// // Make a copy of the fnArray and show all cmds it has.
|
||||||
|
// var fnArray = preCompilation.fnArray.slice(0).sort();
|
||||||
|
// for (var i = 0; i < fnArray.length; true) {
|
||||||
|
// if (fnArray[i] == fnArray[i + 1]) {
|
||||||
|
// fnArray.splice(i, 1);
|
||||||
|
// } else {
|
||||||
|
// i++;
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
console.log("cmds", JSON.stringify(cmdMap));
|
||||||
|
}
|
||||||
|
|
||||||
|
handler.send("page", {
|
||||||
|
pageNum: pageNum,
|
||||||
|
fonts: fontsMin,
|
||||||
|
images: [],
|
||||||
|
preCompilation: preCompilation,
|
||||||
|
});
|
||||||
|
}, this);
|
||||||
|
}
|
||||||
|
}
|
@ -4,29 +4,41 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
|
||||||
function MessageHandler(name, actionHandler, comObj, scope) {
|
function MessageHandler(name, comObj) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
this.comObj = comObj;
|
||||||
|
var ah = this.actionHandler = {};
|
||||||
|
|
||||||
actionHandler["console_log"] = function(data) {
|
ah["console_log"] = [function(data) {
|
||||||
console.log.apply(console, data);
|
console.log.apply(console, data);
|
||||||
}
|
}]
|
||||||
actionHandler["console_error"] = function(data) {
|
ah["console_error"] = [function(data) {
|
||||||
console.error.apply(console, data);
|
console.error.apply(console, data);
|
||||||
}
|
}]
|
||||||
|
|
||||||
|
|
||||||
comObj.onmessage = function(event) {
|
comObj.onmessage = function(event) {
|
||||||
var data = event.data;
|
var data = event.data;
|
||||||
if (data.action in actionHandler) {
|
if (data.action in ah) {
|
||||||
actionHandler[data.action].call(scope, data.data);
|
var action = ah[data.action];
|
||||||
|
action[0].call(action[1], data.data);
|
||||||
} else {
|
} else {
|
||||||
throw 'Unkown action from worker: ' + data.action;
|
throw 'Unkown action from worker: ' + data.action;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
}
|
||||||
this.send = function(actionName, data) {
|
|
||||||
|
MessageHandler.prototype = {
|
||||||
|
on: function(actionName, handler, scope) {
|
||||||
|
var ah = this.actionHandler;
|
||||||
|
if (ah[actionName]) {
|
||||||
|
throw "There is already an actionName called '" + actionName + "'";
|
||||||
|
}
|
||||||
|
ah[actionName] = [handler, scope];
|
||||||
|
},
|
||||||
|
|
||||||
|
send: function(actionName, data) {
|
||||||
try {
|
try {
|
||||||
comObj.postMessage({
|
this.comObj.postMessage({
|
||||||
action: actionName,
|
action: actionName,
|
||||||
data: data
|
data: data
|
||||||
});
|
});
|
||||||
@ -35,4 +47,6 @@ function MessageHandler(name, actionHandler, comObj, scope) {
|
|||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user