Don't uselessly change the filter when drawing
When profiling the pdf in https://bugzilla.mozilla.org/show_bug.cgi?id=1508765, I noticed that half a second was spent to set the filter to "none".
This commit is contained in:
		
							parent
							
								
									1a69b6ad64
								
							
						
					
					
						commit
						9a4750fee5
					
				| @ -790,9 +790,12 @@ function resetCtxToDefault(ctx) { | |||||||
|     (typeof PDFJSDev !== "undefined" && PDFJSDev.test("MOZCENTRAL")) || |     (typeof PDFJSDev !== "undefined" && PDFJSDev.test("MOZCENTRAL")) || | ||||||
|     !isNodeJS |     !isNodeJS | ||||||
|   ) { |   ) { | ||||||
|  |     const { filter } = ctx; | ||||||
|  |     if (filter !== "none" && filter !== "") { | ||||||
|       ctx.filter = "none"; |       ctx.filter = "none"; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| function composeSMaskBackdrop(bytes, r0, g0, b0) { | function composeSMaskBackdrop(bytes, r0, g0, b0) { | ||||||
|   const length = bytes.length; |   const length = bytes.length; | ||||||
| @ -2961,8 +2964,11 @@ class CanvasGraphics { | |||||||
|       // It must be applied to the image before rescaling else some artifacts
 |       // It must be applied to the image before rescaling else some artifacts
 | ||||||
|       // could appear.
 |       // could appear.
 | ||||||
|       // The final restore will reset it to its value.
 |       // The final restore will reset it to its value.
 | ||||||
|  |       const { filter } = ctx; | ||||||
|  |       if (filter !== "none" && filter !== "") { | ||||||
|         ctx.filter = "none"; |         ctx.filter = "none"; | ||||||
|       } |       } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     // 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); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user