first commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Types tests / Test (lts/*) (push) Has been cancelled
				
			
		
			
				
	
				Lint / Lint (lts/*) (push) Has been cancelled
				
			
		
			
				
	
				CodeQL / Analyze (javascript) (push) Has been cancelled
				
			
		
			
				
	
				CI / Test (20) (push) Has been cancelled
				
			
		
			
				
	
				CI / Test (22) (push) Has been cancelled
				
			
		
			
				
	
				CI / Test (24) (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Types tests / Test (lts/*) (push) Has been cancelled
				
			Lint / Lint (lts/*) (push) Has been cancelled
				
			CodeQL / Analyze (javascript) (push) Has been cancelled
				
			CI / Test (20) (push) Has been cancelled
				
			CI / Test (22) (push) Has been cancelled
				
			CI / Test (24) (push) Has been cancelled
				
			This commit is contained in:
		
							
								
								
									
										
											BIN
										
									
								
								examples/image_decoders/fish.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								examples/image_decoders/fish.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 22 KiB  | 
							
								
								
									
										40
									
								
								examples/image_decoders/jpeg_viewer.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								examples/image_decoders/jpeg_viewer.html
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,40 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<!--
 | 
			
		||||
Copyright 2018 Mozilla Foundation
 | 
			
		||||
 | 
			
		||||
Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
you may not use this file except in compliance with the License.
 | 
			
		||||
You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
    http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
See the License for the specific language governing permissions and
 | 
			
		||||
limitations under the License.
 | 
			
		||||
-->
 | 
			
		||||
<html dir="ltr" mozdisallowselectionprint>
 | 
			
		||||
<head>
 | 
			
		||||
  <meta charset="utf-8">
 | 
			
		||||
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
 | 
			
		||||
  <meta name="google" content="notranslate">
 | 
			
		||||
  <title>PDF.js standalone JpegImage parser</title>
 | 
			
		||||
 | 
			
		||||
  <style>
 | 
			
		||||
    body {
 | 
			
		||||
      background-color: #808080;
 | 
			
		||||
      margin: 0;
 | 
			
		||||
      padding: 0;
 | 
			
		||||
    }
 | 
			
		||||
  </style>
 | 
			
		||||
 | 
			
		||||
  <script src="../../node_modules/pdfjs-dist/image_decoders/pdf.image_decoders.mjs" type="module"></script>
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body tabindex="1">
 | 
			
		||||
  <canvas id="jpegCanvas" width="0" height="0"></canvas>
 | 
			
		||||
 | 
			
		||||
  <script src="jpeg_viewer.mjs" type="module"></script>
 | 
			
		||||
</body>
 | 
			
		||||
</html>
 | 
			
		||||
							
								
								
									
										59
									
								
								examples/image_decoders/jpeg_viewer.mjs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								examples/image_decoders/jpeg_viewer.mjs
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,59 @@
 | 
			
		||||
/* Copyright 2018 Mozilla Foundation
 | 
			
		||||
 *
 | 
			
		||||
 * Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
 * you may not use this file except in compliance with the License.
 | 
			
		||||
 * You may obtain a copy of the License at
 | 
			
		||||
 *
 | 
			
		||||
 *     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 *
 | 
			
		||||
 * Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 * distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 * See the License for the specific language governing permissions and
 | 
			
		||||
 * limitations under the License.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (!pdfjsImageDecoders.JpegImage) {
 | 
			
		||||
  // eslint-disable-next-line no-alert
 | 
			
		||||
  alert("Please build the pdfjs-dist library using `gulp dist-install`");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const JPEG_IMAGE = "fish.jpg";
 | 
			
		||||
 | 
			
		||||
const jpegCanvas = document.getElementById("jpegCanvas");
 | 
			
		||||
const jpegCtx = jpegCanvas.getContext("2d");
 | 
			
		||||
 | 
			
		||||
// Load the image data, and convert it to a Uint8Array.
 | 
			
		||||
//
 | 
			
		||||
const response = await fetch(JPEG_IMAGE);
 | 
			
		||||
if (!response.ok) {
 | 
			
		||||
  throw new Error(response.statusText);
 | 
			
		||||
}
 | 
			
		||||
const typedArrayImage = new Uint8Array(await response.arrayBuffer());
 | 
			
		||||
 | 
			
		||||
// Parse the image data using `JpegImage`.
 | 
			
		||||
//
 | 
			
		||||
const jpegImage = new pdfjsImageDecoders.JpegImage();
 | 
			
		||||
jpegImage.parse(typedArrayImage);
 | 
			
		||||
 | 
			
		||||
const width = jpegImage.width,
 | 
			
		||||
  height = jpegImage.height;
 | 
			
		||||
const jpegData = jpegImage.getData({
 | 
			
		||||
  width,
 | 
			
		||||
  height,
 | 
			
		||||
  forceRGB: true,
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
// Render the JPEG image on a <canvas>.
 | 
			
		||||
//
 | 
			
		||||
const imageData = jpegCtx.createImageData(width, height);
 | 
			
		||||
const imageBytes = imageData.data;
 | 
			
		||||
for (let j = 0, k = 0, jj = width * height * 4; j < jj; ) {
 | 
			
		||||
  imageBytes[j++] = jpegData[k++];
 | 
			
		||||
  imageBytes[j++] = jpegData[k++];
 | 
			
		||||
  imageBytes[j++] = jpegData[k++];
 | 
			
		||||
  imageBytes[j++] = 255;
 | 
			
		||||
}
 | 
			
		||||
jpegCanvas.width = width;
 | 
			
		||||
jpegCanvas.height = height;
 | 
			
		||||
jpegCtx.putImageData(imageData, 0, 0);
 | 
			
		||||
		Reference in New Issue
	
	Block a user