added first damage and killing

This commit is contained in:
Jeena 2014-01-21 03:14:50 +01:00
parent 2a4327c5cf
commit f22e0dd53d
9 changed files with 124 additions and 52 deletions

View file

@ -4,14 +4,11 @@ define([
function (Parent) { function (Parent) {
function Detector (player) { function Detector () {
Parent.call(this, player); Parent.call(this);
} }
Detector.prototype = Object.create(Parent.prototype); Detector.prototype = Object.create(Parent.prototype);
Detector.IDENTIFIER = Parent.IDENTIFIER; // Needed because otherwise it will not be
// inherited because it is not in prototype
return Detector; return Detector;
}); });

View file

@ -4,17 +4,11 @@ define([
function (Box2D) { function (Box2D) {
function Detector () { // FIXME evtl.bind(this) ? function Detector () {
this.listener = new Box2D.Dynamics.b2ContactListener(); this.listener = new Box2D.Dynamics.b2ContactListener();
this.listener.chuckDetector = this; this.listener.BeginContact = this.beginContact.bind(this);
this.listener.BeginContact = this.beginContact; //this.listener.PostSolve = this.postSolve.bind(this);
//this.listener.PostSolve = this.postSolve; this.listener.EndContact = this.endContact.bind(this);
this.listener.EndContact = this.endContact;
}
Detector.IDENTIFIER = {
TILE: "tile",
PLAYER: "player"
} }
Detector.prototype.getListener = function () { Detector.prototype.getListener = function () {
@ -27,7 +21,9 @@ function (Box2D) {
if (userDataA && userDataA.onCollisionChange) { if (userDataA && userDataA.onCollisionChange) {
userDataA.onCollisionChange(isColliding, point.GetFixtureB()); userDataA.onCollisionChange(isColliding, point.GetFixtureB());
} else if (userDataB && userDataB.onCollisionChange) { }
if (userDataB && userDataB.onCollisionChange) {
userDataB.onCollisionChange(isColliding, point.GetFixtureA()); userDataB.onCollisionChange(isColliding, point.GetFixtureA());
} }
} }
@ -35,14 +31,24 @@ function (Box2D) {
/** Extension **/ /** Extension **/
Detector.prototype.beginContact = function (point) { Detector.prototype.beginContact = function (point) {
this.chuckDetector.onCollisionChange(point, true); this.onCollisionChange(point, true);
} }
/*
Detector.prototype.postSolve = function (point, impulse) { Detector.prototype.postSolve = function (point, impulse) {
var userDataA = point.GetFixtureA().GetUserData();
var userDataB = point.GetFixtureB().GetUserData();
if (userDataA && userDataA.onImpulse) {
userDataA.onImpulse(impulse, point.GetFixtureB());
} else if (userDataB && userDataB.onImpulse) {
userDataB.onImpulse(impulse, point.GetFixtureA());
} }
}
*/
Detector.prototype.endContact = function (point) { Detector.prototype.endContact = function (point) {
this.chuckDetector.onCollisionChange(point, false); this.onCollisionChange(point, false);
} }
return Detector; return Detector;

View file

@ -60,6 +60,10 @@ function (Parent, Box2D, Settings, CollisionDetector, Item) {
headShape.SetLocalPosition(new Box2D.Common.Math.b2Vec2(0, -(this.height - (this.width / 2)) / Settings.RATIO)); headShape.SetLocalPosition(new Box2D.Common.Math.b2Vec2(0, -(this.height - (this.width / 2)) / Settings.RATIO));
fixtureDef.shape = headShape; fixtureDef.shape = headShape;
fixtureDef.isSensor = false; fixtureDef.isSensor = false;
fixtureDef.userData = {
onCollisionChange: this.onImpact.bind(this)
}
this.body.CreateFixture(fixtureDef); this.body.CreateFixture(fixtureDef);
var bodyShape = new Box2D.Collision.Shapes.b2PolygonShape(); var bodyShape = new Box2D.Collision.Shapes.b2PolygonShape();
@ -270,30 +274,8 @@ function (Parent, Box2D, Settings, CollisionDetector, Item) {
}; };
Doll.prototype.grab = function(item) { Doll.prototype.grab = function(item) {
this.holdingItem = item; this.holdingItem = item;
this.positionHoldingItem(); this.positionHoldingItem();
/*
var item = null;
if (this.lookDirection == -1) {
item = this.reachableItems.left.shift();
} else {
item = this.reachableItems.right.shift();
}
if(item) {
this.holdingItem = item;
this.positionHoldingItem();
}
return item;
*/
}; };
Doll.prototype.positionHoldingItem = function() { Doll.prototype.positionHoldingItem = function() {
@ -346,6 +328,10 @@ function (Parent, Box2D, Settings, CollisionDetector, Item) {
} }
} }
Doll.prototype.onImpact = function(isColliding, fixture) {
// overwrite if necessary
};
Doll.prototype.onFixtureWithinReach = function(isColliding, side, fixture) { Doll.prototype.onFixtureWithinReach = function(isColliding, side, fixture) {
var item = fixture.GetBody().GetUserData(); var item = fixture.GetBody().GetUserData();
if (!(item instanceof Item)) return; if (!(item instanceof Item)) return;

View file

@ -1,10 +1,11 @@
define([ define([
"Game/Config/Settings", "Game/Config/Settings",
"Lib/Vendor/Box2D", "Lib/Vendor/Box2D",
"Game/" + GLOBALS.context + "/Collision/Detector" "Game/" + GLOBALS.context + "/Collision/Detector",
"Lib/Utilities/NotificationCenter"
], ],
function (Settings, Box2D, CollisionDetector) { function (Settings, Box2D, CollisionDetector, NotificationCenter) {
function Engine () { function Engine () {
this.world = new Box2D.Dynamics.b2World( this.world = new Box2D.Dynamics.b2World(
@ -14,6 +15,9 @@ function (Settings, Box2D, CollisionDetector) {
this.world.SetWarmStarting(true); this.world.SetWarmStarting(true);
this.ground = null; this.ground = null;
this.lastStep = Date.now(); this.lastStep = Date.now();
this.worldQueue = [];
NotificationCenter.on("engine/addToWorldQueue", this.addToWorldQueue, this);
} }
Engine.prototype.getWorld = function () { Engine.prototype.getWorld = function () {
@ -24,9 +28,9 @@ function (Settings, Box2D, CollisionDetector) {
return this.ground; return this.ground;
} }
Engine.prototype.setCollisionDetector = function (player) { Engine.prototype.setCollisionDetector = function () {
var detector = new CollisionDetector(player); var detector = new CollisionDetector();
this.world.SetContactListener(detector.getListener()); this.world.SetContactListener(detector.getListener());
} }
@ -36,12 +40,26 @@ function (Settings, Box2D, CollisionDetector) {
return body; return body;
} }
Engine.prototype.addToWorldQueue = function(callback) {
this.worldQueue.push(callback);
};
Engine.prototype.processWorldQueue = function() {
for (var i = 0; i < this.worldQueue.length; i++) {
this.worldQueue[i]();
};
this.worldQueue = [];
};
Engine.prototype.update = function () { Engine.prototype.update = function () {
var stepLength = (Date.now() - this.lastStep) / 1000; var stepLength = (Date.now() - this.lastStep) / 1000;
this.world.Step(stepLength, Settings.BOX2D_VELOCITY_ITERATIONS, Settings.BOX2D_POSITION_ITERATIONS); this.world.Step(stepLength, Settings.BOX2D_VELOCITY_ITERATIONS, Settings.BOX2D_POSITION_ITERATIONS);
this.lastStep = Date.now(); this.lastStep = Date.now();
this.world.ClearForces(); this.world.ClearForces();
this.processWorldQueue();
} }
return Engine; return Engine;
}); });

View file

@ -1,12 +1,19 @@
define([ define([
"Game/" + GLOBALS.context + "/GameObjects/Doll", "Game/" + GLOBALS.context + "/GameObjects/Doll",
"Game/Config/Settings" "Game/Config/Settings",
"Lib/Utilities/NotificationCenter"
], ],
function (Doll, Settings) { function (Doll, Settings, NotificationCenter) {
function Player (id, physicsEngine) { function Player (id, physicsEngine) {
this.stats = {
health: 100,
deaths: 0,
kills: 0
}
this.physicsEngine = physicsEngine; this.physicsEngine = physicsEngine;
this.playerController = null; this.playerController = null;
this.doll; this.doll;
@ -20,6 +27,9 @@ function (Doll, Settings) {
}; };
Player.prototype.spawn = function (x, y) { Player.prototype.spawn = function (x, y) {
if(this.doll) {
this.doll.destroy();
}
this.doll = new Doll(this.physicsEngine, "doll-" + this.id, this); this.doll = new Doll(this.physicsEngine, "doll-" + this.id, this);
this.doll.spawn(x, y); this.doll.spawn(x, y);
this.isSpawned = true; this.isSpawned = true;
@ -64,6 +74,10 @@ function (Doll, Settings) {
this.holdingItem = null; this.holdingItem = null;
}; };
Player.prototype.kill = function(killedBy) {
NotificationCenter.trigger("player/killed", this);
};
Player.prototype.update = function () { Player.prototype.update = function () {
if(this.doll) { if(this.doll) {

View file

@ -4,14 +4,12 @@ define([
function (Parent) { function (Parent) {
function Detector (player) { function Detector () {
Parent.call(this, player); Parent.call(this);
} }
Detector.prototype = Object.create(Parent.prototype); Detector.prototype = Object.create(Parent.prototype);
Detector.IDENTIFIER = Parent.IDENTIFIER; // Needed because otherwise it will not be
// inherited because it is not in prototype
return Detector; return Detector;
}); });

View file

@ -23,6 +23,7 @@ function (Parent, PhysicsEngine, Settings, PlayerController, requestAnimFrame, N
NotificationCenter.on('user/joined', this.userJoined, this); NotificationCenter.on('user/joined', this.userJoined, this);
NotificationCenter.on('user/left', this.userLeft, this); // FIXME: refactor this.userLeft -> this.onUserLeft, even in core and client NotificationCenter.on('user/left', this.userLeft, this); // FIXME: refactor this.userLeft -> this.onUserLeft, even in core and client
NotificationCenter.on('user/resetLevel', this.onResetLevel, this); NotificationCenter.on('user/resetLevel', this.onResetLevel, this);
NotificationCenter.on('player/killed', this.spawnPlayer, this);
console.checkpoint('starting game controller for channel ' + channel.name); console.checkpoint('starting game controller for channel ' + channel.name);
} }

View file

@ -1,8 +1,11 @@
define([ define([
"Game/Core/GameObjects/Doll" "Game/Core/GameObjects/Doll",
"Game/Server/GameObjects/Item",
"Lib/Vendor/Box2D",
"Lib/Utilities/NotificationCenter"
], ],
function (Parent) { function (Parent, Item, Box2D, NotificationCenter) {
function Doll(physicsEngine, uid, player) { function Doll(physicsEngine, uid, player) {
Parent.call(this, physicsEngine, uid, player); Parent.call(this, physicsEngine, uid, player);
@ -28,6 +31,46 @@ function (Parent) {
} }
} }
Doll.prototype.onImpact = function(isColliding, fixture) {
var self = this;
Parent.prototype.onImpact.call(this, isColliding, fixture);
if(isColliding) {
var otherBody = fixture.GetBody();
if(otherBody) {
var item = otherBody.GetUserData();
if(item instanceof Item) {
var itemVelocity = item.body.GetLinearVelocity();
var itemMass = item.body.GetMass();
var ownVelocity = this.body.GetLinearVelocity();
var b2Math = Box2D.Common.Math.b2Math;
var absItemVelocity = b2Math.AbsV(itemVelocity)
var max = 1;
if(absItemVelocity.x > max || absItemVelocity.y > max) {
if(item.lastMoved && item.lastMoved.player != this.player) {
var damage = b2Math.SubtractVV(itemVelocity, ownVelocity);
damage.Abs();
damage.Multiply(itemMass);
var callback = function() {
self.player.addDamage(damage.Length() * 2, item.lastMoved.player);
}
NotificationCenter.trigger("engine/addToWorldQueue", callback)
}
}
item.setLastMovedBy(this.player);
}
}
}
}
return Doll; return Doll;
}); });

View file

@ -59,6 +59,15 @@ function (Parent, NotificationCenter) {
} }
}; };
Player.prototype.addDamage = function(damage, enemy) {
this.stats.health -= damage;
if(this.stats.health <= 0) {
this.stats.deaths++;
enemy.stats.kills++;
this.kill();
}
};
return Player; return Player;
}); });