Remove no longer needed code and rename IR forms to the standard ones
This commit is contained in:
parent
a4cfc44409
commit
e7fa637bf4
210
pdf.js
210
pdf.js
@ -4294,7 +4294,7 @@ var PartialEvaluator = (function() {
|
|||||||
var matrix = xobj.dict.get('Matrix');
|
var matrix = xobj.dict.get('Matrix');
|
||||||
var bbox = xobj.dict.get('BBox');
|
var bbox = xobj.dict.get('BBox');
|
||||||
args = [ raw, matrix, bbox ];
|
args = [ raw, matrix, bbox ];
|
||||||
fn = "paintReadyFormXObject";
|
fn = "paintFormXObject";
|
||||||
} else if ('Image' == type.name) {
|
} else if ('Image' == type.name) {
|
||||||
var image = xobj;
|
var image = xobj;
|
||||||
var dict = image.dict;
|
var dict = image.dict;
|
||||||
@ -4309,7 +4309,7 @@ var PartialEvaluator = (function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// TODO: Place dependency note in IR queue.
|
// TODO: Place dependency note in IR queue.
|
||||||
fn = 'paintReadyJpegXObject';
|
fn = 'paintJpegXObject';
|
||||||
args = [ objId, w, h ];
|
args = [ objId, w, h ];
|
||||||
} else {
|
} else {
|
||||||
// Needs to be rendered ourself.
|
// Needs to be rendered ourself.
|
||||||
@ -4335,7 +4335,7 @@ var PartialEvaluator = (function() {
|
|||||||
var pixels = imgData.data;
|
var pixels = imgData.data;
|
||||||
imageObj.fillRgbaBuffer(pixels, imageObj.decode);
|
imageObj.fillRgbaBuffer(pixels, imageObj.decode);
|
||||||
|
|
||||||
fn = "paintReadyImageXObject";
|
fn = "paintImageXObject";
|
||||||
args = [ imgData ];
|
args = [ imgData ];
|
||||||
} else /* imageMask == true */ {
|
} else /* imageMask == true */ {
|
||||||
// This depends on a tmpCanvas beeing filled with the
|
// This depends on a tmpCanvas beeing filled with the
|
||||||
@ -4343,7 +4343,7 @@ var PartialEvaluator = (function() {
|
|||||||
// data can't be done here. Instead of creating a
|
// data can't be done here. Instead of creating a
|
||||||
// complete PDFImage, only read the information needed
|
// complete PDFImage, only read the information needed
|
||||||
// for later.
|
// for later.
|
||||||
fn = "paintReadyImageMaskXObject";
|
fn = "paintImageMaskXObject";
|
||||||
|
|
||||||
var width = dict.get('Width', 'W');
|
var width = dict.get('Width', 'W');
|
||||||
var height = dict.get('Height', 'H');
|
var height = dict.get('Height', 'H');
|
||||||
@ -4403,25 +4403,14 @@ var PartialEvaluator = (function() {
|
|||||||
error('No shading object found');
|
error('No shading object found');
|
||||||
|
|
||||||
var shadingFill = Pattern.parseShading(shading, null, xref, res, /* ctx */ null);
|
var shadingFill = Pattern.parseShading(shading, null, xref, res, /* ctx */ null);
|
||||||
var patternRaw = shadingFill.getPatternRaw();
|
var patternIR = shadingFill.getPatternRaw();
|
||||||
|
|
||||||
args = [ patternRaw ];
|
args = [ patternIR ];
|
||||||
fn = "shadingFillRaw";
|
fn = "shadingFill";
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
var skips = [ "setFillColorN" ];//[ "paintReadyFormXObject" ];
|
|
||||||
//var skips = ["setFillColorSpace", "setFillColor", "setStrokeColorSpace", "setStrokeColor"];
|
|
||||||
|
|
||||||
if (skips.indexOf(fn) != -1) {
|
|
||||||
// console.log("skipping", fn);
|
|
||||||
args = [];
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
fnArray.push(fn);
|
fnArray.push(fn);
|
||||||
argsArray.push(args);
|
argsArray.push(args);
|
||||||
args = [];
|
args = [];
|
||||||
@ -5308,20 +5297,6 @@ var CanvasGraphics = (function() {
|
|||||||
var color = cs.getRgb(arguments);
|
var color = cs.getRgb(arguments);
|
||||||
this.setStrokeRGBColor.apply(this, color);
|
this.setStrokeRGBColor.apply(this, color);
|
||||||
},
|
},
|
||||||
setStrokeColorN: function(/*...*/) {
|
|
||||||
var cs = this.current.strokeColorSpace;
|
|
||||||
|
|
||||||
if (cs.name == 'Pattern') {
|
|
||||||
// wait until fill to actually get the pattern, since Canvas
|
|
||||||
// calcualtes the pattern according to the current coordinate space,
|
|
||||||
// not the space when the pattern is set.
|
|
||||||
var pattern = Pattern.parse(arguments, cs, this.xref, this.res,
|
|
||||||
this.ctx);
|
|
||||||
this.current.strokeColor = pattern;
|
|
||||||
} else {
|
|
||||||
this.setStrokeColor.apply(this, arguments);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
getColorN_IR_Pattern: function(IR, cs) {
|
getColorN_IR_Pattern: function(IR, cs) {
|
||||||
if (IR[0] == "TilingPatternIR") {
|
if (IR[0] == "TilingPatternIR") {
|
||||||
// First, build the `color` var like it's done in the
|
// First, build the `color` var like it's done in the
|
||||||
@ -5355,25 +5330,12 @@ var CanvasGraphics = (function() {
|
|||||||
} else {
|
} else {
|
||||||
this.setStrokeColor.apply(this, arguments);
|
this.setStrokeColor.apply(this, arguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
setFillColor: function(/*...*/) {
|
setFillColor: function(/*...*/) {
|
||||||
var cs = this.current.fillColorSpace;
|
var cs = this.current.fillColorSpace;
|
||||||
var color = cs.getRgb(arguments);
|
var color = cs.getRgb(arguments);
|
||||||
this.setFillRGBColor.apply(this, color);
|
this.setFillRGBColor.apply(this, color);
|
||||||
},
|
},
|
||||||
setFillColorN: function(/*...*/) {
|
|
||||||
var cs = this.current.fillColorSpace;
|
|
||||||
|
|
||||||
if (cs.name == 'Pattern') {
|
|
||||||
// wait until fill to actually get the pattern
|
|
||||||
var pattern = Pattern.parse(arguments, cs, this.xref, this.res,
|
|
||||||
this.ctx);
|
|
||||||
this.current.fillColor = pattern;
|
|
||||||
} else {
|
|
||||||
this.setFillColor.apply(this, arguments);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
setFillColorN_IR: function(/*...*/) {
|
setFillColorN_IR: function(/*...*/) {
|
||||||
var cs = this.current.fillColorSpace;
|
var cs = this.current.fillColorSpace;
|
||||||
|
|
||||||
@ -5410,24 +5372,11 @@ var CanvasGraphics = (function() {
|
|||||||
this.current.fillColor = color;
|
this.current.fillColor = color;
|
||||||
},
|
},
|
||||||
|
|
||||||
// Shading
|
shadingFill: function(patternIR) {
|
||||||
shadingFill: function(shadingName) {
|
|
||||||
var xref = this.xref;
|
|
||||||
var res = this.res;
|
|
||||||
var ctx = this.ctx;
|
var ctx = this.ctx;
|
||||||
|
|
||||||
var shadingRes = xref.fetchIfRef(res.get('Shading'));
|
|
||||||
if (!shadingRes)
|
|
||||||
error('No shading resource found');
|
|
||||||
|
|
||||||
var shading = xref.fetchIfRef(shadingRes.get(shadingName.name));
|
|
||||||
if (!shading)
|
|
||||||
error('No shading object found');
|
|
||||||
|
|
||||||
var shadingFill = Pattern.parseShading(shading, null, xref, res, ctx);
|
|
||||||
|
|
||||||
this.save();
|
this.save();
|
||||||
ctx.fillStyle = shadingFill.getPattern();
|
ctx.fillStyle = Pattern.shadingFromRaw(ctx, patternIR);
|
||||||
|
|
||||||
var inv = ctx.mozCurrentTransformInverse;
|
var inv = ctx.mozCurrentTransformInverse;
|
||||||
if (inv) {
|
if (inv) {
|
||||||
@ -5459,43 +5408,6 @@ var CanvasGraphics = (function() {
|
|||||||
this.restore();
|
this.restore();
|
||||||
},
|
},
|
||||||
|
|
||||||
shadingFillRaw: function(patternRaw) {
|
|
||||||
var ctx = this.ctx;
|
|
||||||
|
|
||||||
this.save();
|
|
||||||
ctx.fillStyle = Pattern.shadingFromRaw(ctx, patternRaw);
|
|
||||||
|
|
||||||
var inv = ctx.mozCurrentTransformInverse;
|
|
||||||
if (inv) {
|
|
||||||
var canvas = ctx.canvas;
|
|
||||||
var width = canvas.width;
|
|
||||||
var height = canvas.height;
|
|
||||||
|
|
||||||
var bl = Util.applyTransform([0, 0], inv);
|
|
||||||
var br = Util.applyTransform([0, width], inv);
|
|
||||||
var ul = Util.applyTransform([height, 0], inv);
|
|
||||||
var ur = Util.applyTransform([height, width], inv);
|
|
||||||
|
|
||||||
var x0 = Math.min(bl[0], br[0], ul[0], ur[0]);
|
|
||||||
var y0 = Math.min(bl[1], br[1], ul[1], ur[1]);
|
|
||||||
var x1 = Math.max(bl[0], br[0], ul[0], ur[0]);
|
|
||||||
var y1 = Math.max(bl[1], br[1], ul[1], ur[1]);
|
|
||||||
|
|
||||||
this.ctx.fillRect(x0, y0, x1 - x0, y1 - y0);
|
|
||||||
} else {
|
|
||||||
// HACK to draw the gradient onto an infinite rectangle.
|
|
||||||
// PDF gradients are drawn across the entire image while
|
|
||||||
// Canvas only allows gradients to be drawn in a rectangle
|
|
||||||
// The following bug should allow us to remove this.
|
|
||||||
// https://bugzilla.mozilla.org/show_bug.cgi?id=664884
|
|
||||||
|
|
||||||
this.ctx.fillRect(-1e10, -1e10, 2e10, 2e10);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.restore();
|
|
||||||
|
|
||||||
},
|
|
||||||
|
|
||||||
// Images
|
// Images
|
||||||
beginInlineImage: function() {
|
beginInlineImage: function() {
|
||||||
error('Should not call beginInlineImage');
|
error('Should not call beginInlineImage');
|
||||||
@ -5507,38 +5419,7 @@ var CanvasGraphics = (function() {
|
|||||||
this.paintImageXObject(null, image, true);
|
this.paintImageXObject(null, image, true);
|
||||||
},
|
},
|
||||||
|
|
||||||
// XObjects
|
paintFormXObject: function(raw, matrix, bbox) {
|
||||||
paintXObject: function(obj) {
|
|
||||||
var xobj = this.xobjs.get(obj.name);
|
|
||||||
if (!xobj)
|
|
||||||
return;
|
|
||||||
xobj = this.xref.fetchIfRef(xobj);
|
|
||||||
assertWellFormed(IsStream(xobj), 'XObject should be a stream');
|
|
||||||
|
|
||||||
var oc = xobj.dict.get('OC');
|
|
||||||
if (oc) {
|
|
||||||
TODO('oc for xobject');
|
|
||||||
}
|
|
||||||
|
|
||||||
var opi = xobj.dict.get('OPI');
|
|
||||||
if (opi) {
|
|
||||||
TODO('opi for xobject');
|
|
||||||
}
|
|
||||||
|
|
||||||
var type = xobj.dict.get('Subtype');
|
|
||||||
assertWellFormed(IsName(type), 'XObject should have a Name subtype');
|
|
||||||
if ('Image' == type.name) {
|
|
||||||
this.paintImageXObject(obj, xobj, false);
|
|
||||||
} else if ('Form' == type.name) {
|
|
||||||
this.paintFormXObject(obj, xobj);
|
|
||||||
} else if ('PS' == type.name) {
|
|
||||||
warn('(deprecated) PostScript XObjects are not supported');
|
|
||||||
} else {
|
|
||||||
malformed('Unknown XObject subtype ' + type.name);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
paintReadyFormXObject: function(raw, matrix, bbox) {
|
|
||||||
this.save();
|
this.save();
|
||||||
|
|
||||||
if (matrix && IsArray(matrix) && 6 == matrix.length)
|
if (matrix && IsArray(matrix) && 6 == matrix.length)
|
||||||
@ -5557,27 +5438,7 @@ var CanvasGraphics = (function() {
|
|||||||
this.restore();
|
this.restore();
|
||||||
},
|
},
|
||||||
|
|
||||||
paintFormXObject: function(ref, stream) {
|
paintJpegXObject: function(objId, w, h) {
|
||||||
this.save();
|
|
||||||
|
|
||||||
var matrix = stream.dict.get('Matrix');
|
|
||||||
if (matrix && IsArray(matrix) && 6 == matrix.length)
|
|
||||||
this.transform.apply(this, matrix);
|
|
||||||
|
|
||||||
var bbox = stream.dict.get('BBox');
|
|
||||||
if (bbox && IsArray(bbox) && 4 == bbox.length) {
|
|
||||||
this.rectangle.apply(this, bbox);
|
|
||||||
this.clip();
|
|
||||||
this.endPath();
|
|
||||||
}
|
|
||||||
|
|
||||||
var code = this.pe.evalFromRaw(ref.raw)
|
|
||||||
this.execute(code, this.xref, stream.dict.get('Resources'));
|
|
||||||
|
|
||||||
this.restore();
|
|
||||||
},
|
|
||||||
|
|
||||||
paintReadyJpegXObject: function(objId, w, h) {
|
|
||||||
var image = Objects[objId];
|
var image = Objects[objId];
|
||||||
if (!image) {
|
if (!image) {
|
||||||
error("Dependent image isn't ready yet");
|
error("Dependent image isn't ready yet");
|
||||||
@ -5595,52 +5456,7 @@ var CanvasGraphics = (function() {
|
|||||||
this.restore();
|
this.restore();
|
||||||
},
|
},
|
||||||
|
|
||||||
paintImageXObject: function(ref, image, inline) {
|
paintImageMaskXObject: function(imgArray, inverseDecode, width, height) {
|
||||||
this.save();
|
|
||||||
|
|
||||||
var ctx = this.ctx;
|
|
||||||
var dict = image.dict;
|
|
||||||
var w = dict.get('Width', 'W');
|
|
||||||
var h = dict.get('Height', 'H');
|
|
||||||
// scale the image to the unit square
|
|
||||||
ctx.scale(1 / w, -1 / h);
|
|
||||||
|
|
||||||
// If the platform can render the image format directly, the
|
|
||||||
// stream has a getImage property which directly returns a
|
|
||||||
// suitable DOM Image object.
|
|
||||||
if (image.getImage) {
|
|
||||||
var domImage = image.getImage();
|
|
||||||
ctx.drawImage(domImage, 0, 0, domImage.width, domImage.height,
|
|
||||||
0, -h, w, h);
|
|
||||||
this.restore();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var imageObj = new PDFImage(this.xref, this.res, image, inline);
|
|
||||||
|
|
||||||
var tmpCanvas = new this.ScratchCanvas(w, h);
|
|
||||||
var tmpCtx = tmpCanvas.getContext('2d');
|
|
||||||
if (imageObj.imageMask) {
|
|
||||||
var fillColor = this.current.fillColor;
|
|
||||||
tmpCtx.fillStyle = (fillColor && fillColor.type === 'Pattern') ?
|
|
||||||
fillColor.getPattern(tmpCtx) : fillColor;
|
|
||||||
tmpCtx.fillRect(0, 0, w, h);
|
|
||||||
}
|
|
||||||
var imgData = tmpCtx.getImageData(0, 0, w, h);
|
|
||||||
var pixels = imgData.data;
|
|
||||||
|
|
||||||
if (imageObj.imageMask) {
|
|
||||||
var inverseDecode = !!imageObj.decode && imageObj.decode[0] > 0;
|
|
||||||
imageObj.applyStencilMask(pixels, inverseDecode);
|
|
||||||
} else
|
|
||||||
imageObj.fillRgbaBuffer(pixels, imageObj.decode);
|
|
||||||
|
|
||||||
tmpCtx.putImageData(imgData, 0, 0);
|
|
||||||
ctx.drawImage(tmpCanvas, 0, -h);
|
|
||||||
this.restore();
|
|
||||||
},
|
|
||||||
|
|
||||||
paintReadyImageMaskXObject: function(imgArray, inverseDecode, width, height) {
|
|
||||||
function applyStencilMask(buffer, inverseDecode) {
|
function applyStencilMask(buffer, inverseDecode) {
|
||||||
var imgArrayPos = 0;
|
var imgArrayPos = 0;
|
||||||
var i, j, mask, buf;
|
var i, j, mask, buf;
|
||||||
@ -5688,7 +5504,7 @@ var CanvasGraphics = (function() {
|
|||||||
this.restore();
|
this.restore();
|
||||||
},
|
},
|
||||||
|
|
||||||
paintReadyImageXObject: function(imgData) {
|
paintImageXObject: function(imgData) {
|
||||||
this.save();
|
this.save();
|
||||||
|
|
||||||
var ctx = this.ctx;
|
var ctx = this.ctx;
|
||||||
|
Loading…
Reference in New Issue
Block a user