Use Stream instead of byte array access
This commit is contained in:
		
							parent
							
								
									1ccc8a64b7
								
							
						
					
					
						commit
						2982de8f33
					
				| @ -52,18 +52,20 @@ var PDFImage = (function PDFImageClosure() { | ||||
|   function PDFImage(xref, res, image, inline, smask, mask, isMask) { | ||||
|     this.image = image; | ||||
|     var dict = image.dict; | ||||
|     if (dict.get('Filter').name === 'JPXDecode') { | ||||
|     if (dict.has('Filter')) { | ||||
|       var filter = dict.get('Filter').name; | ||||
|       if (filter === 'JPXDecode') { | ||||
|         info('get image params from JPX stream'); | ||||
|         var jpxImage = new JpxImage(); | ||||
|       var data = image.stream.bytes; | ||||
|       jpxImage.parseImageProperties(data, 0, data.length); | ||||
|         jpxImage.parseImageProperties(image.stream); | ||||
|         image.stream.reset(); | ||||
|         image.bitsPerComponent = jpxImage.bitsPerComponent; | ||||
|         image.numComps = jpxImage.componentsCount; | ||||
|     } | ||||
|     if (dict.get('Filter').name === 'JBIG2Decode') { | ||||
|       } else if (filter === 'JBIG2Decode') { | ||||
|         image.bitsPerComponent = 1; | ||||
|         image.numComps = 1; | ||||
|       } | ||||
|     } | ||||
|     // TODO cache rendered images?
 | ||||
| 
 | ||||
|     this.width = dict.get('Width', 'W'); | ||||
|  | ||||
| @ -98,19 +98,22 @@ var JpxImage = (function JpxImageClosure() { | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     parseImageProperties: function JpxImage_parseImageProperties(data, start, | ||||
|                                                                  end) { | ||||
|     parseImageProperties: function JpxImage_parseImageProperties(stream) { | ||||
|       try { | ||||
|         var position = start; | ||||
|         while (position + 40 < end) { | ||||
|           var code = readUint16(data, position); | ||||
|         var newByte = stream.getByte(); | ||||
|         while (newByte >= 0) { | ||||
|           var oldByte = newByte; | ||||
|           newByte = stream.getByte(); | ||||
|           var code = (oldByte << 8) | newByte; | ||||
|           // Image and tile size (SIZ)
 | ||||
|           if (code == 0xFF51) { | ||||
|             var Xsiz = readUint32(data, position + 6); | ||||
|             var Ysiz = readUint32(data, position + 10); | ||||
|             var XOsiz = readUint32(data, position + 14); | ||||
|             var YOsiz = readUint32(data, position + 18); | ||||
|             var Csiz = readUint16(data, position + 38); | ||||
|             stream.skip(4); | ||||
|             var Xsiz = stream.getUint32(); // Byte 4 
 | ||||
|             var Ysiz = stream.getUint32(); // Byte 8
 | ||||
|             var XOsiz = stream.getUint32(); // Byte 12
 | ||||
|             var YOsiz = stream.getUint32(); // Byte 16
 | ||||
|             stream.skip(16); | ||||
|             var Csiz = stream.getUint16(); // Byte 36
 | ||||
|             this.width = Xsiz - XOsiz; | ||||
|             this.height = Ysiz - YOsiz; | ||||
|             this.componentsCount = Csiz; | ||||
| @ -118,7 +121,6 @@ var JpxImage = (function JpxImageClosure() { | ||||
|             this.bitsPerComponent = 8; | ||||
|             return; | ||||
|           } | ||||
|           position += 1; | ||||
|         } | ||||
|         throw 'No size marker found in JPX stream'; | ||||
|       } catch (e) { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user