KineticJS vs EaselJS vs Collie vs Fabric vs Pixi vs CAAT CSS - Image Rotation (v23)

Revision 23 of this benchmark created on


Description

Rotates images using different canvas js tools. (Updated to 2013/2014/latest cdn versions of the libraries)

Preparation HTML

<script>
  var catpicdata = "";
</script>

<!-- KineticJS -->
<div id="kinContainer" style="width: 200px; height: 200px;">
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/kineticjs/5.0.6/kinetic.min.js">
</script>

<!-- EaselJS -->
<canvas id="easCanvas" width="200" height="200">
</canvas>
<script src="http://rawgithub.com/CreateJS/EaselJS/master/lib/easeljs-NEXT.min.js">
</script>

<!-- Collie -->
<script src="http://jindo.dev.naver.com/collie/deploy/collie.min.js"></script>
<div id="colContainer"></div>


<!-- pixi.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/1.6.1/pixi.js">
</script>
<div id="pixiContainer"></div>

<!-- fabric.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/1.4.8/fabric.min.js">
</script>
<canvas id="fabricContainer" width="200" height="200"></canvas>
    
<!-- caat.css.js -->
<script src="http://labs.hyperandroid.com/static/caat/lib/caat-css.js"></script>
<div id="caatContainer" ></div>

<script>

  // **** KineticJS **** //
  var kinStage = new Kinetic.Stage({
    container: 'kinContainer',
    width: 200,
    height: 200
  });

  var kinLayer = new Kinetic.Layer();

  var kinImage = new Image();
  kinImage.src = catpicdata;
  var kinLogo;
  kinImage.onload = function() {

  kinLogo = new Kinetic.Image({
    x: 100,
    y: 62,
    image: kinImage,
    width: 200,
    height: 125,
    offset: [100, 62]
  });

  // add the shape to the layer
  kinLayer.add(kinLogo);

  // add the layer to the stage
  kinStage.add(kinLayer);
  }


  // **** FabricJS **** //
  var fabricCanvas = new fabric.StaticCanvas('fabricContainer');

  var fabricImage = new Image();
  fabricImage.src = catpicdata;
  var fabricObj;

  fabricImage.onload = function() {
    fabricObj = new fabric.Image(fabricImage, {
      originX: 'center', originY: 'center',
      left: 100, top: 62
    });
    fabricCanvas.add(fabricObj);
  };




  // **** EaselJS **** //
  var easStage = new createjs.Stage('easCanvas');
  var easLogo = new createjs.Bitmap(catpicdata);
  easLogo.set({
    x: 100,
    y: 62,
    regX: 100,
    regY: 62
  });
  easStage.addChild(easLogo);
  easStage.update();


  // **** Collie **** //
  var colLayer = new collie.Layer({
    width: 200,
    height: 200
  });

  collie.ImageManager.add({
    logo: catpicdata
  });

  var colLogo = new collie.MovableObject({
    x: 0,
    y: 0,
    backgroundImage: "logo",
    originX: 100,
    originY: 62
  }).addTo(colLayer);

  collie.Renderer.addLayer(colLayer);
  collie.Renderer.load(document.getElementById("colContainer"));


  // **** pixi.js **** //
  var pixiStage = new PIXI.Stage(0xFFFFFF);
  var pixiRenderer = PIXI.autoDetectRenderer(200, 200);
  document.getElementById('pixiContainer').appendChild(pixiRenderer.view);

  var pixiTexture = PIXI.Texture.fromImage(catpicdata);
  var pixiLogo = new PIXI.Sprite(pixiTexture);
  pixiLogo.anchor.x = 0.5;
  pixiLogo.anchor.y = 0.5;
  pixiLogo.position.x = 100;
  pixiLogo.position.y = 62;

  pixiStage.addChild(pixiLogo);



  // **** caat ****
  var caatDirector = new CAAT.Director().initialize(
        200,    // 200 pixels wide
        200,     // 200 pixels across
        document.getElementById("caatContainer"));

  var caatScene = caatDirector.createScene();  
  var caatActor = new CAAT.Actor();
    
  caatActor.x = 0;
  caatActor.y = 0;
  caatActor.width=200;
  caatActor.height=200;
  caatScene.addChild(caatActor);
    
  new CAAT.ImagePreloader().loadImages(
      [
          {id:'cat',    url:catpicdata}
      ],
      function( counter, images ) {
          caatDirector.setImagesCache(images);
          caatActor.setBackgroundImage(caatDirector.getImage("cat"));
          caatDirector.renderFrame();
      }
  );
    
  // **** Init **** //
  setTimeout(function() {
    kinLayer.drawScene();
    easStage.update();
    collie.Renderer.draw();
    pixiRenderer.render(pixiStage);
    CAAT.renderEnabled = true;
    caatDirector.renderFrame();
  }, 50);
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
KineticJS
for (var i = 0; i < 360; i += 15) {
  kinLogo.setRotationDeg(i);
  kinLayer.drawScene();
}
ready
EaselJS
for (var i = 0; i < 360; i += 15) {
  easLogo.rotation = i;
  easStage.update();
}
ready
Collie
for (var i = 0; i < 360; i += 15) {
  colLogo.set('angle', i);
  collie.Renderer.draw();
}
ready
Pixi.js (WebGL if supported)
for (var i = 0; i < 360; i += 15) {
  pixiLogo.rotation = i * Math.PI / 180;
  pixiRenderer.render(pixiStage);
}
ready
Fabric.js
for (var i = 0; i < 360; i += 15) {
  fabricObj.angle = -i * Math.PI / 180;
  fabricCanvas.renderAll();
}
ready
Caat CSS
for (var i = 0; i < 360; i += 15) {
  caatActor.setRotation(i * Math.PI / 180);
  caatDirector.renderFrame();
}
ready

Revisions

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