KineticJS vs EaselJS vs Collie vs Pixi - Image Rotation (v39)

Revision 39 of this benchmark created by Bob on


Preparation HTML

<script>
  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="https://github.com/pixijs/pixi.js/releases/download/v3.0.7/pixi.min.js">
</script>
<div id="pixiContainer"></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);
  }




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

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

Revisions

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