-
Notifications
You must be signed in to change notification settings - Fork 8
Home
James Baicoianu edited this page Aug 25, 2013
·
10 revisions
The Elation Engine is a lightweight framework for developing 3d world simulations using HTML5 and JavaScript.
var engine = elation.engine.create("websoccer", ["physics", "render", "controls", "ai", "world"], function(engine) {
// Create field
var field = engine.systems.world.spawn("soccerfield", "playground");
// Spawn players
var player1 = field.spawn("player", "player1", {position: field.getPlayerPosition(1)});
var player2 = field.spawn("player", "player2", {position: field.getPlayerPosition(2)});
// Define goals
var goal1 = field.spawn("goal", "goal1", {position: field.getGoalPosition(1), owner: player1});
var goal2 = field.spawn("goal", "goal2", {position: field.getGoalPosition(2), owner: player2});
// Add ball
var ball = field.spawn("ball", "ball", {position: field.getCenterPosition()});
// Let's go!
engine.start();
});
elation.component.add("engine.things.field", function() {
// Size reference: http://upload.wikimedia.org/wikipedia/commons/c/cf/Football_pitch_metric.svg
this.init = function() {
this.defineProperties({
'size': { type: 'vector', default: [100, 0, 75] },
'circlesize': { type: 'float': default: 9.15 }
});
}
this.getPlayerPosition = function(playernum) {
var pos = this.getCenterPosition();
// We could support more players if we added teams, but for now it's just 1v1
switch (playernum) {
case 1:
pos.x -= this.properties.circlesize;
break;
case 2:
pos.x += this.properties.circlesize;
break;
}
return pos;
}
this.getGoalPosition = function(playernum) {
return new THREE.Vector3((playernum == 1 ? 0 : this.size[1]), 0, this.size[1] / 2);
}
this.getCenterPosition = function() {
return new THREE.Vector3(this.size[0] / 2, 0, this.size[1] / 2);
}
}, elation.engine.things.generic);