 6878d42720
			
		
	
	6878d42720
	
	
	
		
			
			we use a static guard to only call SDL_Init() once. Another option would be to call SDL_Quit(), but it doesn't seem to be doing anything. Also, fix the HTML code and add 'use strict' directive. BUG=webp:354 Change-Id: I3c6421e2c1c8cc200556cd4092a0ead9a8b054ef
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="en">
 | |
| 
 | |
| <head>
 | |
|   <meta charset="UTF-8">
 | |
|   <title>simple Javascript WebP decoding demo</title>
 | |
|   <script type="text/javascript">
 | |
|     var Module = {
 | |
|       noInitialRun : true
 | |
|     };
 | |
|   </script>
 | |
|   <script type="text/javascript" src="./webp.js"></script>
 | |
|   <script type="text/javascript">
 | |
| 
 | |
| 'use strict';
 | |
| 
 | |
| // main wrapper for the function decoding a WebP into a canvas object
 | |
| var WebpToCanvas;
 | |
| 
 | |
| function init() {
 | |
|   WebpToCanvas = Module.cwrap('WebpToSDL', 'number', ['array', 'number']);
 | |
| }
 | |
| window.onload = init;
 | |
| 
 | |
| function decode(webp_data, canvas_id) {
 | |
|   // get the canvas to decode into
 | |
|   var canvas = document.getElementById(canvas_id);
 | |
|   if (canvas == null) return;
 | |
|   // clear previous picture (if any)
 | |
|   Module.canvas = canvas;
 | |
|   canvas.getContext('2d').clearRect(0, 0, canvas.width, canvas.height);
 | |
|   // decode and measure timing
 | |
|   var start = new Date();
 | |
|   var ret = WebpToCanvas(webp_data, webp_data.length);
 | |
|   var end = new Date();
 | |
|   var speed_result = document.getElementById('timing');
 | |
|   // display timing result
 | |
|   if (speed_result != null) {
 | |
|     var decode_time = end - start;
 | |
|     speed_result.innerHTML = '<p>decoding time: ' + decode_time +' ms.</p>';
 | |
|   }
 | |
| }
 | |
| 
 | |
| function loadfile(filename, canvas_id) {
 | |
|   var xhr = new XMLHttpRequest();
 | |
|   xhr.open('GET', filename);
 | |
|   xhr.responseType = 'arraybuffer';
 | |
|   xhr.onreadystatechange = function() {
 | |
|     if (xhr.readyState == 4 && xhr.status == 200) {
 | |
|       var webp_data = new Uint8Array(xhr.response);
 | |
|       decode(webp_data, canvas_id);
 | |
|     }
 | |
|   };
 | |
|   xhr.send();
 | |
| }
 | |
|   </script>
 | |
| </head>
 | |
| 
 | |
| <body>
 | |
|   <p>
 | |
|     <strong>WebP in JavaScript demo</strong> -
 | |
|   </p>
 | |
|   <p>
 | |
|     WebP decoder in JavaScript, using libwebp compiled with
 | |
|     <a href="https://github.com/kripken/emscripten/wiki">Emscripten</a>.
 | |
|   </p>
 | |
|   <p id="image_buttons">
 | |
|     <input type="button" value="test image!" name="./test_webp_js.webp"
 | |
|            onclick="loadfile(this.name, 'output_canvas')">
 | |
|   </p>
 | |
|   <p id="timing">Timing: N/A</p>
 | |
|   <canvas id="output_canvas">Your browser does not support canvas</canvas>
 | |
| 
 | |
| </body>
 | |
| </html>
 |