Blame webp_js/index_wasm.html

Packit 9c6abc
Packit 9c6abc
<html lang="en">
Packit 9c6abc
Packit 9c6abc
<head>
Packit 9c6abc
  <meta charset="UTF-8">
Packit 9c6abc
  <title>simple Javascript WebP decoding demo, using Web-Assembly (WASM)</title>
Packit 9c6abc
  <script type="text/javascript">
Packit 9c6abc
    var Module = {
Packit 9c6abc
      noInitialRun : true
Packit 9c6abc
    };
Packit 9c6abc
  </script>
Packit 9c6abc
  <script type="text/javascript">
Packit 9c6abc
Packit 9c6abc
'use strict';
Packit 9c6abc
Packit 9c6abc
// main wrapper for the function decoding a WebP into a canvas object
Packit 9c6abc
var WebpToCanvas;
Packit 9c6abc
Packit 9c6abc
function init() {
Packit 9c6abc
  var xhr = new XMLHttpRequest();
Packit 9c6abc
  xhr.open('GET', 'webp_wasm.wasm', true);
Packit 9c6abc
  xhr.responseType = 'arraybuffer';
Packit 9c6abc
  xhr.onload = function() {
Packit 9c6abc
    Module.wasmBinary = xhr.response;
Packit 9c6abc
    var script = document.createElement('script');
Packit 9c6abc
    script.src = "webp_wasm.js";
Packit 9c6abc
    document.body.appendChild(script);
Packit 9c6abc
  };
Packit 9c6abc
  xhr.send(null);
Packit 9c6abc
}
Packit 9c6abc
window.onload = init;
Packit 9c6abc
Packit 9c6abc
function decode(webp_data, canvas_id) {
Packit 9c6abc
  var result;
Packit 9c6abc
  if (Module["asm"] != undefined) {
Packit 9c6abc
    // wrapper for the function decoding a WebP into a canvas object
Packit 9c6abc
    WebpToCanvas = Module.cwrap('WebpToSDL', 'number', ['array', 'number']);
Packit 9c6abc
    // get the canvas to decode into
Packit 9c6abc
    var canvas = document.getElementById(canvas_id);
Packit 9c6abc
    if (canvas == null) return;
Packit 9c6abc
    // clear previous picture (if any)
Packit 9c6abc
    Module.canvas = canvas;
Packit 9c6abc
    canvas.getContext('2d').clearRect(0, 0, canvas.width, canvas.height);
Packit 9c6abc
    // decode and measure timing
Packit 9c6abc
    var start = new Date();
Packit 9c6abc
    var ret = WebpToCanvas(webp_data, webp_data.length);
Packit 9c6abc
    var end = new Date();
Packit 9c6abc
    var decode_time = end - start;
Packit 9c6abc
    result = 'decoding time: ' + decode_time +' ms.';
Packit 9c6abc
  } else {
Packit 9c6abc
    result = "WASM module not finished loading! Please retry";
Packit 9c6abc
  }
Packit 9c6abc
  // display timing result
Packit 9c6abc
  var speed_result = document.getElementById('timing');
Packit 9c6abc
  if (speed_result != null) {
Packit 9c6abc
    speed_result.innerHTML = '

'+ result + '

';
Packit 9c6abc
  }
Packit 9c6abc
}
Packit 9c6abc
Packit 9c6abc
function loadfile(filename, canvas_id) {
Packit 9c6abc
  var xhr = new XMLHttpRequest();
Packit 9c6abc
  xhr.open('GET', filename);
Packit 9c6abc
  xhr.responseType = 'arraybuffer';
Packit 9c6abc
  xhr.onreadystatechange = function() {
Packit 9c6abc
    if (xhr.readyState == 4 && xhr.status == 200) {
Packit 9c6abc
      var webp_data = new Uint8Array(xhr.response);
Packit 9c6abc
      decode(webp_data, canvas_id);
Packit 9c6abc
    }
Packit 9c6abc
  };
Packit 9c6abc
  xhr.send();
Packit 9c6abc
}
Packit 9c6abc
  </script>
Packit 9c6abc
</head>
Packit 9c6abc
Packit 9c6abc
<body>
Packit 9c6abc
  

Packit 9c6abc
    WebP demo using Web-Assembly -
Packit 9c6abc
  

Packit 9c6abc
  

Packit 9c6abc
    WASM version of the WebP decoder, using libwebp compiled with
Packit 9c6abc
    Emscripten.
Packit 9c6abc
  

Packit 9c6abc
  

Packit 9c6abc
    
Packit 9c6abc
           onclick="loadfile('./test_webp_wasm.webp', 'output_canvas')">
Packit 9c6abc
  

Packit 9c6abc
  

Timing: N/A

Packit 9c6abc
  <canvas id="output_canvas">Your browser does not support canvas</canvas>
Packit 9c6abc
</body>
Packit 9c6abc
</html>