Skip to content
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);
Clone this wiki locally