jsPerf.app is an online JavaScript performance benchmark test runner & jsperf.com mirror. It is a complete rewrite in homage to the once excellent jsperf.com now with hopefully a more modern & maintainable codebase.
jsperf.com URLs are mirrored at the same path, e.g:
https://jsperf.com/negative-modulo/2
Can be accessed at:
https://jsperf.app/negative-modulo/2
Rotates images using different canvas js tools.
<script src="https://www.cinsoft.net/mylib099-min.js"></script>
<script>
var catpicdata = "";
</script>
<!-- KineticJS -->
<div id="kinContainer" style="width: 200px; height: 200px;">
</div>
<script src="http://d3lp1msu2r81bx.cloudfront.net/kjs/js/lib/kinetic-v5.1.0.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>
<script>
// **** KineticJS **** //
var kinStage = new Kinetic.Stage({
container: 'kinContainer',
width: 200,
height: 200
});
var kinLayer = new Kinetic.FastLayer();
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: {x: 100, y: 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
});
easLogo.snapToPixel = true;
easLogo.cache(0,0,easLogo.getBounds().width, easLogo.getBounds().height);
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 = new PIXI.CanvasRenderer(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>
Ready to run.
Test | Ops/sec | |
---|---|---|
KineticJS |
| ready |
EaselJS |
| ready |
Collie |
| ready |
Pixi.js (Canvas) |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.