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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user