mirror of
				https://github.com/webmproject/libwebp.git
				synced 2025-10-31 02:15:42 +01:00 
			
		
		
		
	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
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | |
| <html lang="en">
 | |
| 
 | |
| <head>
 | |
|   <meta charset="UTF-8">
 | |
|   <title>simple Javascript WebP decoding demo, using Web-Assembly (WASM)</title>
 | |
|   <script type="text/javascript">
 | |
|     var Module = {
 | |
|       noInitialRun : true
 | |
|     };
 | |
|   </script>
 | |
|   <script type="text/javascript">
 | |
| 
 | |
| 'use strict';
 | |
| 
 | |
| // main wrapper for the function decoding a WebP into a canvas object
 | |
| var WebpToCanvas;
 | |
| 
 | |
| function init() {
 | |
|   var xhr = new XMLHttpRequest();
 | |
|   xhr.open('GET', 'webp_wasm.wasm', true);
 | |
|   xhr.responseType = 'arraybuffer';
 | |
|   xhr.onload = function() {
 | |
|     Module.wasmBinary = xhr.response;
 | |
|     var script = document.createElement('script');
 | |
|     script.src = "webp_wasm.js";
 | |
|     document.body.appendChild(script);
 | |
|   };
 | |
|   xhr.send(null);
 | |
| }
 | |
| window.onload = init;
 | |
| 
 | |
| function decode(webp_data, canvas_id) {
 | |
|   var result;
 | |
|   if (Module["asm"] != undefined) {
 | |
|     // wrapper for the function decoding a WebP into a canvas object
 | |
|     WebpToCanvas = Module.cwrap('WebpToSDL', 'number', ['array', 'number']);
 | |
|     // 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 decode_time = end - start;
 | |
|     result = 'decoding time: ' + decode_time +' ms.';
 | |
|   } else {
 | |
|     result = "WASM module not finished loading! Please retry";
 | |
|   }
 | |
|   // display timing result
 | |
|   var speed_result = document.getElementById('timing');
 | |
|   if (speed_result != null) {
 | |
|     speed_result.innerHTML = '<p>'+ result + '</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 demo using Web-Assembly</strong> -
 | |
|   </p>
 | |
|   <p>
 | |
|     WASM version of the WebP decoder, 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!"
 | |
|            onclick="loadfile('./test_webp_wasm.webp', 'output_canvas')">
 | |
|   </p>
 | |
|   <p id="timing">Timing: N/A</p>
 | |
|   <canvas id="output_canvas">Your browser does not support canvas</canvas>
 | |
| </body>
 | |
| </html>
 |