opacity animations using css vs. html5 canvas (v3)

Revision 3 of this benchmark created on


Description

Still a work in progress (i.e. some weirdness is present)...

Tests the speed of rendering an semi-opaque image on top of another using HTML and CSS vs. Canvas

Preparation HTML

<div style="position: relative; width: 256px; height: 256px;">
  <img src="#" id="background" width="256" height="256" style="position: absolute; left: 0px; top 0px"
  ;>
  <img src="#" id="overlay" width="90" height="46">
</div>
<canvas id="canvas" style="position: relative; width: 256px; height: 256px;">
</canvas>
<script>
  var backgroundSrc = "";
  var fadeSrc = "";

  var posX = 100;
  var posY = 100;
  var changeBy = 0.01;
  var opacity = 0;

  var increment = function() {
      opacity = opacity + changeBy;
      if (opacity >= 1) {
        opacity = 1;
        changeBy = -0.01;
      } else if (opacity <= 0) {
        opacity = 0;
        changeBy = 0.01;
      }
      }
      
      
      
      // set's up the canvas by painting the background onto the canvas, as well as loading the two images into image objects.
      
  var backgroundImage = new Image();
  var fadeImage = new Image();
  var context = document.getElementById("canvas").getContext("2d");

  backgroundImage.onload = function(event) {
    backgroundImage.width = 256;
    backgroundImage.height = 256;
    context.drawImage(backgroundImage, 0, 0, 256, 256);
  }

  backgroundImage.src = backgroundSrc;
  fadeImage.src = fadeSrc;

  // set's up the html images with the appropriate src
  document.getElementById("background").src = backgroundSrc;
  var htmlOverlay = document.getElementById("overlay");
  htmlOverlay.src = fadeSrc;
  htmlOverlay.style.position = "absolute";
  htmlOverlay.style.left = posX + "px";
  htmlOverlay.style.top = posY + "px";
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
css
increment();
htmlOverlay.style.opacity = opacity;
ready
canvas
increment();
context.drawImage(fadeImage, posX, posY, 90, 46);
ready

Revisions

You can edit these tests or add more tests to this page by appending /edit to the URL.