blob: 7a049836ff240f98827e9da0c567f4fb1ccf9315 [file] [log] [blame]
Leaf = Utilities.createSubclass(Particle,
function(stage)
{
this.element = document.createElement("img");
this.element.setAttribute("src", Stage.randomElementInArray(stage.images).src);
var sizeString = this.sizeMinimum + "px";
this.element.style.width = sizeString;
this.element.style.height = sizeString;
stage.element.appendChild(this.element);
Particle.call(this, stage);
}, {
sizeMinimum: 25,
sizeRange: 0,
reset: function()
{
Particle.prototype.reset.call(this);
this._life = Stage.randomInt(20, 100);
this._position = new Point(Stage.random(0, this.maxPosition.x), Stage.random(-this.size.height, this.maxPosition.y));
this._velocity = new Point(Stage.random(-6, -2), .1 * this.size.y + Stage.random(-1, 1));
},
animate: function(timeDelta)
{
this.rotater.next(timeDelta);
this._position.x += this._velocity.x + 8 * this.stage.focusX;
this._position.y += this._velocity.y;
this._life--;
if (!this._life || this._position.y > this.stage.size.height)
this.reset();
if (this._position.x < -this.size.width || this._position.x > this.stage.size.width)
this._position.x = this._position.x - Math.sign(this._position.x) * (this.size.width + this.stage.size.width);
this.move();
},
move: function()
{
this.element.style.transform = "translate(" + this._position.x + "px, " + this._position.y + "px)" + this.rotater.rotateZ();
}
});
Utilities.extendObject(ParticlesStage.prototype, {
imageSrcs: [
"compass",
"console",
"contribute",
"debugger",
"inspector",
"layout",
"performance",
"script",
"shortcuts",
"standards",
"storage",
"styles",
"timeline"
],
images: [],
initialize: function(benchmark)
{
Stage.prototype.initialize.call(this, benchmark);
var lastPromise;
var images = this.images;
this.imageSrcs.forEach(function(imageSrc) {
var promise = this._loadImage("../master/resources/" + imageSrc + "100.png");
if (!lastPromise)
lastPromise = promise;
else {
lastPromise = lastPromise.then(function(img) {
images.push(img);
return promise;
});
}
}, this);
lastPromise.then(function(img) {
images.push(img);
benchmark.readyPromise.resolve();
});
},
_loadImage: function(src) {
var img = new Image;
var promise = new SimplePromise;
img.onload = function(e) {
promise.resolve(e.target);
};
img.src = src;
return promise;
},
animate: function(timeDelta)
{
this.focusX = 0.5 + 0.5 * Math.sin(Stage.dateFractionalValue(10000) * Math.PI * 2);
timeDelta /= 4;
this.particles.forEach(function(particle) {
particle.animate(timeDelta);
});
},
createParticle: function()
{
return new Leaf(this);
},
willRemoveParticle: function(particle)
{
particle.element.remove();
}
});
LeavesBenchmark = Utilities.createSubclass(Benchmark,
function(options)
{
Benchmark.call(this, new ParticlesStage(), options);
}, {
waitUntilReady: function() {
this.readyPromise = new SimplePromise;
return this.readyPromise;
}
});
window.benchmarkClass = LeavesBenchmark;