2018-02-12 16:01:20 +00:00
|
|
|
/**
|
2024-02-19 17:12:18 +00:00
|
|
|
* @author Richard Davey <rich@phaser.io>
|
|
|
|
* @copyright 2013-2024 Phaser Studio Inc.
|
2019-05-10 15:15:04 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
2018-02-12 16:01:20 +00:00
|
|
|
*/
|
|
|
|
|
2017-06-30 14:47:51 +00:00
|
|
|
var Class = require('../../utils/Class');
|
2017-10-29 21:46:23 +00:00
|
|
|
var Contains = require('./Contains');
|
2017-10-25 15:06:52 +00:00
|
|
|
var GetPoint = require('./GetPoint');
|
|
|
|
var GetPoints = require('./GetPoints');
|
2019-07-18 09:36:11 +00:00
|
|
|
var GEOM_CONST = require('../const');
|
2017-09-25 17:10:01 +00:00
|
|
|
var Random = require('./Random');
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-02-07 15:27:21 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
|
|
|
* An Ellipse object.
|
|
|
|
*
|
|
|
|
* This is a geometry object, containing numerical values and related methods to inspect and modify them.
|
|
|
|
* It is not a Game Object, in that you cannot add it to the display list, and it has no texture.
|
|
|
|
* To render an Ellipse you should look at the capabilities of the Graphics class.
|
|
|
|
*
|
|
|
|
* @class Ellipse
|
2018-10-10 09:49:13 +00:00
|
|
|
* @memberof Phaser.Geom
|
2018-02-07 15:27:21 +00:00
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} [x=0] - The x position of the center of the ellipse.
|
|
|
|
* @param {number} [y=0] - The y position of the center of the ellipse.
|
|
|
|
* @param {number} [width=0] - The width of the ellipse.
|
|
|
|
* @param {number} [height=0] - The height of the ellipse.
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
var Ellipse = new Class({
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2017-06-30 14:47:51 +00:00
|
|
|
initialize:
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2017-06-30 14:47:51 +00:00
|
|
|
function Ellipse (x, y, width, height)
|
|
|
|
{
|
|
|
|
if (x === undefined) { x = 0; }
|
|
|
|
if (y === undefined) { y = 0; }
|
|
|
|
if (width === undefined) { width = 0; }
|
|
|
|
if (height === undefined) { height = 0; }
|
|
|
|
|
2019-07-18 09:36:11 +00:00
|
|
|
/**
|
|
|
|
* The geometry constant type of this object: `GEOM_CONST.ELLIPSE`.
|
|
|
|
* Used for fast type comparisons.
|
|
|
|
*
|
|
|
|
* @name Phaser.Geom.Ellipse#type
|
2020-11-23 10:22:13 +00:00
|
|
|
* @type {number}
|
2019-07-18 09:36:11 +00:00
|
|
|
* @readonly
|
|
|
|
* @since 3.19.0
|
|
|
|
*/
|
|
|
|
this.type = GEOM_CONST.ELLIPSE;
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The x position of the center of the ellipse.
|
|
|
|
*
|
2018-02-07 15:27:21 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#x
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.x = x;
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The y position of the center of the ellipse.
|
|
|
|
*
|
2018-02-07 15:27:21 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#y
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.y = y;
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The width of the ellipse.
|
|
|
|
*
|
2018-02-07 15:27:21 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#width
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.width = width;
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The height of the ellipse.
|
|
|
|
*
|
2018-02-07 15:27:21 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#height
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.height = height;
|
|
|
|
},
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Check to see if the Ellipse contains the given x / y coordinates.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#contains
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} x - The x coordinate to check within the ellipse.
|
|
|
|
* @param {number} y - The y coordinate to check within the ellipse.
|
|
|
|
*
|
|
|
|
* @return {boolean} True if the coordinates are within the ellipse, otherwise false.
|
|
|
|
*/
|
2017-10-29 21:46:23 +00:00
|
|
|
contains: function (x, y)
|
|
|
|
{
|
|
|
|
return Contains(this, x, y);
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Returns a Point object containing the coordinates of a point on the circumference of the Ellipse
|
|
|
|
* based on the given angle normalized to the range 0 to 1. I.e. a value of 0.5 will give the point
|
|
|
|
* at 180 degrees around the circle.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#getPoint
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2024-11-14 18:21:43 +00:00
|
|
|
* @generic {Phaser.Math.Vector2} O - [out,$return]
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2018-06-26 22:19:14 +00:00
|
|
|
* @param {number} position - A value between 0 and 1, where 0 equals 0 degrees, 0.5 equals 180 degrees and 1 equals 360 around the ellipse.
|
2024-11-14 18:45:04 +00:00
|
|
|
* @param {Phaser.Math.Vector2} [out] - A Vector2 to store the return values in. If not given a Vector2 object will be created.
|
2018-01-26 04:53:16 +00:00
|
|
|
*
|
2024-11-14 18:45:04 +00:00
|
|
|
* @return {Phaser.Math.Vector2} A Vector2 instance containing the coordinates of the point around the ellipse.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-10-25 15:06:52 +00:00
|
|
|
getPoint: function (position, point)
|
|
|
|
{
|
|
|
|
return GetPoint(this, position, point);
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
2024-11-14 18:45:04 +00:00
|
|
|
* Returns an array of Vector2 objects containing the coordinates of the points around the circumference of the Ellipse,
|
2018-01-26 04:53:16 +00:00
|
|
|
* based on the given quantity or stepRate values.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#getPoints
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2024-11-14 18:21:43 +00:00
|
|
|
* @generic {Phaser.Math.Vector2[]} O - [output,$return]
|
2020-01-03 12:21:50 +00:00
|
|
|
*
|
2020-11-23 10:22:13 +00:00
|
|
|
* @param {number} quantity - The amount of points to return. If a falsey value the quantity will be derived from the `stepRate` instead.
|
2018-01-26 04:53:16 +00:00
|
|
|
* @param {number} [stepRate] - Sets the quantity by getting the circumference of the ellipse and dividing it by the stepRate.
|
2024-11-14 18:45:04 +00:00
|
|
|
* @param {Phaser.Math.Vector2[]} [output] - An array to insert the Vector2s in. If not provided a new array will be created.
|
2018-01-26 04:53:16 +00:00
|
|
|
*
|
2024-11-14 18:45:04 +00:00
|
|
|
* @return {Phaser.Math.Vector2[]} An array of Vector2 objects pertaining to the points around the circumference of the ellipse.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-10-26 15:37:00 +00:00
|
|
|
getPoints: function (quantity, stepRate, output)
|
2017-10-25 15:06:52 +00:00
|
|
|
{
|
2017-10-26 15:37:00 +00:00
|
|
|
return GetPoints(this, quantity, stepRate, output);
|
2017-10-25 15:06:52 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Returns a uniformly distributed random point from anywhere within the given Ellipse.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#getRandomPoint
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2024-11-14 18:21:43 +00:00
|
|
|
* @generic {Phaser.Math.Vector2} O - [point,$return]
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2024-11-14 18:45:04 +00:00
|
|
|
* @param {Phaser.Math.Vector2} [vec] - A Vector2 object to set the random `x` and `y` values in.
|
2018-01-26 04:53:16 +00:00
|
|
|
*
|
2024-11-14 18:45:04 +00:00
|
|
|
* @return {Phaser.Math.Vector2} A Vector2 object with the random values set in the `x` and `y` properties.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2024-11-14 18:45:04 +00:00
|
|
|
getRandomPoint: function (vec)
|
2017-09-25 17:10:01 +00:00
|
|
|
{
|
2024-11-14 18:45:04 +00:00
|
|
|
return Random(this, vec);
|
2017-09-25 17:10:01 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Sets the x, y, width and height of this ellipse.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#setTo
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} x - The x position of the center of the ellipse.
|
|
|
|
* @param {number} y - The y position of the center of the ellipse.
|
|
|
|
* @param {number} width - The width of the ellipse.
|
|
|
|
* @param {number} height - The height of the ellipse.
|
|
|
|
*
|
2020-01-30 15:32:05 +00:00
|
|
|
* @return {this} This Ellipse object.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
setTo: function (x, y, width, height)
|
|
|
|
{
|
|
|
|
this.x = x;
|
|
|
|
this.y = y;
|
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Sets this Ellipse to be empty with a width and height of zero.
|
|
|
|
* Does not change its position.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#setEmpty
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2020-01-30 15:32:05 +00:00
|
|
|
* @return {this} This Ellipse object.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
setEmpty: function ()
|
|
|
|
{
|
2018-01-26 04:53:16 +00:00
|
|
|
this.width = 0;
|
|
|
|
this.height = 0;
|
|
|
|
|
|
|
|
return this;
|
2017-01-01 18:23:19 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Sets the position of this Ellipse.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#setPosition
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} x - The x position of the center of the ellipse.
|
|
|
|
* @param {number} y - The y position of the center of the ellipse.
|
|
|
|
*
|
2020-01-30 15:32:05 +00:00
|
|
|
* @return {this} This Ellipse object.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
setPosition: function (x, y)
|
|
|
|
{
|
|
|
|
if (y === undefined) { y = x; }
|
|
|
|
|
|
|
|
this.x = x;
|
|
|
|
this.y = y;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Sets the size of this Ellipse.
|
|
|
|
* Does not change its position.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#setSize
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} width - The width of the ellipse.
|
|
|
|
* @param {number} [height=width] - The height of the ellipse.
|
|
|
|
*
|
2020-01-30 15:32:05 +00:00
|
|
|
* @return {this} This Ellipse object.
|
2018-01-26 04:53:16 +00:00
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
setSize: function (width, height)
|
|
|
|
{
|
|
|
|
if (height === undefined) { height = width; }
|
|
|
|
|
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Checks to see if the Ellipse is empty: has a width or height equal to zero.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#isEmpty
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {boolean} True if the Ellipse is empty, otherwise false.
|
|
|
|
*/
|
2017-01-02 00:53:18 +00:00
|
|
|
isEmpty: function ()
|
|
|
|
{
|
|
|
|
return (this.width <= 0 || this.height <= 0);
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Returns the minor radius of the ellipse. Also known as the Semi Minor Axis.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#getMinorRadius
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {number} The minor radius.
|
|
|
|
*/
|
2017-01-02 00:47:16 +00:00
|
|
|
getMinorRadius: function ()
|
|
|
|
{
|
|
|
|
return Math.min(this.width, this.height) / 2;
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* Returns the major radius of the ellipse. Also known as the Semi Major Axis.
|
|
|
|
*
|
|
|
|
* @method Phaser.Geom.Ellipse#getMajorRadius
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {number} The major radius.
|
|
|
|
*/
|
2017-01-02 00:47:16 +00:00
|
|
|
getMajorRadius: function ()
|
|
|
|
{
|
|
|
|
return Math.max(this.width, this.height) / 2;
|
2017-06-30 14:47:51 +00:00
|
|
|
},
|
2017-01-01 18:23:19 +00:00
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The left position of the Ellipse.
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2018-01-26 04:53:16 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#left
|
2018-02-07 15:27:21 +00:00
|
|
|
* @type {number}
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
left: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
return this.x - (this.width / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
this.x = value + (this.width / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The right position of the Ellipse.
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2018-01-26 04:53:16 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#right
|
2018-02-07 15:27:21 +00:00
|
|
|
* @type {number}
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
right: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
return this.x + (this.width / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
this.x = value - (this.width / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The top position of the Ellipse.
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2018-01-26 04:53:16 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#top
|
2018-02-07 15:27:21 +00:00
|
|
|
* @type {number}
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
top: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
return this.y - (this.height / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
this.y = value + (this.height / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2018-01-26 04:53:16 +00:00
|
|
|
/**
|
|
|
|
* The bottom position of the Ellipse.
|
2018-03-27 13:27:08 +00:00
|
|
|
*
|
2018-01-26 04:53:16 +00:00
|
|
|
* @name Phaser.Geom.Ellipse#bottom
|
2018-02-07 15:27:21 +00:00
|
|
|
* @type {number}
|
2018-01-26 04:53:16 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-01-01 18:23:19 +00:00
|
|
|
bottom: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
return this.y + (this.height / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
2017-12-02 01:24:36 +00:00
|
|
|
this.y = value - (this.height / 2);
|
2017-01-01 18:23:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Ellipse;
|