phaser/Phaser/physics/Body.ts

215 lines
5.8 KiB
TypeScript
Raw Normal View History

/// <reference path="../_definitions.ts" />
2013-08-02 11:38:56 +00:00
/**
* Phaser - Physics - Body
* A binding between a Sprite and a physics object (AABB or Circle)
2013-08-02 11:38:56 +00:00
*/
module Phaser.Physics {
export class Body {
constructor(sprite: Phaser.Sprite, type: number) {
this.sprite = sprite;
this.game = sprite.game;
this.type = type;
this.aabb = new Phaser.Physics.AABB(sprite.game, sprite.x, sprite.y, sprite.width, sprite.height);
2013-08-02 11:38:56 +00:00
this.velocity = new Phaser.Vec2;
this.acceleration = new Phaser.Vec2;
this.drag = new Phaser.Vec2;
this.gravity = new Phaser.Vec2;
this.maxVelocity = new Phaser.Vec2(10000, 10000);
2013-08-02 11:38:56 +00:00
this.angularVelocity = 0;
this.angularAcceleration = 0;
this.angularDrag = 0;
this.maxAngular = 10000;
2013-08-02 11:38:56 +00:00
//this.touching = Phaser.Types.NONE;
//this.wasTouching = Phaser.Types.NONE;
this.allowCollisions = Phaser.Types.ANY;
2013-08-02 11:38:56 +00:00
//this.position = new Phaser.Vec2(sprite.x + this.bounds.halfWidth, sprite.y + this.bounds.halfHeight);
//this.oldPosition = new Phaser.Vec2(sprite.x + this.bounds.halfWidth, sprite.y + this.bounds.halfHeight);
//this.offset = new Phaser.Vec2;
2013-08-02 11:38:56 +00:00
}
public game: Phaser.Game;
2013-08-02 11:38:56 +00:00
public sprite: Phaser.Sprite;
public aabb: Phaser.Physics.AABB;
public bounds: Phaser.Rectangle;
2013-08-02 11:38:56 +00:00
/**
* The type of Body (disabled, dynamic, static or kinematic)
* Disabled = skips all physics operations / tests (default)
* Dynamic = gives and receives impacts
* Static = gives but doesn't receive impacts, cannot be moved by physics
* Kinematic = gives impacts, but never receives, can be moved by physics
* @type {number}
*/
public type: number;
public gravity: Phaser.Vec2;
public bounce: Phaser.Vec2;
2013-08-02 11:38:56 +00:00
public velocity: Phaser.Vec2;
public acceleration: Phaser.Vec2;
public drag: Phaser.Vec2;
public maxVelocity: Phaser.Vec2;
2013-08-02 11:38:56 +00:00
public angularVelocity: number = 0;
public angularAcceleration: number = 0;
public angularDrag: number = 0;
public maxAngular: number = 10000;
/**
* Orientation of the object.
* @type {number}
*/
public facing: number;
public deltaX: number = 0;
public deltaY: number = 0;
//public touching: number;
2013-08-02 11:38:56 +00:00
public allowCollisions: number;
//public wasTouching: number;
//public mass: number = 1;
2013-08-02 11:38:56 +00:00
//public position: Phaser.Vec2;
//public oldPosition: Phaser.Vec2;
//public offset: Phaser.Vec2;
//public bounds: Phaser.Rectangle;
2013-08-02 11:38:56 +00:00
/*
2013-08-02 11:38:56 +00:00
private _width: number = 0;
private _height: number = 0;
public get x(): number {
return this.sprite.x + this.offset.x;
}
public get y(): number {
return this.sprite.y + this.offset.y;
}
public set width(value: number) {
this._width = value;
}
public set height(value: number) {
this._height = value;
}
public get width(): number {
return this._width * this.sprite.transform.scale.x;
}
public get height(): number {
return this._height * this.sprite.transform.scale.y;
}
public preUpdate() {
this.oldPosition.copyFrom(this.position);
this.bounds.x = this.x;
this.bounds.y = this.y;
this.bounds.width = this.width;
this.bounds.height = this.height;
}
// Shall we do this? Or just update the values directly in the separate functions? But then the bounds will be out of sync - as long as
// the bounds are updated and used in calculations then we can do one final sprite movement here I guess?
public postUpdate() {
// if this is all it does maybe move elsewhere? Sprite postUpdate?
if (this.type !== Phaser.Types.BODY_DISABLED)
{
//this.game.world.physics.updateMotion(this);
this.wasTouching = this.touching;
this.touching = Phaser.Types.NONE;
}
this.position.setTo(this.x, this.y);
}
public get hullWidth(): number {
if (this.deltaX > 0)
{
return this.bounds.width + this.deltaX;
}
else
{
return this.bounds.width - this.deltaX;
}
}
public get hullHeight(): number {
if (this.deltaY > 0)
{
return this.bounds.height + this.deltaY;
}
else
{
return this.bounds.height - this.deltaY;
}
}
public get hullX(): number {
if (this.position.x < this.oldPosition.x)
{
return this.position.x;
}
else
{
return this.oldPosition.x;
}
}
public get hullY(): number {
if (this.position.y < this.oldPosition.y)
{
return this.position.y;
}
else
{
return this.oldPosition.y;
}
}
public get deltaXAbs(): number {
return (this.deltaX > 0 ? this.deltaX : -this.deltaX);
}
public get deltaYAbs(): number {
return (this.deltaY > 0 ? this.deltaY : -this.deltaY);
}
public get deltaX(): number {
return this.position.x - this.oldPosition.x;
}
public get deltaY(): number {
return this.position.y - this.oldPosition.y;
}
*/
2013-08-02 11:38:56 +00:00
}
}