KineticJS vs EaselJS vs Collie vs Fabric vs Pixi - Image Rotation

JavaScript performance comparison

Revision 5 of this test case created by kangax

Info

Rotates images using different canvas js tools.

Preparation code

<script type="text/javascript">
  var catpicdata = "";
</script>

<!-- KineticJS -->
<div id="kinContainer" style="width: 200px; height: 200px;">
</div>
<script src="http://d3lp1msu2r81bx.cloudfront.net/kjs/js/lib/kinetic-v4.7.2.min.js">
</script>

<!-- EaselJS -->
<canvas id="easCanvas" width="200" height="200">
</canvas>
<script src="http://code.createjs.com/createjs-2013.09.25.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="http://www.goodboydigital.com/pixijs/bunnymark/js/pixi.js">
</script>
<div id="pixiContainer"></div>

<!-- fabric.js -->
<script src="https://rawgithub.com/kangax/fabric.js/master/dist/fabric.js">
</script>
<canvas id="fabricContainer" width="200" height="200"></canvas>


<script type="text/javascript">

  // **** 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);


  // **** Init **** //
  setTimeout(function() {
    kinLayer.drawScene();
    easStage.update();
    collie.Renderer.draw();
    pixiRenderer.render(pixiStage);
  }, 50);
</script>

Preparation code output

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

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

Compare results of other browsers

Revisions

You can edit these tests or add even more tests to this page by appending /edit to the URL. Here’s a list of current revisions for this page:

0 comments

Add a comment