Merge pull request #3312 from yurydelendik/no-getimagedata
Removes getImageData from canvas.js
This commit is contained in:
		
						commit
						2e130903ef
					
				
							
								
								
									
										274
									
								
								src/canvas.js
									
									
									
									
									
								
							
							
						
						
									
										274
									
								
								src/canvas.js
									
									
									
									
									
								
							| @ -167,6 +167,29 @@ function addContextCurrentTransform(ctx) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | var CachedCanvases = (function CachedCanvasesClosure() { | ||||||
|  |   var cache = {}; | ||||||
|  |   return { | ||||||
|  |     getCanvas: function CachedCanvases_getCanvas(id, width, height) { | ||||||
|  |       var canvas; | ||||||
|  |       if (id in cache) { | ||||||
|  |         canvas = cache[id]; | ||||||
|  |         canvas.width = width; | ||||||
|  |         canvas.height = height; | ||||||
|  |         // reset canvas transform for emulated mozCurrentTransform, if needed
 | ||||||
|  |         canvas.getContext('2d').setTransform(1, 0, 0, 1, 0, 0); | ||||||
|  |       } else { | ||||||
|  |         canvas = createScratchCanvas(width, height); | ||||||
|  |         cache[id] = canvas; | ||||||
|  |       } | ||||||
|  |       return canvas; | ||||||
|  |     }, | ||||||
|  |     clear: function () { | ||||||
|  |       cache = {}; | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  | })(); | ||||||
|  | 
 | ||||||
| function compileType3Glyph(imgData) { | function compileType3Glyph(imgData) { | ||||||
|   var POINT_TO_PROCESS_LIMIT = 1000; |   var POINT_TO_PROCESS_LIMIT = 1000; | ||||||
| 
 | 
 | ||||||
| @ -394,31 +417,15 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function applyStencilMask(imgArray, width, height, inverseDecode, buffer) { |   function putBinaryImageData(ctx, imgData) { | ||||||
|     var imgArrayPos = 0; |     if (typeof ImageData !== 'undefined' && imgData instanceof ImageData) { | ||||||
|     var i, j, mask, buf; |       ctx.putImageData(imgData, 0, 0); | ||||||
|     // removing making non-masked pixels transparent
 |       return; | ||||||
|     var bufferPos = 3; // alpha component offset
 |  | ||||||
|     for (i = 0; i < height; i++) { |  | ||||||
|       mask = 0; |  | ||||||
|       for (j = 0; j < width; j++) { |  | ||||||
|         if (!mask) { |  | ||||||
|           buf = imgArray[imgArrayPos++]; |  | ||||||
|           mask = 128; |  | ||||||
|         } |  | ||||||
|         if (!(buf & mask) === inverseDecode) { |  | ||||||
|           buffer[bufferPos] = 0; |  | ||||||
|         } |  | ||||||
|         bufferPos += 4; |  | ||||||
|         mask >>= 1; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|   function putBinaryImageData(ctx, data, w, h) { |     var tmpImgData = ctx.createImageData(imgData.width, imgData.height); | ||||||
|     var tmpImgData = 'createImageData' in ctx ? ctx.createImageData(w, h) : |  | ||||||
|       ctx.getImageData(0, 0, w, h); |  | ||||||
| 
 | 
 | ||||||
|  |     var data = imgData.data; | ||||||
|     var tmpImgDataPixels = tmpImgData.data; |     var tmpImgDataPixels = tmpImgData.data; | ||||||
|     if ('set' in tmpImgDataPixels) |     if ('set' in tmpImgDataPixels) | ||||||
|       tmpImgDataPixels.set(data); |       tmpImgDataPixels.set(data); | ||||||
| @ -431,96 +438,6 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|     ctx.putImageData(tmpImgData, 0, 0); |     ctx.putImageData(tmpImgData, 0, 0); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function prescaleImage(pixels, width, height, widthScale, heightScale) { |  | ||||||
|     pixels = new Uint8Array(pixels); // creating a copy
 |  | ||||||
|     while (widthScale > 2 || heightScale > 2) { |  | ||||||
|       if (heightScale > 2) { |  | ||||||
|         // scaling image twice vertically
 |  | ||||||
|         var rowSize = width * 4; |  | ||||||
|         var k = 0, l = 0; |  | ||||||
|         for (var i = 0; i < height - 1; i += 2) { |  | ||||||
|           for (var j = 0; j < width; j++) { |  | ||||||
|             var alpha1 = pixels[k + 3], alpha2 = pixels[k + 3 + rowSize]; |  | ||||||
|             if (alpha1 === alpha2) { |  | ||||||
|               pixels[l] = (pixels[k] + pixels[k + rowSize]) >> 1; |  | ||||||
|               pixels[l + 1] = (pixels[k + 1] + pixels[k + 1 + rowSize]) >> 1; |  | ||||||
|               pixels[l + 2] = (pixels[k + 2] + pixels[k + 2 + rowSize]) >> 1; |  | ||||||
|               pixels[l + 3] = alpha1; |  | ||||||
|             } else if (alpha1 < alpha2) { |  | ||||||
|               var d = 256 - alpha2 + alpha1; |  | ||||||
|               pixels[l] = (pixels[k] * d + (pixels[k + rowSize] << 8)) >> 9; |  | ||||||
|               pixels[l + 1] = (pixels[k + 1] * d + |  | ||||||
|                               (pixels[k + 1 + rowSize] << 8)) >> 9; |  | ||||||
|               pixels[l + 2] = (pixels[k + 2] * d + |  | ||||||
|                               (pixels[k + 2 + rowSize] << 8)) >> 9; |  | ||||||
|               pixels[l + 3] = alpha2; |  | ||||||
|             } else { |  | ||||||
|               var d = 256 - alpha1 + alpha2; |  | ||||||
|               pixels[l] = ((pixels[k] << 8) + pixels[k + rowSize] * d) >> 9; |  | ||||||
|               pixels[l + 1] = ((pixels[k + 1] << 8) + |  | ||||||
|                               pixels[k + 1 + rowSize] * d) >> 9; |  | ||||||
|               pixels[l + 2] = ((pixels[k + 2] << 8) + |  | ||||||
|                               pixels[k + 2 + rowSize] * d) >> 9; |  | ||||||
|               pixels[l + 3] = alpha1; |  | ||||||
|             } |  | ||||||
|             k += 4; l += 4; |  | ||||||
|           } |  | ||||||
|           k += rowSize; |  | ||||||
|         } |  | ||||||
|         if (height & 1) { |  | ||||||
|           for (var i = 0; i < rowSize; i++) { |  | ||||||
|             pixels[l++] = pixels[k++]; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|         height = (height + 1) >> 1; |  | ||||||
|         heightScale /= 2; |  | ||||||
|       } |  | ||||||
|       if (widthScale > 2) { |  | ||||||
|         // scaling image twice horizontally
 |  | ||||||
|         var k = 0, l = 0; |  | ||||||
|         for (var i = 0; i < height; i++) { |  | ||||||
|           for (var j = 0; j < width - 1; j += 2) { |  | ||||||
|             var alpha1 = pixels[k + 3], alpha2 = pixels[k + 7]; |  | ||||||
|             if (alpha1 === alpha2) { |  | ||||||
|               pixels[l] = (pixels[k] + pixels[k + 4]) >> 1; |  | ||||||
|               pixels[l + 1] = (pixels[k + 1] + pixels[k + 5]) >> 1; |  | ||||||
|               pixels[l + 2] = (pixels[k + 2] + pixels[k + 6]) >> 1; |  | ||||||
|               pixels[l + 3] = alpha1; |  | ||||||
|             } else if (alpha1 < alpha2) { |  | ||||||
|               var d = 256 - alpha2 + alpha1; |  | ||||||
|               pixels[l] = (pixels[k] * d + (pixels[k + 4] << 8)) >> 9; |  | ||||||
|               pixels[l + 1] = (pixels[k + 1] * d + (pixels[k + 5] << 8)) >> 9; |  | ||||||
|               pixels[l + 2] = (pixels[k + 2] * d + (pixels[k + 6] << 8)) >> 9; |  | ||||||
|               pixels[l + 3] = alpha2; |  | ||||||
|             } else { |  | ||||||
|               var d = 256 - alpha1 + alpha2; |  | ||||||
|               pixels[l] = ((pixels[k] << 8) + pixels[k + 4] * d) >> 9; |  | ||||||
|               pixels[l + 1] = ((pixels[k + 1] << 8) + pixels[k + 5] * d) >> 9; |  | ||||||
|               pixels[l + 2] = ((pixels[k + 2] << 8) + pixels[k + 6] * d) >> 9; |  | ||||||
|               pixels[l + 3] = alpha1; |  | ||||||
|             } |  | ||||||
|             k += 8; l += 4; |  | ||||||
|           } |  | ||||||
|           if (width & 1) { |  | ||||||
|             pixels[l++] = pixels[k++]; |  | ||||||
|             pixels[l++] = pixels[k++]; |  | ||||||
|             pixels[l++] = pixels[k++]; |  | ||||||
|             pixels[l++] = pixels[k++]; |  | ||||||
|           } |  | ||||||
|         } |  | ||||||
|         width = (width + 1) >> 1; |  | ||||||
|         widthScale /= 2; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     var tmpCanvas = createScratchCanvas(width, height); |  | ||||||
|     var tmpCtx = tmpCanvas.getContext('2d'); |  | ||||||
|     putBinaryImageData(tmpCtx, pixels.subarray(0, width * height * 4), |  | ||||||
|                                width, height); |  | ||||||
| 
 |  | ||||||
|     return tmpCanvas; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   function copyCtxState(sourceCtx, destCtx) { |   function copyCtxState(sourceCtx, destCtx) { | ||||||
|     var properties = ['strokeStyle', 'fillStyle', 'fillRule', 'globalAlpha', |     var properties = ['strokeStyle', 'fillStyle', 'fillRule', 'globalAlpha', | ||||||
|                       'lineWidth', 'lineCap', 'lineJoin', 'miterLimit', |                       'lineWidth', 'lineCap', 'lineJoin', 'miterLimit', | ||||||
| @ -681,6 +598,7 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
| 
 | 
 | ||||||
|     endDrawing: function CanvasGraphics_endDrawing() { |     endDrawing: function CanvasGraphics_endDrawing() { | ||||||
|       this.ctx.restore(); |       this.ctx.restore(); | ||||||
|  |       CachedCanvases.clear(); | ||||||
| 
 | 
 | ||||||
|       if (this.textLayer) { |       if (this.textLayer) { | ||||||
|         this.textLayer.endLayout(); |         this.textLayer.endLayout(); | ||||||
| @ -1704,21 +1622,17 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|       this.restore(); |       this.restore(); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     paintImageMaskXObject: function CanvasGraphics_paintImageMaskXObject( |     paintImageMaskXObject: function CanvasGraphics_paintImageMaskXObject(img) { | ||||||
|                              imgArray, inverseDecode, width, height) { |  | ||||||
|       var ctx = this.ctx; |       var ctx = this.ctx; | ||||||
|  |       var width = img.width, height = img.height; | ||||||
|  | 
 | ||||||
|       var glyph = this.processingType3; |       var glyph = this.processingType3; | ||||||
| 
 | 
 | ||||||
|       if (COMPILE_TYPE3_GLYPHS && glyph && !('compiled' in glyph)) { |       if (COMPILE_TYPE3_GLYPHS && glyph && !('compiled' in glyph)) { | ||||||
|         var MAX_SIZE_TO_COMPILE = 1000; |         var MAX_SIZE_TO_COMPILE = 1000; | ||||||
|         if (width <= MAX_SIZE_TO_COMPILE && height <= MAX_SIZE_TO_COMPILE) { |         if (width <= MAX_SIZE_TO_COMPILE && height <= MAX_SIZE_TO_COMPILE) { | ||||||
|           var pixels = new Uint8Array(width * height * 4); |  | ||||||
|           for (var i = 3, ii = pixels.length; i < ii; i += 4) { |  | ||||||
|             pixels[i] = 255; |  | ||||||
|           } |  | ||||||
|           applyStencilMask(imgArray, width, height, inverseDecode, pixels); |  | ||||||
|           glyph.compiled = |           glyph.compiled = | ||||||
|             compileType3Glyph({data: pixels, width: width, height: height}); |             compileType3Glyph({data: img.data, width: width, height: height}); | ||||||
|         } else { |         } else { | ||||||
|           glyph.compiled = null; |           glyph.compiled = null; | ||||||
|         } |         } | ||||||
| @ -1729,55 +1643,53 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|  |       var maskCanvas = CachedCanvases.getCanvas('maskCanvas', width, height); | ||||||
|  |       var maskCtx = maskCanvas.getContext('2d'); | ||||||
|  |       maskCtx.save(); | ||||||
| 
 | 
 | ||||||
|       var tmpCanvas = createScratchCanvas(width, height); |       putBinaryImageData(maskCtx, img); | ||||||
|       var tmpCtx = tmpCanvas.getContext('2d'); | 
 | ||||||
|  |       maskCtx.globalCompositeOperation = 'source-in'; | ||||||
| 
 | 
 | ||||||
|       var fillColor = this.current.fillColor; |       var fillColor = this.current.fillColor; | ||||||
|       tmpCtx.fillStyle = (fillColor && fillColor.hasOwnProperty('type') && |       maskCtx.fillStyle = (fillColor && fillColor.hasOwnProperty('type') && | ||||||
|                           fillColor.type === 'Pattern') ? |                           fillColor.type === 'Pattern') ? | ||||||
|                           fillColor.getPattern(tmpCtx) : fillColor; |                           fillColor.getPattern(maskCtx) : fillColor; | ||||||
|       tmpCtx.fillRect(0, 0, width, height); |       maskCtx.fillRect(0, 0, width, height); | ||||||
| 
 | 
 | ||||||
|       var imgData = tmpCtx.getImageData(0, 0, width, height); |       maskCtx.restore(); | ||||||
|       var pixels = imgData.data; |  | ||||||
| 
 | 
 | ||||||
|       applyStencilMask(imgArray, width, height, inverseDecode, pixels); |       this.paintInlineImageXObject(maskCanvas); | ||||||
| 
 |  | ||||||
|       this.paintInlineImageXObject(imgData); |  | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     paintImageMaskXObjectGroup: |     paintImageMaskXObjectGroup: | ||||||
|       function CanvasGraphics_paintImageMaskXObjectGroup(images) { |       function CanvasGraphics_paintImageMaskXObjectGroup(images) { | ||||||
|       var ctx = this.ctx; |       var ctx = this.ctx; | ||||||
|       var tmpCanvasWidth = 0, tmpCanvasHeight = 0, tmpCanvas, tmpCtx; | 
 | ||||||
|       for (var i = 0, ii = images.length; i < ii; i++) { |       for (var i = 0, ii = images.length; i < ii; i++) { | ||||||
|         var image = images[i]; |         var image = images[i]; | ||||||
|         var w = image.width, h = image.height; |         var width = image.width, height = image.height; | ||||||
|         if (w > tmpCanvasWidth || h > tmpCanvasHeight) { | 
 | ||||||
|           tmpCanvasWidth = Math.max(w, tmpCanvasWidth); |         var maskCanvas = CachedCanvases.getCanvas('maskCanvas', width, height); | ||||||
|           tmpCanvasHeight = Math.max(h, tmpCanvasHeight); |         var maskCtx = maskCanvas.getContext('2d'); | ||||||
|           tmpCanvas = createScratchCanvas(tmpCanvasWidth, tmpCanvasHeight); |         maskCtx.save(); | ||||||
|           tmpCtx = tmpCanvas.getContext('2d'); | 
 | ||||||
|  |         putBinaryImageData(maskCtx, image); | ||||||
|  | 
 | ||||||
|  |         maskCtx.globalCompositeOperation = 'source-in'; | ||||||
| 
 | 
 | ||||||
|         var fillColor = this.current.fillColor; |         var fillColor = this.current.fillColor; | ||||||
|           tmpCtx.fillStyle = (fillColor && fillColor.hasOwnProperty('type') && |         maskCtx.fillStyle = (fillColor && fillColor.hasOwnProperty('type') && | ||||||
|                             fillColor.type === 'Pattern') ? |                             fillColor.type === 'Pattern') ? | ||||||
|                               fillColor.getPattern(tmpCtx) : fillColor; |                             fillColor.getPattern(maskCtx) : fillColor; | ||||||
|         } |         maskCtx.fillRect(0, 0, width, height); | ||||||
|         tmpCtx.fillRect(0, 0, w, h); |  | ||||||
| 
 | 
 | ||||||
|         var imgData = tmpCtx.getImageData(0, 0, w, h); |         maskCtx.restore(); | ||||||
|         var pixels = imgData.data; |  | ||||||
| 
 |  | ||||||
|         applyStencilMask(image.data, w, h, image.inverseDecode, pixels); |  | ||||||
| 
 |  | ||||||
|         tmpCtx.putImageData(imgData, 0, 0); |  | ||||||
| 
 | 
 | ||||||
|         ctx.save(); |         ctx.save(); | ||||||
|         ctx.transform.apply(ctx, image.transform); |         ctx.transform.apply(ctx, image.transform); | ||||||
|         ctx.scale(1, -1); |         ctx.scale(1, -1); | ||||||
|         ctx.drawImage(tmpCanvas, 0, 0, w, h, |         ctx.drawImage(maskCanvas, 0, 0, width, height, | ||||||
|                       0, -1, 1, 1); |                       0, -1, 1, 1); | ||||||
|         ctx.restore(); |         ctx.restore(); | ||||||
|       } |       } | ||||||
| @ -1796,32 +1708,56 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|       var width = imgData.width; |       var width = imgData.width; | ||||||
|       var height = imgData.height; |       var height = imgData.height; | ||||||
|       var ctx = this.ctx; |       var ctx = this.ctx; | ||||||
|  | 
 | ||||||
|       this.save(); |       this.save(); | ||||||
|       // scale the image to the unit square
 |       // scale the image to the unit square
 | ||||||
|       ctx.scale(1 / width, -1 / height); |       ctx.scale(1 / width, -1 / height); | ||||||
| 
 | 
 | ||||||
|       var currentTransform = ctx.mozCurrentTransformInverse; |       var currentTransform = ctx.mozCurrentTransformInverse; | ||||||
|       var widthScale = Math.max(Math.abs(currentTransform[0]), 1); |       var a = currentTransform[0], b = currentTransform[1]; | ||||||
|       var heightScale = Math.max(Math.abs(currentTransform[3]), 1); |       var widthScale = Math.max(Math.sqrt(a * a + b * b), 1); | ||||||
|       var tmpCanvas = createScratchCanvas(width, height); |       var c = currentTransform[2], d = currentTransform[3]; | ||||||
|       var tmpCtx = tmpCanvas.getContext('2d'); |       var heightScale = Math.max(Math.sqrt(c * c + d * d), 1); | ||||||
| 
 | 
 | ||||||
|       if (widthScale > 2 || heightScale > 2) { |       var imgToPaint; | ||||||
|         // canvas does not resize well large images to small -- using simple
 |       if (imgData instanceof HTMLElement) { | ||||||
|         // algorithm to perform pre-scaling
 |         imgToPaint = imgData; | ||||||
|         tmpCanvas = prescaleImage(imgData.data, |       } else { | ||||||
|                                  width, height, |         var tmpCanvas = CachedCanvases.getCanvas('inlineImage', width, height); | ||||||
|                                  widthScale, heightScale); |         var tmpCtx = tmpCanvas.getContext('2d'); | ||||||
|         ctx.drawImage(tmpCanvas, 0, 0, tmpCanvas.width, tmpCanvas.height, |         putBinaryImageData(tmpCtx, imgData); | ||||||
|  |         imgToPaint = tmpCanvas; | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       var paintWidth = width, paintHeight = height; | ||||||
|  |       var tmpCanvasId = 'prescale1'; | ||||||
|  |       // Vertial or horizontal scaling shall not be more than 2 to not loose the
 | ||||||
|  |       // pixels during drawImage operation, painting on the temporary canvas(es)
 | ||||||
|  |       // that are twice smaller in size
 | ||||||
|  |       while ((widthScale > 2 && paintWidth > 1) || | ||||||
|  |              (heightScale > 2 && paintHeight > 1)) { | ||||||
|  |         var newWidth = paintWidth, newHeight = paintHeight; | ||||||
|  |         if (widthScale > 2 && paintWidth > 1) { | ||||||
|  |           newWidth = Math.ceil(paintWidth / 2); | ||||||
|  |           widthScale /= paintWidth / newWidth; | ||||||
|  |         } | ||||||
|  |         if (heightScale > 2 && paintHeight > 1) { | ||||||
|  |           newHeight = Math.ceil(paintHeight / 2); | ||||||
|  |           heightScale /= paintHeight / newHeight; | ||||||
|  |         } | ||||||
|  |         var tmpCanvas = CachedCanvases.getCanvas(tmpCanvasId, | ||||||
|  |                                                  newWidth, newHeight); | ||||||
|  |         tmpCtx = tmpCanvas.getContext('2d'); | ||||||
|  |         tmpCtx.clearRect(0, 0, newWidth, newHeight); | ||||||
|  |         tmpCtx.drawImage(imgToPaint, 0, 0, paintWidth, paintHeight, | ||||||
|  |                                      0, 0, newWidth, newHeight); | ||||||
|  |         imgToPaint = tmpCanvas; | ||||||
|  |         paintWidth = newWidth; | ||||||
|  |         paintHeight = newHeight; | ||||||
|  |         tmpCanvasId = tmpCanvasId === 'prescale1' ? 'prescale2' : 'prescale1'; | ||||||
|  |       } | ||||||
|  |       ctx.drawImage(imgToPaint, 0, 0, paintWidth, paintHeight, | ||||||
|                                 0, -height, width, height); |                                 0, -height, width, height); | ||||||
|       } else { |  | ||||||
|         if (typeof ImageData !== 'undefined' && imgData instanceof ImageData) { |  | ||||||
|           tmpCtx.putImageData(imgData, 0, 0); |  | ||||||
|         } else { |  | ||||||
|           putBinaryImageData(tmpCtx, imgData.data, width, height); |  | ||||||
|         } |  | ||||||
|         ctx.drawImage(tmpCanvas, 0, -height); |  | ||||||
|       } |  | ||||||
| 
 | 
 | ||||||
|       if (this.imageLayer) { |       if (this.imageLayer) { | ||||||
|         var position = this.getCanvasPosition(0, -height); |         var position = this.getCanvasPosition(0, -height); | ||||||
| @ -1842,9 +1778,9 @@ var CanvasGraphics = (function CanvasGraphicsClosure() { | |||||||
|       var w = imgData.width; |       var w = imgData.width; | ||||||
|       var h = imgData.height; |       var h = imgData.height; | ||||||
| 
 | 
 | ||||||
|       var tmpCanvas = createScratchCanvas(w, h); |       var tmpCanvas = CachedCanvases.getCanvas('inlineImage', w, h); | ||||||
|       var tmpCtx = tmpCanvas.getContext('2d'); |       var tmpCtx = tmpCanvas.getContext('2d'); | ||||||
|       putBinaryImageData(tmpCtx, imgData.data, w, h); |       putBinaryImageData(tmpCtx, imgData); | ||||||
| 
 | 
 | ||||||
|       for (var i = 0, ii = map.length; i < ii; i++) { |       for (var i = 0, ii = map.length; i < ii; i++) { | ||||||
|         var entry = map[i]; |         var entry = map[i]; | ||||||
|  | |||||||
| @ -253,7 +253,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() { | |||||||
|         var inverseDecode = !!decode && decode[0] > 0; |         var inverseDecode = !!decode && decode[0] > 0; | ||||||
| 
 | 
 | ||||||
|         retData.fn = 'paintImageMaskXObject'; |         retData.fn = 'paintImageMaskXObject'; | ||||||
|         retData.args = [imgArray, inverseDecode, width, height]; |         retData.args = [PDFImage.createMask(imgArray, width, height, | ||||||
|  |                                             inverseDecode)]; | ||||||
|         return retData; |         return retData; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| @ -1631,9 +1632,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() { | |||||||
|         for (var q = 0; q < count; q++) { |         for (var q = 0; q < count; q++) { | ||||||
|           var transform = argsArray[j + (q << 2) + 1]; |           var transform = argsArray[j + (q << 2) + 1]; | ||||||
|           var maskParams = argsArray[j + (q << 2) + 2]; |           var maskParams = argsArray[j + (q << 2) + 2]; | ||||||
|           images.push({data: maskParams[0], width: maskParams[2], |           images.push({data: maskParams.data, width: maskParams.width, | ||||||
|             height: maskParams[3], transform: transform, |             height: maskParams.height, transform: transform}); | ||||||
|             inverseDecode: maskParams[1]}); |  | ||||||
|         } |         } | ||||||
|         // replacing queue items
 |         // replacing queue items
 | ||||||
|         fnArray.splice(j, count * 4, ['paintImageMaskXObjectGroup']); |         fnArray.splice(j, count * 4, ['paintImageMaskXObjectGroup']); | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								src/image.js
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								src/image.js
									
									
									
									
									
								
							| @ -206,6 +206,30 @@ var PDFImage = (function PDFImageClosure() { | |||||||
|     return temp; |     return temp; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   PDFImage.createMask = function PDFImage_createMask(imgArray, width, height, | ||||||
|  |                                                      inverseDecode) { | ||||||
|  |     var buffer = new Uint8Array(width * height * 4); | ||||||
|  |     var imgArrayPos = 0; | ||||||
|  |     var i, j, mask, buf; | ||||||
|  |     // removing making non-masked pixels transparent
 | ||||||
|  |     var bufferPos = 3; // alpha component offset
 | ||||||
|  |     for (i = 0; i < height; i++) { | ||||||
|  |       mask = 0; | ||||||
|  |       for (j = 0; j < width; j++) { | ||||||
|  |         if (!mask) { | ||||||
|  |           buf = imgArray[imgArrayPos++]; | ||||||
|  |           mask = 128; | ||||||
|  |         } | ||||||
|  |         if (!(buf & mask) !== inverseDecode) { | ||||||
|  |           buffer[bufferPos] = 255; | ||||||
|  |         } | ||||||
|  |         bufferPos += 4; | ||||||
|  |         mask >>= 1; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     return {data: buffer, width: width, height: height}; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   PDFImage.prototype = { |   PDFImage.prototype = { | ||||||
|     get drawWidth() { |     get drawWidth() { | ||||||
|       if (!this.smask) |       if (!this.smask) | ||||||
| @ -362,30 +386,6 @@ var PDFImage = (function PDFImageClosure() { | |||||||
|       } |       } | ||||||
|       return buf; |       return buf; | ||||||
|     }, |     }, | ||||||
|     applyStencilMask: function PDFImage_applyStencilMask(buffer, |  | ||||||
|                                                          inverseDecode) { |  | ||||||
|       var width = this.width, height = this.height; |  | ||||||
|       var bitStrideLength = (width + 7) >> 3; |  | ||||||
|       var imgArray = this.getImageBytes(bitStrideLength * height); |  | ||||||
|       var imgArrayPos = 0; |  | ||||||
|       var i, j, mask, buf; |  | ||||||
|       // removing making non-masked pixels transparent
 |  | ||||||
|       var bufferPos = 3; // alpha component offset
 |  | ||||||
|       for (i = 0; i < height; i++) { |  | ||||||
|         mask = 0; |  | ||||||
|         for (j = 0; j < width; j++) { |  | ||||||
|           if (!mask) { |  | ||||||
|             buf = imgArray[imgArrayPos++]; |  | ||||||
|             mask = 128; |  | ||||||
|           } |  | ||||||
|           if (!(buf & mask) === inverseDecode) { |  | ||||||
|             buffer[bufferPos] = 0; |  | ||||||
|           } |  | ||||||
|           bufferPos += 4; |  | ||||||
|           mask >>= 1; |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     fillRgbaBuffer: function PDFImage_fillRgbaBuffer(buffer, width, height) { |     fillRgbaBuffer: function PDFImage_fillRgbaBuffer(buffer, width, height) { | ||||||
|       var numComps = this.numComps; |       var numComps = this.numComps; | ||||||
|       var originalWidth = this.width; |       var originalWidth = this.width; | ||||||
|  | |||||||
| @ -16,14 +16,10 @@ | |||||||
|  */ |  */ | ||||||
| /* globals CanvasGraphics, ColorSpace, createScratchCanvas, DeviceRgbCS, error, | /* globals CanvasGraphics, ColorSpace, createScratchCanvas, DeviceRgbCS, error, | ||||||
|            info, isArray, isPDFFunction, isStream, PDFFunction, TODO, Util, |            info, isArray, isPDFFunction, isStream, PDFFunction, TODO, Util, | ||||||
|            warn */ |            warn, CachedCanvases */ | ||||||
| 
 | 
 | ||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| // This global variable is used to minimize the memory usage when patterns are
 |  | ||||||
| // used.
 |  | ||||||
| var temporaryPatternCanvas = null; |  | ||||||
| 
 |  | ||||||
| var PatternType = { | var PatternType = { | ||||||
|   AXIAL: 2, |   AXIAL: 2, | ||||||
|   RADIAL: 3 |   RADIAL: 3 | ||||||
| @ -351,9 +347,6 @@ var TilingPattern = (function TilingPatternClosure() { | |||||||
| 
 | 
 | ||||||
|       // set the new canvas element context as the graphics context
 |       // set the new canvas element context as the graphics context
 | ||||||
|       var tmpCtx = tmpCanvas.getContext('2d'); |       var tmpCtx = tmpCanvas.getContext('2d'); | ||||||
|       // for simulated mozCurrentTransform canvas (normaly setting width/height
 |  | ||||||
|       // will reset the matrix)
 |  | ||||||
|       tmpCtx.setTransform(1, 0, 0, 1, 0, 0); |  | ||||||
|       var graphics = new CanvasGraphics(tmpCtx, commonObjs, objs); |       var graphics = new CanvasGraphics(tmpCtx, commonObjs, objs); | ||||||
| 
 | 
 | ||||||
|       this.setFillAndStrokeStyleToContext(tmpCtx, paintType, color); |       this.setFillAndStrokeStyleToContext(tmpCtx, paintType, color); | ||||||
| @ -415,11 +408,7 @@ var TilingPattern = (function TilingPatternClosure() { | |||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     getPattern: function TilingPattern_getPattern() { |     getPattern: function TilingPattern_getPattern() { | ||||||
|       // The temporary canvas is created only because the memory is released
 |       var temporaryPatternCanvas = CachedCanvases.getCanvas('pattern'); | ||||||
|       // more quickly than creating multiple temporary canvases.
 |  | ||||||
|       if (temporaryPatternCanvas === null) { |  | ||||||
|         temporaryPatternCanvas = createScratchCanvas(1, 1); |  | ||||||
|       } |  | ||||||
|       this.createPatternCanvas(temporaryPatternCanvas); |       this.createPatternCanvas(temporaryPatternCanvas); | ||||||
| 
 | 
 | ||||||
|       var ctx = this.ctx; |       var ctx = this.ctx; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user