phaser/src/gameobjects/components/Transform.js

297 lines
5.7 KiB
JavaScript
Raw Normal View History

var MATH_CONST = require('../../math/const');
var WrapAngle = require('../../math/angle/Wrap');
var WrapAngleDegrees = require('../../math/angle/WrapDegrees');
// global bitmask flag for GameObject.renderMask (used by Scale)
var _FLAG = 4; // 0100
// Transform Component
var Transform = {
// "private" properties
_scaleX: 1,
_scaleY: 1,
_rotation: 0,
_depth: 0,
_dirty: false,
_world: { a: 1, b: 0, c: 0, d: 1, tx: 0, ty: 0, sr: 0, cr: 0 },
2017-04-04 22:57:37 +00:00
// public properties / methods
// These are world coordinate values.
2017-04-04 22:57:37 +00:00
// If Game Object is a child of a Container, then you can modify its local position (relative to the Container)
// by setting `localX`, `localY`, etc (or changing x/y directly, but remember the values given here are world based).
// Changes to the parent Container are instantly reflected in the world coords here (x,y, etc)
_x: 0,
_y: 0,
_z: 0,
_w: 0,
x: {
2017-04-04 22:57:37 +00:00
get: function ()
{
return this._x;
2017-03-23 19:51:02 +00:00
},
2017-04-04 22:57:37 +00:00
set: function (value)
{
this._x = value;
this._dirty = true;
}
},
y: {
get: function ()
{
return this._y;
},
set: function (value)
{
this._y = value;
this._dirty = true;
}
},
z: {
get: function ()
{
return this._z;
},
set: function (value)
{
this._z = value;
this._dirty = true;
}
},
w: {
get: function ()
{
return this._w;
},
set: function (value)
{
this._w = value;
this._dirty = true;
2017-03-23 19:51:02 +00:00
}
2017-04-04 22:57:37 +00:00
2017-03-23 19:51:02 +00:00
},
scaleX: {
get: function ()
{
return this._scaleX;
},
set: function (value)
{
this._scaleX = value;
this._dirty = true;
if (this._scaleX === 0)
{
this.renderFlags &= ~_FLAG;
}
else
{
this.renderFlags |= _FLAG;
}
}
},
scaleY: {
get: function ()
{
return this._scaleY;
},
set: function (value)
{
this._scaleY = value;
this._dirty = true;
if (this._scaleY === 0)
{
this.renderFlags &= ~_FLAG;
}
else
{
this.renderFlags |= _FLAG;
}
}
},
angle: {
get: function ()
{
return WrapAngleDegrees(this._rotation * MATH_CONST.RAD_TO_DEG);
},
set: function (value)
{
// value is in degrees
this.rotation = WrapAngleDegrees(value) * MATH_CONST.DEG_TO_RAD;
}
},
rotation: {
get: function ()
{
return this._rotation;
},
set: function (value)
{
// value is in radians
this._rotation = WrapAngle(value);
this._world.sr = Math.sin(this._rotation);
this._world.cr = Math.cos(this._rotation);
this._dirty = true;
}
},
depth: {
get: function ()
{
return this._depth;
},
set: function (value)
{
this.scene.sys.sortChildrenFlag = true;
this._depth = value;
}
},
2017-09-15 03:04:51 +00:00
setPosition: function (x, y, z, w)
{
2017-03-09 00:41:21 +00:00
if (x === undefined) { x = 0; }
if (y === undefined) { y = x; }
2017-09-15 03:04:51 +00:00
if (z === undefined) { z = 0; }
if (w === undefined) { w = 0; }
this._x = x;
this._y = y;
this._z = z;
this._w = w;
this._dirty = true;
return this;
},
setRotation: function (radians)
{
2017-03-09 00:41:21 +00:00
if (radians === undefined) { radians = 0; }
this.rotation = radians;
return this;
},
2017-07-13 01:05:44 +00:00
setAngle: function (degrees)
{
if (degrees === undefined) { degrees = 0; }
this.angle = degrees;
return this;
},
setScale: function (x, y)
{
if (x === undefined) { x = 1; }
if (y === undefined) { y = x; }
2017-03-28 23:43:55 +00:00
this.scaleX = x;
this.scaleY = y;
2017-04-04 22:57:37 +00:00
return this;
},
2017-09-15 03:04:51 +00:00
setZ: function (value)
{
if (value === undefined) { value = 0; }
this.z = value;
return this;
},
setW: function (value)
{
if (value === undefined) { value = 0; }
this.w = value;
return this;
},
setDepth: function (value)
2017-04-04 22:57:37 +00:00
{
if (value === undefined) { value = 0; }
this.depth = value;
2017-04-04 22:57:37 +00:00
return this;
},
updateTransform: function ()
{
if (!this.parent || !this._dirty)
{
return;
}
var tx = this._x;
var ty = this._y;
var world = this._world;
var parent = this.parent.world;
var a = world.cr * this._scaleX;
var b = world.sr * this._scaleX;
var c = -world.sr * this._scaleY;
var d = world.cr * this._scaleY;
world.a = (a * parent.a) + (b * parent.c);
world.b = (a * parent.b) + (b * parent.d);
world.c = (c * parent.a) + (d * parent.c);
world.d = (c * parent.b) + (d * parent.d);
// this._worldRotation = Math.atan2(-this.world.c, this.world.d);
world.tx = (tx * parent.a) + (ty * parent.c) + parent.tx;
world.ty = (tx * parent.b) + (ty * parent.d) + parent.ty;
// this._worldScaleX = this._scaleX * Math.sqrt((world.a * world.a) + (world.c * world.c));
// this._worldScaleY = this._scaleY * Math.sqrt((world.b * world.b) + (world.d * world.d));
}
};
module.exports = Transform;