Merge pull request #29 from notmasteryet/jpegstream2
DCTDecode; text and images vertical inversion fix
This commit is contained in:
		
						commit
						6ae70b4421
					
				
							
								
								
									
										71
									
								
								pdf.js
									
									
									
									
									
								
							
							
						
						
									
										71
									
								
								pdf.js
									
									
									
									
									
								
							| @ -518,9 +518,38 @@ var FlateStream = (function() { | |||||||
|     return constructor; |     return constructor; | ||||||
| })(); | })(); | ||||||
| 
 | 
 | ||||||
|  | var JpegStream = (function() { | ||||||
|  |     function constructor(bytes, dict) { | ||||||
|  |         // TODO per poppler, some images may have "junk" before that need to be removed
 | ||||||
|  |         this.bytes = bytes; | ||||||
|  |         this.dict = dict; | ||||||
|  | 
 | ||||||
|  |         // create DOM image
 | ||||||
|  |         var buffer = "", i, n = bytes.length; | ||||||
|  |         for (i = 0; i < n; ++i) { | ||||||
|  |             buffer += String.fromCharCode(bytes[i]); | ||||||
|  |         } | ||||||
|  |         var img = new Image(); | ||||||
|  |         img.src = "data:image/jpeg;base64," + window.btoa(buffer); | ||||||
|  |         this.domImage = img; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     constructor.prototype = { | ||||||
|  |         getChar: function() { | ||||||
|  |             TODO("read direct pixels data"); | ||||||
|  |         }, | ||||||
|  |         getImage: function() { | ||||||
|  |             return this.domImage; | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     return constructor; | ||||||
|  | })(); | ||||||
|  | 
 | ||||||
| var PredictorStream = (function() { | var PredictorStream = (function() { | ||||||
|     function constructor(stream, params) { |     function constructor(stream, params) { | ||||||
|         this.stream = stream; |         this.stream = stream; | ||||||
|  |         this.dict = stream.dict; | ||||||
|         this.predictor = params.get("Predictor") || 1; |         this.predictor = params.get("Predictor") || 1; | ||||||
|         if (this.predictor <= 1) { |         if (this.predictor <= 1) { | ||||||
|             return stream; // no prediction
 |             return stream; // no prediction
 | ||||||
| @ -1186,15 +1215,15 @@ var Parser = (function() { | |||||||
|                                            this.encAlgorithm, |                                            this.encAlgorithm, | ||||||
|                                            this.keyLength); |                                            this.keyLength); | ||||||
|             } |             } | ||||||
|             stream = this.filter(stream, dict); |             stream = this.filter(stream, dict, length); | ||||||
|             stream.parameters = dict;  |             stream.parameters = dict;  | ||||||
|             return stream; |             return stream; | ||||||
|         }, |         }, | ||||||
|         filter: function(stream, dict) { |         filter: function(stream, dict, length) { | ||||||
|             var filter = dict.get2("Filter", "F"); |             var filter = dict.get2("Filter", "F"); | ||||||
|             var params = dict.get2("DecodeParms", "DP"); |             var params = dict.get2("DecodeParms", "DP"); | ||||||
|             if (IsName(filter)) |             if (IsName(filter)) | ||||||
|                 return this.makeFilter(stream, filter.name, params); |                 return this.makeFilter(stream, filter.name, length, params); | ||||||
|             if (IsArray(filter)) { |             if (IsArray(filter)) { | ||||||
|                 var filterArray = filter; |                 var filterArray = filter; | ||||||
|                 var paramsArray = params; |                 var paramsArray = params; | ||||||
| @ -1205,18 +1234,21 @@ var Parser = (function() { | |||||||
|                         params = null; |                         params = null; | ||||||
|                         if (IsArray(paramsArray) && (i in paramsArray)) |                         if (IsArray(paramsArray) && (i in paramsArray)) | ||||||
|                             params = paramsArray[i]; |                             params = paramsArray[i]; | ||||||
|                         stream = this.makeFilter(stream, filter.name, params); |                         stream = this.makeFilter(stream, filter.name, length, params); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             return stream; |             return stream; | ||||||
|         }, |         }, | ||||||
|         makeFilter: function(stream, name, params) { |         makeFilter: function(stream, name, length, params) { | ||||||
|             if (name == "FlateDecode" || name == "Fl") { |             if (name == "FlateDecode" || name == "Fl") { | ||||||
|                 if (params) { |                 if (params) { | ||||||
|                     return new PredictorStream(new FlateStream(stream), params); |                     return new PredictorStream(new FlateStream(stream), params); | ||||||
|                 } |                 } | ||||||
|                 return new FlateStream(stream); |                 return new FlateStream(stream); | ||||||
|  |             } else if (name == "DCTDecode") { | ||||||
|  |                 var bytes = stream.getBytes(length); | ||||||
|  |                 return new JpegStream(bytes, stream.dict); | ||||||
|             } else { |             } else { | ||||||
|                 error("filter '" + name + "' not supported yet"); |                 error("filter '" + name + "' not supported yet"); | ||||||
|             } |             } | ||||||
| @ -2403,11 +2435,17 @@ var CanvasGraphics = (function() { | |||||||
| 
 | 
 | ||||||
|             var fontName = ""; |             var fontName = ""; | ||||||
|             var fontDescriptor = font.get("FontDescriptor"); |             var fontDescriptor = font.get("FontDescriptor"); | ||||||
|             if (fontDescriptor.num) { |             if (fontDescriptor && fontDescriptor.num) { | ||||||
|                 var fontDescriptor = this.xref.fetchIfRef(fontDescriptor); |                 var fontDescriptor = this.xref.fetchIfRef(fontDescriptor); | ||||||
|                 fontName = fontDescriptor.get("FontName").name.replace("+", "_"); |                 fontName = fontDescriptor.get("FontName").name.replace("+", "_"); | ||||||
|                 Fonts.active = fontName; |                 Fonts.active = fontName; | ||||||
|             } |             } | ||||||
|  |             if (!fontName) { | ||||||
|  |                 // fontDescriptor is not available, fallback to default font (TODO ?)
 | ||||||
|  |                 this.current.fontSize = size; | ||||||
|  |                 this.ctx.font = this.current.fontSize + 'px sans-serif'; | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             this.current.fontSize = size; |             this.current.fontSize = size; | ||||||
|             this.ctx.font = this.current.fontSize +'px "' + fontName + '"'; |             this.ctx.font = this.current.fontSize +'px "' + fontName + '"'; | ||||||
| @ -2436,9 +2474,9 @@ var CanvasGraphics = (function() { | |||||||
|         }, |         }, | ||||||
|         showText: function(text) { |         showText: function(text) { | ||||||
|             this.ctx.save(); |             this.ctx.save(); | ||||||
|             this.ctx.translate(0, 2 * this.current.y); |  | ||||||
|             this.ctx.scale(1, -1); |  | ||||||
|             this.ctx.transform.apply(this.ctx, this.current.textMatrix); |             this.ctx.transform.apply(this.ctx, this.current.textMatrix); | ||||||
|  |             this.ctx.scale(1, -1); | ||||||
|  |             this.ctx.translate(0, -2 * this.current.y); | ||||||
|             this.ctx.fillText(Fonts.chars2Unicode(text), this.current.x, this.current.y); |             this.ctx.fillText(Fonts.chars2Unicode(text), this.current.x, this.current.y); | ||||||
|             this.current.x += this.ctx.measureText(text).width; |             this.current.x += this.ctx.measureText(text).width; | ||||||
| 
 | 
 | ||||||
| @ -2812,8 +2850,17 @@ var CanvasGraphics = (function() { | |||||||
|                 error("Invalid image width or height"); |                 error("Invalid image width or height"); | ||||||
|              |              | ||||||
|             var ctx = this.ctx; |             var ctx = this.ctx; | ||||||
|  | 
 | ||||||
|             // scale the image to the unit square
 |             // scale the image to the unit square
 | ||||||
|             ctx.scale(1/w, 1/h); |             ctx.scale(1/w, -1/h); | ||||||
|  | 
 | ||||||
|  |             if (image instanceof JpegStream) { | ||||||
|  |                 var domImage = image.getImage(); | ||||||
|  |                 ctx.drawImage(domImage, 0, 0, domImage.width, domImage.height, | ||||||
|  |                     0, -h, w, h); | ||||||
|  |                 this.restore(); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             var interpolate = dict.get2("Interpolate", "I"); |             var interpolate = dict.get2("Interpolate", "I"); | ||||||
|             if (!IsBool(interpolate)) |             if (!IsBool(interpolate)) | ||||||
| @ -2919,7 +2966,7 @@ var CanvasGraphics = (function() { | |||||||
|                 switch (numComps) { |                 switch (numComps) { | ||||||
|                 case 1: |                 case 1: | ||||||
|                     for (var i = 0; i < length; i += 4) { |                     for (var i = 0; i < length; i += 4) { | ||||||
|                         var p = imgArray[imageIdx++]; |                         var p = imgArray[imgIdx++]; | ||||||
|                         pixels[i] = p; |                         pixels[i] = p; | ||||||
|                         pixels[i+1] = p; |                         pixels[i+1] = p; | ||||||
|                         pixels[i+2] = p; |                         pixels[i+2] = p; | ||||||
| @ -2946,7 +2993,7 @@ var CanvasGraphics = (function() { | |||||||
|                 switch (numComps) { |                 switch (numComps) { | ||||||
|                 case 1: |                 case 1: | ||||||
|                     for (var i = 0; i < length; i += 4) { |                     for (var i = 0; i < length; i += 4) { | ||||||
|                         var p = imgArray[imageIdx++]; |                         var p = imgArray[imgIdx++]; | ||||||
|                         pixels[i] = p; |                         pixels[i] = p; | ||||||
|                         pixels[i+1] = p; |                         pixels[i+1] = p; | ||||||
|                         pixels[i+2] = p; |                         pixels[i+2] = p; | ||||||
| @ -2966,7 +3013,7 @@ var CanvasGraphics = (function() { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             tmpCtx.putImageData(imgData, 0, 0); |             tmpCtx.putImageData(imgData, 0, 0); | ||||||
|             ctx.drawImage(tmpCanvas, 0, 0); |             ctx.drawImage(tmpCanvas, 0, -h); | ||||||
|             this.restore(); |             this.restore(); | ||||||
|         }, |         }, | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user