Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

collider2d

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

collider2d - npm Package Compare versions

Comparing version 0.1.1 to 0.2.0

4

CHANGELOG.md

@@ -0,1 +1,5 @@

## 0.2.0 / 2020-02-18
- [FEATURE] Added `translate` to circle to easily modify the position like the polygon version.
- [TEST] Added testing for circle and polygon translations.
## 0.1.1 / 2020-02-18

@@ -2,0 +6,0 @@ - [MISC] Replaced rollup-plugin-commonjs and rollup-plugin-node-resolve with @rollup/plugin-commonjs and @rollup/plugin-node-resolve.

@@ -481,3 +481,3 @@ function _classCallCheck(instance, Constructor) {

* @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.
*
* *
* @returns {Polygon} Returns this for chaining.

@@ -721,2 +721,24 @@ */

/**
* **Note:** Not sure if this will be kept or not but for now it's disabled.
*
* Sets a new position for this polygon and recalculates the points.
*
* @param {Vector} position A Vector representing the new position of this polygon.
*/
// set position(position: Vector) {
// const diffX: number = -(this._position.x - position.x);
// const diffY: number = -(this._position.y - position.y);
// const diffPoint: Vector = new Vector(diffX, diffY);
// const points: Array<Vector> = [];
// this._points.map((point: Vector) => {
// const tempX: number = point.x;
// const tempY: number = point.y;
// const tempPoint: Vector = new Vector(tempX, tempY);
// const calculatedPoint: Vector = tempPoint.add(diffPoint);
// points.push(calculatedPoint);
// });
// this.setPoints(points, true);
// }
/**
* Returns the points of this polygon.

@@ -927,5 +949,14 @@ *

_createClass(Circle, [{
key: "getAABB",
key: "translate",
/**
* Translate the center of the cirlc.e
*
* @param {Vector} position A Vector representing the new center of this circle.
*/
value: function translate(x, y) {
this._position.x += x;
this._position.y += y;
}
/**
* Compute the axis-aligned bounding box (AABB) of this Circle.

@@ -937,2 +968,5 @@ *

*/
}, {
key: "getAABB",
value: function getAABB() {

@@ -939,0 +973,0 @@ var corner = this._position.clone().add(this._offset).sub(new Vector(this._radius, this._radius));

@@ -483,3 +483,3 @@ 'use strict';

* @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.
*
* *
* @returns {Polygon} Returns this for chaining.

@@ -723,2 +723,24 @@ */

/**
* **Note:** Not sure if this will be kept or not but for now it's disabled.
*
* Sets a new position for this polygon and recalculates the points.
*
* @param {Vector} position A Vector representing the new position of this polygon.
*/
// set position(position: Vector) {
// const diffX: number = -(this._position.x - position.x);
// const diffY: number = -(this._position.y - position.y);
// const diffPoint: Vector = new Vector(diffX, diffY);
// const points: Array<Vector> = [];
// this._points.map((point: Vector) => {
// const tempX: number = point.x;
// const tempY: number = point.y;
// const tempPoint: Vector = new Vector(tempX, tempY);
// const calculatedPoint: Vector = tempPoint.add(diffPoint);
// points.push(calculatedPoint);
// });
// this.setPoints(points, true);
// }
/**
* Returns the points of this polygon.

@@ -929,5 +951,14 @@ *

_createClass(Circle, [{
key: "getAABB",
key: "translate",
/**
* Translate the center of the cirlc.e
*
* @param {Vector} position A Vector representing the new center of this circle.
*/
value: function translate(x, y) {
this._position.x += x;
this._position.y += y;
}
/**
* Compute the axis-aligned bounding box (AABB) of this Circle.

@@ -939,2 +970,5 @@ *

*/
}, {
key: "getAABB",
value: function getAABB() {

@@ -941,0 +975,0 @@ var corner = this._position.clone().add(this._offset).sub(new Vector(this._radius, this._radius));

@@ -65,2 +65,8 @@ import Vector from './Vector';

/**
* Translate the center of the cirlc.e
*
* @param {Vector} position A Vector representing the new center of this circle.
*/
translate(x: number, y: number): void;
/**
* Compute the axis-aligned bounding box (AABB) of this Circle.

@@ -67,0 +73,0 @@ *

@@ -83,5 +83,14 @@ 'use strict';

_createClass(Circle, [{
key: "getAABB",
key: "translate",
/**
* Translate the center of the cirlc.e
*
* @param {Vector} position A Vector representing the new center of this circle.
*/
value: function translate(x, y) {
this._position.x += x;
this._position.y += y;
}
/**
* Compute the axis-aligned bounding box (AABB) of this Circle.

@@ -93,2 +102,5 @@ *

*/
}, {
key: "getAABB",
value: function getAABB() {

@@ -155,2 +167,2 @@ var corner = this._position.clone().add(this._offset).sub(new _Vector["default"](this._radius, this._radius));

exports["default"] = Circle;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW9tZXRyeS9DaXJjbGUudHMiXSwibmFtZXMiOlsiQ2lyY2xlIiwicG9zaXRpb24iLCJWZWN0b3IiLCJyYWRpdXMiLCJfcG9zaXRpb24iLCJfcmFkaXVzIiwiY29ybmVyIiwiY2xvbmUiLCJhZGQiLCJfb2Zmc2V0Iiwic3ViIiwiQm94IiwidG9Qb2x5Z29uIiwib2Zmc2V0Il0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7OztBQUVBOztBQUNBOzs7Ozs7Ozs7Ozs7QUFHQTs7Ozs7OztJQU9xQkEsTTs7O0FBQ25COzs7Ozs7OztBQVNBOzs7Ozs7OztBQVNBOzs7Ozs7OztBQVNBOzs7O0FBSUEsb0JBQWlFO0FBQUEsUUFBckRDLFFBQXFELHVFQUFsQyxJQUFJQyxrQkFBSixFQUFrQztBQUFBLFFBQXBCQyxNQUFvQix1RUFBSCxDQUFHOztBQUFBOztBQUFBLHVDQXhCckMsSUFBSUQsa0JBQUosRUF3QnFDOztBQUFBLHFDQWZ2QyxDQWV1Qzs7QUFBQSxxQ0FOdkMsSUFBSUEsa0JBQUosRUFNdUM7O0FBQy9ELFNBQUtFLFNBQUwsR0FBaUJILFFBQWpCO0FBRUEsU0FBS0ksT0FBTCxHQUFlRixNQUFmO0FBQ0Q7QUFFRDs7Ozs7Ozs7OztBQTRCQTs7Ozs7Ozs4QkFPbUI7QUFDakIsVUFBTUcsTUFBTSxHQUFHLEtBQUtGLFNBQUwsQ0FBZUcsS0FBZixHQUF1QkMsR0FBdkIsQ0FBMkIsS0FBS0MsT0FBaEMsRUFBeUNDLEdBQXpDLENBQTZDLElBQUlSLGtCQUFKLENBQVcsS0FBS0csT0FBaEIsRUFBeUIsS0FBS0EsT0FBOUIsQ0FBN0MsQ0FBZjs7QUFFQSxhQUFPLElBQUlNLGVBQUosQ0FBUUwsTUFBUixFQUFnQixLQUFLRCxPQUFMLEdBQWUsQ0FBL0IsRUFBa0MsS0FBS0EsT0FBTCxHQUFlLENBQWpELEVBQW9ETyxTQUFwRCxFQUFQO0FBQ0Q7QUFFRDs7Ozs7Ozs7Ozs4QkFPVUMsTSxFQUF3QjtBQUNoQyxXQUFLSixPQUFMLEdBQWVJLE1BQWY7QUFFQSxhQUFPLElBQVA7QUFDRDs7O3dCQS9Dc0I7QUFBRSxhQUFPLEtBQUtULFNBQVo7QUFBd0I7QUFFakQ7Ozs7Ozs7O3dCQUtxQjtBQUFFLGFBQU8sS0FBS0MsT0FBWjtBQUFzQjtBQUU3Qzs7Ozs7Ozs7d0JBS3FCO0FBQUUsYUFBTyxLQUFLSSxPQUFaO0FBQXNCO0FBRTdDOzs7Ozs7c0JBS1dJLE0sRUFBZ0I7QUFBRSxXQUFLSixPQUFMLEdBQWVJLE1BQWY7QUFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCdcclxuXHJcbmltcG9ydCBCb3ggZnJvbSAnLi9Cb3gnO1xyXG5pbXBvcnQgVmVjdG9yIGZyb20gJy4vVmVjdG9yJztcclxuaW1wb3J0IFBvbHlnb24gZnJvbSAnLi9Qb2x5Z29uJztcclxuXHJcbi8qKlxyXG4gKiBSZXByZXNlbnRzIGEgY2lyY2xlIHdpdGggYSBwb3NpdGlvbiBhbmQgYSByYWRpdXMuXHJcbiAqIFxyXG4gKiBDcmVhdGVzIGEgbmV3IENpcmNsZSwgb3B0aW9uYWxseSBwYXNzaW5nIGluIGEgcG9zaXRpb24gYW5kL29yIHJhZGl1cy4gSWYgbm8gcG9zaXRpb24gaXMgZ2l2ZW4sIHRoZSBDaXJjbGUgd2lsbCBiZSBhdCBgKDAsMClgLiBcclxuICogXHJcbiAqIElmIG5vIHJhZGl1cyBpcyBwcm92aWRlZCB0aGUgY2lyY2xlIHdpbGwgaGF2ZSBhIHJhZGl1cyBvZiBgMGAuXHJcbiAqL1xyXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBDaXJjbGUge1xyXG4gIC8qKlxyXG4gICAqIEEgVmVjdG9yIHJlcHJlc2VudGluZyB0aGUgY2VudGVyIHBvaW50IG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIEBwcml2YXRlXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtWZWN0b3J9XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBfcG9zaXRpb246IFZlY3RvciA9IG5ldyBWZWN0b3IoKTtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHJhZGl1cyBvZiB0aGlzIGNpcmNsZS5cclxuICAgKiBcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7bnVtYmVyfVxyXG4gICAqL1xyXG4gIHByaXZhdGUgX3JhZGl1czogbnVtYmVyID0gMDtcclxuXHJcbiAgLyoqXHJcbiAgICogQSBWZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBvZmZzZXQgb2YgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHByaXZhdGVcclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge1ZlY3Rvcn1cclxuICAgKi9cclxuICBwcml2YXRlIF9vZmZzZXQ6IFZlY3RvciA9IG5ldyBWZWN0b3IoKTtcclxuXHJcbiAgLyoqXHJcbiAgICogQHBhcmFtIHtWZWN0b3J9IHBvc2l0aW9uIEEgVmVjdG9yIHJlcHJlc2VudGluZyB0aGUgY2VudGVyIG9mIHRoaXMgQ2lyY2xlLlxyXG4gICAqIEBwYXJhbSB7bnVtYmVyfSByYWRpdXMgVGhlIHJhZGl1cyBvZiB0aGlzIENpcmNsZS4gXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocG9zaXRpb246IFZlY3RvciA9IG5ldyBWZWN0b3IoKSwgcmFkaXVzOiBudW1iZXIgPSAwKSB7XHJcbiAgICB0aGlzLl9wb3NpdGlvbiA9IHBvc2l0aW9uO1xyXG5cclxuICAgIHRoaXMuX3JhZGl1cyA9IHJhZGl1cztcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIHBvc2l0aW9uIG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtWZWN0b3J9XHJcbiAgICovXHJcbiAgZ2V0IHBvc2l0aW9uKCk6IFZlY3RvciB7IHJldHVybiB0aGlzLl9wb3NpdGlvbjsgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSByYWRpdXMgb2YgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge251bWJlcn1cclxuICAgKi9cclxuICBnZXQgcmFkaXVzKCk6IG51bWJlciB7IHJldHVybiB0aGlzLl9yYWRpdXM7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgb2Zmc2V0IG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtWZWN0b3J9XHJcbiAgICovXHJcbiAgZ2V0IG9mZnNldCgpOiBWZWN0b3IgeyByZXR1cm4gdGhpcy5fb2Zmc2V0OyB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNldCBhIG5ldyBvZmZzZXQgZm9yIHRoaXMgY2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSB7VmVjdG9yfSBvZmZzZXQgVGhlIG5ldyBvZmZzZXQgZm9yIHRoaXMgY2lyY2xlLlxyXG4gICAqL1xyXG4gIHNldCBvZmZzZXQob2Zmc2V0OiBWZWN0b3IpIHsgdGhpcy5fb2Zmc2V0ID0gb2Zmc2V0OyB9XHJcblxyXG4gIC8qKlxyXG4gICAqIENvbXB1dGUgdGhlIGF4aXMtYWxpZ25lZCBib3VuZGluZyBib3ggKEFBQkIpIG9mIHRoaXMgQ2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIE5vdGU6IFJldHVybnMgYSBuZXcgYFBvbHlnb25gIGVhY2ggdGltZSB0aGlzIGlzIGNhbGxlZC5cclxuICAgKiBcclxuICAgKiBAcmV0dXJucyB7UG9seWdvbn0gUmV0dXJucyB0aGUgQUFCQiBvZiB0aGlzIGNpcmNsZS5cclxuICAgKi9cclxuICBnZXRBQUJCKCk6IFBvbHlnb24ge1xyXG4gICAgY29uc3QgY29ybmVyID0gdGhpcy5fcG9zaXRpb24uY2xvbmUoKS5hZGQodGhpcy5fb2Zmc2V0KS5zdWIobmV3IFZlY3Rvcih0aGlzLl9yYWRpdXMsIHRoaXMuX3JhZGl1cykpO1xyXG5cclxuICAgIHJldHVybiBuZXcgQm94KGNvcm5lciwgdGhpcy5fcmFkaXVzICogMiwgdGhpcy5fcmFkaXVzICogMikudG9Qb2x5Z29uKCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBTZXQgdGhlIGN1cnJlbnQgb2Zmc2V0IHRvIGFwcGx5IHRvIHRoZSByYWRpdXMuXHJcbiAgICogXHJcbiAgICogQHBhcmFtIHtWZWN0b3J9IG9mZnNldCBUaGUgbmV3IG9mZnNldCBWZWN0b3IuXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge0NpcmNsZX0gUmV0dXJucyB0aGlzIGZvciBjaGFpbmluZy5cclxuICAgKi9cclxuICBzZXRPZmZzZXQob2Zmc2V0OiBWZWN0b3IpOiBDaXJjbGUge1xyXG4gICAgdGhpcy5fb2Zmc2V0ID0gb2Zmc2V0O1xyXG5cclxuICAgIHJldHVybiB0aGlzO1xyXG4gIH1cclxufSJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW9tZXRyeS9DaXJjbGUudHMiXSwibmFtZXMiOlsiQ2lyY2xlIiwicG9zaXRpb24iLCJWZWN0b3IiLCJyYWRpdXMiLCJfcG9zaXRpb24iLCJfcmFkaXVzIiwieCIsInkiLCJjb3JuZXIiLCJjbG9uZSIsImFkZCIsIl9vZmZzZXQiLCJzdWIiLCJCb3giLCJ0b1BvbHlnb24iLCJvZmZzZXQiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBRUE7O0FBQ0E7Ozs7Ozs7Ozs7OztBQUdBOzs7Ozs7O0lBT3FCQSxNOzs7QUFDbkI7Ozs7Ozs7O0FBU0E7Ozs7Ozs7O0FBU0E7Ozs7Ozs7O0FBU0E7Ozs7QUFJQSxvQkFBaUU7QUFBQSxRQUFyREMsUUFBcUQsdUVBQWxDLElBQUlDLGtCQUFKLEVBQWtDO0FBQUEsUUFBcEJDLE1BQW9CLHVFQUFILENBQUc7O0FBQUE7O0FBQUEsdUNBeEJyQyxJQUFJRCxrQkFBSixFQXdCcUM7O0FBQUEscUNBZnZDLENBZXVDOztBQUFBLHFDQU52QyxJQUFJQSxrQkFBSixFQU11Qzs7QUFDL0QsU0FBS0UsU0FBTCxHQUFpQkgsUUFBakI7QUFFQSxTQUFLSSxPQUFMLEdBQWVGLE1BQWY7QUFDRDtBQUVEOzs7Ozs7Ozs7O0FBNEJBOzs7Ozs4QkFLVUcsQyxFQUFXQyxDLEVBQVc7QUFDOUIsV0FBS0gsU0FBTCxDQUFlRSxDQUFmLElBQW9CQSxDQUFwQjtBQUNBLFdBQUtGLFNBQUwsQ0FBZUcsQ0FBZixJQUFvQkEsQ0FBcEI7QUFDRDtBQUVEOzs7Ozs7Ozs7OzhCQU9tQjtBQUNqQixVQUFNQyxNQUFNLEdBQUcsS0FBS0osU0FBTCxDQUFlSyxLQUFmLEdBQXVCQyxHQUF2QixDQUEyQixLQUFLQyxPQUFoQyxFQUF5Q0MsR0FBekMsQ0FBNkMsSUFBSVYsa0JBQUosQ0FBVyxLQUFLRyxPQUFoQixFQUF5QixLQUFLQSxPQUE5QixDQUE3QyxDQUFmOztBQUVBLGFBQU8sSUFBSVEsZUFBSixDQUFRTCxNQUFSLEVBQWdCLEtBQUtILE9BQUwsR0FBZSxDQUEvQixFQUFrQyxLQUFLQSxPQUFMLEdBQWUsQ0FBakQsRUFBb0RTLFNBQXBELEVBQVA7QUFDRDtBQUVEOzs7Ozs7Ozs7OzhCQU9VQyxNLEVBQXdCO0FBQ2hDLFdBQUtKLE9BQUwsR0FBZUksTUFBZjtBQUVBLGFBQU8sSUFBUDtBQUNEOzs7d0JBekRzQjtBQUFFLGFBQU8sS0FBS1gsU0FBWjtBQUF3QjtBQUVqRDs7Ozs7Ozs7d0JBS3FCO0FBQUUsYUFBTyxLQUFLQyxPQUFaO0FBQXNCO0FBRTdDOzs7Ozs7Ozt3QkFLcUI7QUFBRSxhQUFPLEtBQUtNLE9BQVo7QUFBc0I7QUFFN0M7Ozs7OztzQkFLV0ksTSxFQUFnQjtBQUFFLFdBQUtKLE9BQUwsR0FBZUksTUFBZjtBQUF3QiIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xyXG5cclxuaW1wb3J0IEJveCBmcm9tICcuL0JveCc7XHJcbmltcG9ydCBWZWN0b3IgZnJvbSAnLi9WZWN0b3InO1xyXG5pbXBvcnQgUG9seWdvbiBmcm9tICcuL1BvbHlnb24nO1xyXG5cclxuLyoqXHJcbiAqIFJlcHJlc2VudHMgYSBjaXJjbGUgd2l0aCBhIHBvc2l0aW9uIGFuZCBhIHJhZGl1cy5cclxuICogXHJcbiAqIENyZWF0ZXMgYSBuZXcgQ2lyY2xlLCBvcHRpb25hbGx5IHBhc3NpbmcgaW4gYSBwb3NpdGlvbiBhbmQvb3IgcmFkaXVzLiBJZiBubyBwb3NpdGlvbiBpcyBnaXZlbiwgdGhlIENpcmNsZSB3aWxsIGJlIGF0IGAoMCwwKWAuIFxyXG4gKiBcclxuICogSWYgbm8gcmFkaXVzIGlzIHByb3ZpZGVkIHRoZSBjaXJjbGUgd2lsbCBoYXZlIGEgcmFkaXVzIG9mIGAwYC5cclxuICovXHJcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENpcmNsZSB7XHJcbiAgLyoqXHJcbiAgICogQSBWZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBjZW50ZXIgcG9pbnQgb2YgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHByaXZhdGVcclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge1ZlY3Rvcn1cclxuICAgKi9cclxuICBwcml2YXRlIF9wb3NpdGlvbjogVmVjdG9yID0gbmV3IFZlY3RvcigpO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgcmFkaXVzIG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqIFxyXG4gICAqIEBwcml2YXRlXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtudW1iZXJ9XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBfcmFkaXVzOiBudW1iZXIgPSAwO1xyXG5cclxuICAvKipcclxuICAgKiBBIFZlY3RvciByZXByZXNlbnRpbmcgdGhlIG9mZnNldCBvZiB0aGlzIGNpcmNsZS5cclxuICAgKiBcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7VmVjdG9yfVxyXG4gICAqL1xyXG4gIHByaXZhdGUgX29mZnNldDogVmVjdG9yID0gbmV3IFZlY3RvcigpO1xyXG5cclxuICAvKipcclxuICAgKiBAcGFyYW0ge1ZlY3Rvcn0gcG9zaXRpb24gQSBWZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBjZW50ZXIgb2YgdGhpcyBDaXJjbGUuXHJcbiAgICogQHBhcmFtIHtudW1iZXJ9IHJhZGl1cyBUaGUgcmFkaXVzIG9mIHRoaXMgQ2lyY2xlLiBcclxuICAgKi9cclxuICBjb25zdHJ1Y3Rvcihwb3NpdGlvbjogVmVjdG9yID0gbmV3IFZlY3RvcigpLCByYWRpdXM6IG51bWJlciA9IDApIHtcclxuICAgIHRoaXMuX3Bvc2l0aW9uID0gcG9zaXRpb247XHJcblxyXG4gICAgdGhpcy5fcmFkaXVzID0gcmFkaXVzO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgcG9zaXRpb24gb2YgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge1ZlY3Rvcn1cclxuICAgKi9cclxuICBnZXQgcG9zaXRpb24oKTogVmVjdG9yIHsgcmV0dXJuIHRoaXMuX3Bvc2l0aW9uOyB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIHJhZGl1cyBvZiB0aGlzIGNpcmNsZS5cclxuICAgKiBcclxuICAgKiBAcmV0dXJucyB7bnVtYmVyfVxyXG4gICAqL1xyXG4gIGdldCByYWRpdXMoKTogbnVtYmVyIHsgcmV0dXJuIHRoaXMuX3JhZGl1czsgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSBvZmZzZXQgb2YgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge1ZlY3Rvcn1cclxuICAgKi9cclxuICBnZXQgb2Zmc2V0KCk6IFZlY3RvciB7IHJldHVybiB0aGlzLl9vZmZzZXQ7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2V0IGEgbmV3IG9mZnNldCBmb3IgdGhpcyBjaXJjbGUuXHJcbiAgICogXHJcbiAgICogQHBhcmFtIHtWZWN0b3J9IG9mZnNldCBUaGUgbmV3IG9mZnNldCBmb3IgdGhpcyBjaXJjbGUuXHJcbiAgICovXHJcbiAgc2V0IG9mZnNldChvZmZzZXQ6IFZlY3RvcikgeyB0aGlzLl9vZmZzZXQgPSBvZmZzZXQ7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogVHJhbnNsYXRlIHRoZSBjZW50ZXIgb2YgdGhlIGNpcmxjLmVcclxuICAgKiBcclxuICAgKiBAcGFyYW0ge1ZlY3Rvcn0gcG9zaXRpb24gQSBWZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBuZXcgY2VudGVyIG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqL1xyXG4gIHRyYW5zbGF0ZSh4OiBudW1iZXIsIHk6IG51bWJlcikge1xyXG4gICAgdGhpcy5fcG9zaXRpb24ueCArPSB4O1xyXG4gICAgdGhpcy5fcG9zaXRpb24ueSArPSB5O1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQ29tcHV0ZSB0aGUgYXhpcy1hbGlnbmVkIGJvdW5kaW5nIGJveCAoQUFCQikgb2YgdGhpcyBDaXJjbGUuXHJcbiAgICogXHJcbiAgICogTm90ZTogUmV0dXJucyBhIG5ldyBgUG9seWdvbmAgZWFjaCB0aW1lIHRoaXMgaXMgY2FsbGVkLlxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtQb2x5Z29ufSBSZXR1cm5zIHRoZSBBQUJCIG9mIHRoaXMgY2lyY2xlLlxyXG4gICAqL1xyXG4gIGdldEFBQkIoKTogUG9seWdvbiB7XHJcbiAgICBjb25zdCBjb3JuZXIgPSB0aGlzLl9wb3NpdGlvbi5jbG9uZSgpLmFkZCh0aGlzLl9vZmZzZXQpLnN1YihuZXcgVmVjdG9yKHRoaXMuX3JhZGl1cywgdGhpcy5fcmFkaXVzKSk7XHJcblxyXG4gICAgcmV0dXJuIG5ldyBCb3goY29ybmVyLCB0aGlzLl9yYWRpdXMgKiAyLCB0aGlzLl9yYWRpdXMgKiAyKS50b1BvbHlnb24oKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNldCB0aGUgY3VycmVudCBvZmZzZXQgdG8gYXBwbHkgdG8gdGhlIHJhZGl1cy5cclxuICAgKiBcclxuICAgKiBAcGFyYW0ge1ZlY3Rvcn0gb2Zmc2V0IFRoZSBuZXcgb2Zmc2V0IFZlY3Rvci5cclxuICAgKiBcclxuICAgKiBAcmV0dXJucyB7Q2lyY2xlfSBSZXR1cm5zIHRoaXMgZm9yIGNoYWluaW5nLlxyXG4gICAqL1xyXG4gIHNldE9mZnNldChvZmZzZXQ6IFZlY3Rvcik6IENpcmNsZSB7XHJcbiAgICB0aGlzLl9vZmZzZXQgPSBvZmZzZXQ7XHJcblxyXG4gICAgcmV0dXJuIHRoaXM7XHJcbiAgfVxyXG59Il19

@@ -82,2 +82,9 @@ import Vector from './Vector';

/**
* **Note:** Not sure if this will be kept or not but for now it's disabled.
*
* Sets a new position for this polygon and recalculates the points.
*
* @param {Vector} position A Vector representing the new position of this polygon.
*/
/**
* Returns the points of this polygon.

@@ -126,3 +133,3 @@ *

* @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.
*
* *
* @returns {Polygon} Returns this for chaining.

@@ -129,0 +136,0 @@ */

@@ -137,3 +137,3 @@ 'use strict';

* @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.
*
* *
* @returns {Polygon} Returns this for chaining.

@@ -377,2 +377,24 @@ */

/**
* **Note:** Not sure if this will be kept or not but for now it's disabled.
*
* Sets a new position for this polygon and recalculates the points.
*
* @param {Vector} position A Vector representing the new position of this polygon.
*/
// set position(position: Vector) {
// const diffX: number = -(this._position.x - position.x);
// const diffY: number = -(this._position.y - position.y);
// const diffPoint: Vector = new Vector(diffX, diffY);
// const points: Array<Vector> = [];
// this._points.map((point: Vector) => {
// const tempX: number = point.x;
// const tempY: number = point.y;
// const tempPoint: Vector = new Vector(tempX, tempY);
// const calculatedPoint: Vector = tempPoint.add(diffPoint);
// points.push(calculatedPoint);
// });
// this.setPoints(points, true);
// }
/**
* Returns the points of this polygon.

@@ -449,2 +471,2 @@ *

exports["default"] = Polygon;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/geometry/Polygon.ts"],"names":["Polygon","position","Vector","points","_position","setPoints","lengthChanged","length","i","calcPoints","_calcPoints","edges","_edges","normals","_normals","p1","p2","x","y","splice","push","_points","_recalc","angle","_angle","offset","_offset","len","rotate","calcPoint","copy","e","sub","perp","normalize","xMin","yMin","xMax","yMax","point","Box","clone","add","toPolygon","cx","cy","ar","a"],"mappings":"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","sourcesContent":["'use strict'\r\n\r\nimport Box from './Box';\r\nimport Vector from './Vector';\r\n\r\n/**\r\n * Represents a *convex* polygon with any number of points (specified in counter-clockwise order).\r\n * \r\n * Note: Do _not_ manually change the `points`, `angle`, or `offset` properties. Use the provided  setters. \r\n * Otherwise the calculated properties will not be updated correctly.\r\n * \r\n * The `pos` property can be changed directly.\r\n */\r\nexport default class Polygon {\r\n  /**\r\n   * A vector representing the origin of this polygon (all other points are relative to this one).\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Vector}\r\n   */\r\n  private _position: Vector = new Vector();\r\n\r\n  /**\r\n   * An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _points: Array<Vector> = [];\r\n\r\n  /**\r\n   * The angle of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _angle: number = 0;\r\n\r\n  /**\r\n   * The offset of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Vector}\r\n   */\r\n  private _offset: Vector = new Vector();\r\n\r\n  /**\r\n   * The calculated points of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _calcPoints: Array<Vector> = [];\r\n\r\n  /**\r\n   * The edges of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _edges: Array<Vector> = [];\r\n\r\n  /**\r\n   * The normals of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _normals: Array<Vector> = [];\r\n\r\n  /**\r\n   * Create a new polygon, passing in a position vector, and an array of points (represented by vectors \r\n   * relative to the position vector). If no position is passed in, the position of the polygon will be `(0,0)`.\r\n   * \r\n   * @param {Vector} [position=Vector] A vector representing the origin of the polygon (all other points are relative to this one)\r\n   * @param {Array<Vector>} [points=[]] An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   */\r\n  constructor(position: Vector = new Vector(), points: Array<Vector> = []) {\r\n    this._position = position;\r\n\r\n    this.setPoints(points);\r\n  }\r\n\r\n  /**\r\n   * Returns the position of this polygon.\r\n   * \r\n   * @returns {Vector}\r\n   */\r\n  get position(): Vector { return this._position; }\r\n\r\n  /**\r\n   * Returns the points of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get points(): Array<Vector> { return this._points; }\r\n\r\n  /**\r\n   * Returns the calculated points of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get calcPoints(): Array<Vector> { return this._calcPoints; }\r\n\r\n  /**\r\n   * Returns the offset of this polygon.\r\n   * \r\n   * @returns {Vector}\r\n   */\r\n  get offset(): Vector { return this._offset; }\r\n\r\n  /**\r\n   * Returns the angle of this polygon.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get angle(): number { return this._angle; }\r\n\r\n  /**\r\n   * Returns the edges of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get edges(): Array<Vector> { return this._edges; }\r\n\r\n  /**\r\n   * Returns the normals of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get normals(): Array<Vector> { return this._normals; }\r\n\r\n  /**\r\n   * Set the points of the polygon. Any consecutive duplicate points will be combined.\r\n   * \r\n   * Note: The points are counter-clockwise *with respect to the coordinate system*. If you directly draw the points on a screen \r\n   * that has the origin at the top-left corner it will _appear_ visually that the points are being specified clockwise. This is \r\n   * just because of the inversion of the Y-axis when being displayed.\r\n   * \r\n   * @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setPoints(points: Array<Vector>): Polygon {\r\n    // Only re-allocate if this is a new polygon or the number of points has changed.\r\n    const lengthChanged: boolean = !this.points || this.points.length !== points.length;\r\n\r\n    if (lengthChanged) {\r\n      let i: number;\r\n\r\n      const calcPoints: Array<Vector> = this._calcPoints = [];\r\n      const edges: Array<Vector> = this._edges = [];\r\n      const normals: Array<Vector> = this._normals = [];\r\n\r\n      // Allocate the vector arrays for the calculated properties\r\n      for (i = 0; i < points.length; i++) {\r\n        // Remove consecutive duplicate points\r\n        const p1: Vector = points[i];\r\n        const p2: Vector = i < points.length - 1 ? points[i + 1] : points[0];\r\n\r\n        if (p1 !== p2 && p1.x === p2.x && p1.y === p2.y) {\r\n          points.splice(i, 1);\r\n          i -= 1;\r\n          continue;\r\n        }\r\n\r\n        calcPoints.push(new Vector());\r\n        edges.push(new Vector());\r\n        normals.push(new Vector());\r\n      }\r\n    }\r\n\r\n    this._points = points;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Set the current rotation angle of the polygon.\r\n   * \r\n   * @param {number} angle The current rotation angle (in radians).\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setAngle(angle: number): Polygon {\r\n    this._angle = angle;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Set the current offset to apply to the `points` before applying the `angle` rotation.\r\n   * \r\n   * @param {Vector} offset The new offset Vector.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setOffset(offset: Vector): Polygon {\r\n    this._offset = offset;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Rotates this Polygon counter-clockwise around the origin of *its local coordinate system* (i.e. `position`).\r\n   * \r\n   * Note: This changes the **original** points (so any `angle` will be applied on top of this rotation).\r\n   * \r\n   * @param {number} angle The angle to rotate (in radians).\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  rotate(angle: number): Polygon {\r\n    const points: Array<Vector> = this.points;\r\n    const len: number = points.length;\r\n\r\n    for (let i = 0; i < len; i++) points[i].rotate(angle);\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Translates the points of this polygon by a specified amount relative to the origin of *its own coordinate system* (i.e. `position`).\r\n   * \r\n   * Note: This changes the **original** points (so any `offset` will be applied on top of this translation)\r\n   * \r\n   * @param {number} x The horizontal amount to translate.\r\n   * @param {number} y The vertical amount to translate.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  translate(x: number, y: number): Polygon {\r\n    const points: Array<Vector> = this.points;\r\n    const len: number = points.length;\r\n\r\n    for (let i: number = 0; i < len; i++) {\r\n      points[i].x += x;\r\n      points[i].y += y;\r\n    }\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Computes the calculated collision Polygon.\r\n   * \r\n   * This applies the `angle` and `offset` to the original points then recalculates the edges and normals of the collision Polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  private _recalc(): Polygon {\r\n    // Calculated points - this is what is used for underlying collisions and takes into account\r\n    // the angle/offset set on the polygon.\r\n    const calcPoints: Array<Vector> = this.calcPoints;\r\n\r\n    // The edges here are the direction of the `n`th edge of the polygon, relative to\r\n    // the `n`th point. If you want to draw a given edge from the edge value, you must\r\n    // first translate to the position of the starting point.\r\n    const edges: Array<Vector> = this._edges;\r\n\r\n    // The normals here are the direction of the normal for the `n`th edge of the polygon, relative\r\n    // to the position of the `n`th point. If you want to draw an edge normal, you must first\r\n    // translate to the position of the starting point.\r\n    const normals: Array<Vector> = this._normals;\r\n\r\n    // Copy the original points array and apply the offset/angle\r\n    const points: Array<Vector> = this.points;\r\n    const offset: Vector = this.offset;\r\n    const angle: number = this.angle;\r\n\r\n    const len: number = points.length;\r\n    let i: number;\r\n\r\n    for (i = 0; i < len; i++) {\r\n      const calcPoint: Vector = calcPoints[i].copy(points[i]);\r\n\r\n      calcPoint.x += offset.x;\r\n      calcPoint.y += offset.y;\r\n\r\n      if (angle !== 0) calcPoint.rotate(angle);\r\n    }\r\n\r\n    // Calculate the edges/normals\r\n    for (i = 0; i < len; i++) {\r\n      const p1: Vector = calcPoints[i];\r\n      const p2: Vector = i < len - 1 ? calcPoints[i + 1] : calcPoints[0];\r\n\r\n      const e: Vector = edges[i].copy(p2).sub(p1);\r\n\r\n      normals[i].copy(e).perp().normalize();\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Compute the axis-aligned bounding box.\r\n   * \r\n   * Any current state (translations/rotations) will be applied before constructing the AABB.\r\n   * \r\n   * Note: Returns a _new_ `Polygon` each time you call this.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  getAABB(): Polygon {\r\n    const points: Array<Vector> = this.calcPoints;\r\n    const len: number = points.length;\r\n\r\n    let xMin: number = points[0].x;\r\n    let yMin: number = points[0].y;\r\n\r\n    let xMax: number = points[0].x;\r\n    let yMax: number = points[0].y;\r\n\r\n    for (let i: number = 1; i < len; i++) {\r\n      const point: Vector = points[i];\r\n\r\n      if (point[\"x\"] < xMin) xMin = point[\"x\"];\r\n      else if (point[\"x\"] > xMax) xMax = point[\"x\"];\r\n\r\n      if (point[\"y\"] < yMin) yMin = point[\"y\"];\r\n      else if (point[\"y\"] > yMax) yMax = point[\"y\"];\r\n\r\n    }\r\n\r\n    return new Box(this._position.clone().add(new Vector(xMin, yMin)), xMax - xMin, yMax - yMin).toPolygon();\r\n  }\r\n\r\n  /**\r\n   * Compute the centroid (geometric center) of the Polygon.\r\n   * \r\n   * Any current state (translations/rotations) will be applied before computing the centroid.\r\n   * \r\n   * See https://en.wikipedia.org/wiki/Centroid#Centroid_of_a_polygon\r\n   * \r\n   * Note: Returns a _new_ `Vector` each time you call this.\r\n   * \r\n   * @returns {Vector} Returns a Vector that contains the coordinates of the centroid.\r\n   */\r\n  getCentroid(): Vector {\r\n    const points: Array<Vector> = this.calcPoints;\r\n    const len: number = points.length;\r\n\r\n    let cx: number = 0;\r\n    let cy: number = 0;\r\n    let ar: number = 0;\r\n\r\n    for (var i: number = 0; i < len; i++) {\r\n      const p1: Vector = points[i];\r\n      const p2: Vector = i === len - 1 ? points[0] : points[i + 1]; // Loop around if last point\r\n\r\n      const a: number = p1[\"x\"] * p2[\"y\"] - p2[\"x\"] * p1[\"y\"];\r\n\r\n      cx += (p1[\"x\"] + p2[\"x\"]) * a;\r\n      cy += (p1[\"y\"] + p2[\"y\"]) * a;\r\n      ar += a;\r\n    }\r\n\r\n    ar = ar * 3; // we want 1 / 6 the area and we currently have 2*area\r\n    cx = cx / ar;\r\n    cy = cy / ar;\r\n\r\n    return new Vector(cx, cy);\r\n  }\r\n}"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/geometry/Polygon.ts"],"names":["Polygon","position","Vector","points","_position","setPoints","lengthChanged","length","i","calcPoints","_calcPoints","edges","_edges","normals","_normals","p1","p2","x","y","splice","push","_points","_recalc","angle","_angle","offset","_offset","len","rotate","calcPoint","copy","e","sub","perp","normalize","xMin","yMin","xMax","yMax","point","Box","clone","add","toPolygon","cx","cy","ar","a"],"mappings":"AAAA;;;;;;;AAEA;;AACA;;;;;;;;;;;;AAEA;;;;;;;;IAQqBA,O;;;AACnB;;;;;;;;AASA;;;;;;;;AASA;;;;;;;;AASA;;;;;;;;AASA;;;;;;;;AASA;;;;;;;;AASA;;;;;;;;AASA;;;;;;;AAOA,qBAAyE;AAAA,QAA7DC,QAA6D,uEAA1C,IAAIC,kBAAJ,EAA0C;AAAA,QAA5BC,MAA4B,uEAAJ,EAAI;;AAAA;;AAAA,uCA/D7C,IAAID,kBAAJ,EA+D6C;;AAAA,qCAtDxC,EAsDwC;;AAAA,oCA7ChD,CA6CgD;;AAAA,qCApC/C,IAAIA,kBAAJ,EAoC+C;;AAAA,yCA3BpC,EA2BoC;;AAAA,oCAlBzC,EAkByC;;AAAA,sCATvC,EASuC;;AACvE,SAAKE,SAAL,GAAiBH,QAAjB;AAEA,SAAKI,SAAL,CAAeF,MAAf;AACD;AAED;;;;;;;;;;AA8EA;;;;;;;;;;;8BAWUA,M,EAAgC;AACxC;AACA,UAAMG,aAAsB,GAAG,CAAC,KAAKH,MAAN,IAAgB,KAAKA,MAAL,CAAYI,MAAZ,KAAuBJ,MAAM,CAACI,MAA7E;;AAEA,UAAID,aAAJ,EAAmB;AACjB,YAAIE,CAAJ;AAEA,YAAMC,UAAyB,GAAG,KAAKC,WAAL,GAAmB,EAArD;AACA,YAAMC,KAAoB,GAAG,KAAKC,MAAL,GAAc,EAA3C;AACA,YAAMC,OAAsB,GAAG,KAAKC,QAAL,GAAgB,EAA/C,CALiB,CAOjB;;AACA,aAAKN,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGL,MAAM,CAACI,MAAvB,EAA+BC,CAAC,EAAhC,EAAoC;AAClC;AACA,cAAMO,EAAU,GAAGZ,MAAM,CAACK,CAAD,CAAzB;AACA,cAAMQ,EAAU,GAAGR,CAAC,GAAGL,MAAM,CAACI,MAAP,GAAgB,CAApB,GAAwBJ,MAAM,CAACK,CAAC,GAAG,CAAL,CAA9B,GAAwCL,MAAM,CAAC,CAAD,CAAjE;;AAEA,cAAIY,EAAE,KAAKC,EAAP,IAAaD,EAAE,CAACE,CAAH,KAASD,EAAE,CAACC,CAAzB,IAA8BF,EAAE,CAACG,CAAH,KAASF,EAAE,CAACE,CAA9C,EAAiD;AAC/Cf,YAAAA,MAAM,CAACgB,MAAP,CAAcX,CAAd,EAAiB,CAAjB;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;AACD;;AAEDC,UAAAA,UAAU,CAACW,IAAX,CAAgB,IAAIlB,kBAAJ,EAAhB;AACAS,UAAAA,KAAK,CAACS,IAAN,CAAW,IAAIlB,kBAAJ,EAAX;AACAW,UAAAA,OAAO,CAACO,IAAR,CAAa,IAAIlB,kBAAJ,EAAb;AACD;AACF;;AAED,WAAKmB,OAAL,GAAelB,MAAf;;AAEA,WAAKmB,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;;;;;;;;;;6BAOSC,K,EAAwB;AAC/B,WAAKC,MAAL,GAAcD,KAAd;;AAEA,WAAKD,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;;;;;;;;;;8BAOUG,M,EAAyB;AACjC,WAAKC,OAAL,GAAeD,MAAf;;AAEA,WAAKH,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;;;;;;;;;;;;2BASOC,K,EAAwB;AAC7B,UAAMpB,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMwB,GAAW,GAAGxB,MAAM,CAACI,MAA3B;;AAEA,WAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGmB,GAApB,EAAyBnB,CAAC,EAA1B;AAA8BL,QAAAA,MAAM,CAACK,CAAD,CAAN,CAAUoB,MAAV,CAAiBL,KAAjB;AAA9B;;AAEA,WAAKD,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;;;;;;;;;;;;;8BAUUL,C,EAAWC,C,EAAoB;AACvC,UAAMf,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMwB,GAAW,GAAGxB,MAAM,CAACI,MAA3B;;AAEA,WAAK,IAAIC,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGmB,GAA5B,EAAiCnB,CAAC,EAAlC,EAAsC;AACpCL,QAAAA,MAAM,CAACK,CAAD,CAAN,CAAUS,CAAV,IAAeA,CAAf;AACAd,QAAAA,MAAM,CAACK,CAAD,CAAN,CAAUU,CAAV,IAAeA,CAAf;AACD;;AAED,WAAKI,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;;;;;;;;;;;;8BAS2B;AACzB;AACA;AACA,UAAMb,UAAyB,GAAG,KAAKA,UAAvC,CAHyB,CAKzB;AACA;AACA;;AACA,UAAME,KAAoB,GAAG,KAAKC,MAAlC,CARyB,CAUzB;AACA;AACA;;AACA,UAAMC,OAAsB,GAAG,KAAKC,QAApC,CAbyB,CAezB;;AACA,UAAMX,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMsB,MAAc,GAAG,KAAKA,MAA5B;AACA,UAAMF,KAAa,GAAG,KAAKA,KAA3B;AAEA,UAAMI,GAAW,GAAGxB,MAAM,CAACI,MAA3B;AACA,UAAIC,CAAJ;;AAEA,WAAKA,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGmB,GAAhB,EAAqBnB,CAAC,EAAtB,EAA0B;AACxB,YAAMqB,SAAiB,GAAGpB,UAAU,CAACD,CAAD,CAAV,CAAcsB,IAAd,CAAmB3B,MAAM,CAACK,CAAD,CAAzB,CAA1B;AAEAqB,QAAAA,SAAS,CAACZ,CAAV,IAAeQ,MAAM,CAACR,CAAtB;AACAY,QAAAA,SAAS,CAACX,CAAV,IAAeO,MAAM,CAACP,CAAtB;AAEA,YAAIK,KAAK,KAAK,CAAd,EAAiBM,SAAS,CAACD,MAAV,CAAiBL,KAAjB;AAClB,OA9BwB,CAgCzB;;;AACA,WAAKf,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGmB,GAAhB,EAAqBnB,CAAC,EAAtB,EAA0B;AACxB,YAAMO,EAAU,GAAGN,UAAU,CAACD,CAAD,CAA7B;AACA,YAAMQ,EAAU,GAAGR,CAAC,GAAGmB,GAAG,GAAG,CAAV,GAAclB,UAAU,CAACD,CAAC,GAAG,CAAL,CAAxB,GAAkCC,UAAU,CAAC,CAAD,CAA/D;AAEA,YAAMsB,CAAS,GAAGpB,KAAK,CAACH,CAAD,CAAL,CAASsB,IAAT,CAAcd,EAAd,EAAkBgB,GAAlB,CAAsBjB,EAAtB,CAAlB;AAEAF,QAAAA,OAAO,CAACL,CAAD,CAAP,CAAWsB,IAAX,CAAgBC,CAAhB,EAAmBE,IAAnB,GAA0BC,SAA1B;AACD;;AAED,aAAO,IAAP;AACD;AAED;;;;;;;;;;;;8BASmB;AACjB,UAAM/B,MAAqB,GAAG,KAAKM,UAAnC;AACA,UAAMkB,GAAW,GAAGxB,MAAM,CAACI,MAA3B;AAEA,UAAI4B,IAAY,GAAGhC,MAAM,CAAC,CAAD,CAAN,CAAUc,CAA7B;AACA,UAAImB,IAAY,GAAGjC,MAAM,CAAC,CAAD,CAAN,CAAUe,CAA7B;AAEA,UAAImB,IAAY,GAAGlC,MAAM,CAAC,CAAD,CAAN,CAAUc,CAA7B;AACA,UAAIqB,IAAY,GAAGnC,MAAM,CAAC,CAAD,CAAN,CAAUe,CAA7B;;AAEA,WAAK,IAAIV,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGmB,GAA5B,EAAiCnB,CAAC,EAAlC,EAAsC;AACpC,YAAM+B,KAAa,GAAGpC,MAAM,CAACK,CAAD,CAA5B;AAEA,YAAI+B,KAAK,CAAC,GAAD,CAAL,GAAaJ,IAAjB,EAAuBA,IAAI,GAAGI,KAAK,CAAC,GAAD,CAAZ,CAAvB,KACK,IAAIA,KAAK,CAAC,GAAD,CAAL,GAAaF,IAAjB,EAAuBA,IAAI,GAAGE,KAAK,CAAC,GAAD,CAAZ;AAE5B,YAAIA,KAAK,CAAC,GAAD,CAAL,GAAaH,IAAjB,EAAuBA,IAAI,GAAGG,KAAK,CAAC,GAAD,CAAZ,CAAvB,KACK,IAAIA,KAAK,CAAC,GAAD,CAAL,GAAaD,IAAjB,EAAuBA,IAAI,GAAGC,KAAK,CAAC,GAAD,CAAZ;AAE7B;;AAED,aAAO,IAAIC,eAAJ,CAAQ,KAAKpC,SAAL,CAAeqC,KAAf,GAAuBC,GAAvB,CAA2B,IAAIxC,kBAAJ,CAAWiC,IAAX,EAAiBC,IAAjB,CAA3B,CAAR,EAA4DC,IAAI,GAAGF,IAAnE,EAAyEG,IAAI,GAAGF,IAAhF,EAAsFO,SAAtF,EAAP;AACD;AAED;;;;;;;;;;;;;;kCAWsB;AACpB,UAAMxC,MAAqB,GAAG,KAAKM,UAAnC;AACA,UAAMkB,GAAW,GAAGxB,MAAM,CAACI,MAA3B;AAEA,UAAIqC,EAAU,GAAG,CAAjB;AACA,UAAIC,EAAU,GAAG,CAAjB;AACA,UAAIC,EAAU,GAAG,CAAjB;;AAEA,WAAK,IAAItC,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGmB,GAA5B,EAAiCnB,CAAC,EAAlC,EAAsC;AACpC,YAAMO,EAAU,GAAGZ,MAAM,CAACK,CAAD,CAAzB;AACA,YAAMQ,EAAU,GAAGR,CAAC,KAAKmB,GAAG,GAAG,CAAZ,GAAgBxB,MAAM,CAAC,CAAD,CAAtB,GAA4BA,MAAM,CAACK,CAAC,GAAG,CAAL,CAArD,CAFoC,CAE0B;;AAE9D,YAAMuC,CAAS,GAAGhC,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAZ,GAAoBA,EAAE,CAAC,GAAD,CAAF,GAAUD,EAAE,CAAC,GAAD,CAAlD;AAEA6B,QAAAA,EAAE,IAAI,CAAC7B,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAb,IAAsB+B,CAA5B;AACAF,QAAAA,EAAE,IAAI,CAAC9B,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAb,IAAsB+B,CAA5B;AACAD,QAAAA,EAAE,IAAIC,CAAN;AACD;;AAEDD,MAAAA,EAAE,GAAGA,EAAE,GAAG,CAAV,CAnBoB,CAmBP;;AACbF,MAAAA,EAAE,GAAGA,EAAE,GAAGE,EAAV;AACAD,MAAAA,EAAE,GAAGA,EAAE,GAAGC,EAAV;AAEA,aAAO,IAAI5C,kBAAJ,CAAW0C,EAAX,EAAeC,EAAf,CAAP;AACD;;;wBA5TsB;AAAE,aAAO,KAAKzC,SAAZ;AAAwB;AAEjD;;;;;;;AAOA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;;AAEA;;;;;;;;wBAK4B;AAAE,aAAO,KAAKiB,OAAZ;AAAsB;AAEpD;;;;;;;;wBAKgC;AAAE,aAAO,KAAKX,WAAZ;AAA0B;AAE5D;;;;;;;;wBAKqB;AAAE,aAAO,KAAKgB,OAAZ;AAAsB;AAE7C;;;;;;;;wBAKoB;AAAE,aAAO,KAAKF,MAAZ;AAAqB;AAE3C;;;;;;;;wBAK2B;AAAE,aAAO,KAAKZ,MAAZ;AAAqB;AAElD;;;;;;;;wBAK6B;AAAE,aAAO,KAAKE,QAAZ;AAAuB","sourcesContent":["'use strict'\r\n\r\nimport Box from './Box';\r\nimport Vector from './Vector';\r\n\r\n/**\r\n * Represents a *convex* polygon with any number of points (specified in counter-clockwise order).\r\n * \r\n * Note: Do _not_ manually change the `points`, `angle`, or `offset` properties. Use the provided  setters. \r\n * Otherwise the calculated properties will not be updated correctly.\r\n * \r\n * The `pos` property can be changed directly.\r\n */\r\nexport default class Polygon {\r\n  /**\r\n   * A vector representing the origin of this polygon (all other points are relative to this one).\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Vector}\r\n   */\r\n  private _position: Vector = new Vector();\r\n\r\n  /**\r\n   * An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _points: Array<Vector> = [];\r\n\r\n  /**\r\n   * The angle of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _angle: number = 0;\r\n\r\n  /**\r\n   * The offset of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Vector}\r\n   */\r\n  private _offset: Vector = new Vector();\r\n\r\n  /**\r\n   * The calculated points of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _calcPoints: Array<Vector> = [];\r\n\r\n  /**\r\n   * The edges of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _edges: Array<Vector> = [];\r\n\r\n  /**\r\n   * The normals of this polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<Vector>}\r\n   */\r\n  private _normals: Array<Vector> = [];\r\n\r\n  /**\r\n   * Create a new polygon, passing in a position vector, and an array of points (represented by vectors \r\n   * relative to the position vector). If no position is passed in, the position of the polygon will be `(0,0)`.\r\n   * \r\n   * @param {Vector} [position=Vector] A vector representing the origin of the polygon (all other points are relative to this one)\r\n   * @param {Array<Vector>} [points=[]] An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   */\r\n  constructor(position: Vector = new Vector(), points: Array<Vector> = []) {\r\n    this._position = position;\r\n\r\n    this.setPoints(points);\r\n  }\r\n\r\n  /**\r\n   * Returns the position of this polygon.\r\n   * \r\n   * @returns {Vector}\r\n   */\r\n  get position(): Vector { return this._position; }\r\n\r\n  /**\r\n   * **Note:** Not sure if this will be kept or not but for now it's disabled.\r\n   * \r\n   * Sets a new position for this polygon and recalculates the points.\r\n   * \r\n   * @param {Vector} position A Vector representing the new position of this polygon.\r\n   */\r\n  // set position(position: Vector) {\r\n  //   const diffX: number = -(this._position.x - position.x);\r\n  //   const diffY: number = -(this._position.y - position.y);\r\n\r\n  //   const diffPoint: Vector = new Vector(diffX, diffY);\r\n\r\n  //   const points: Array<Vector> = [];\r\n\r\n  //   this._points.map((point: Vector) => {\r\n  //     const tempX: number = point.x;\r\n  //     const tempY: number = point.y;\r\n\r\n  //     const tempPoint: Vector = new Vector(tempX, tempY);\r\n\r\n  //     const calculatedPoint: Vector = tempPoint.add(diffPoint);\r\n\r\n  //     points.push(calculatedPoint);\r\n  //   });\r\n\r\n  //   this.setPoints(points, true);\r\n  // }\r\n\r\n  /**\r\n   * Returns the points of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get points(): Array<Vector> { return this._points; }\r\n\r\n  /**\r\n   * Returns the calculated points of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get calcPoints(): Array<Vector> { return this._calcPoints; }\r\n\r\n  /**\r\n   * Returns the offset of this polygon.\r\n   * \r\n   * @returns {Vector}\r\n   */\r\n  get offset(): Vector { return this._offset; }\r\n\r\n  /**\r\n   * Returns the angle of this polygon.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get angle(): number { return this._angle; }\r\n\r\n  /**\r\n   * Returns the edges of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get edges(): Array<Vector> { return this._edges; }\r\n\r\n  /**\r\n   * Returns the normals of this polygon.\r\n   * \r\n   * @returns {Array<Vector>}\r\n   */\r\n  get normals(): Array<Vector> { return this._normals; }\r\n\r\n  /**\r\n   * Set the points of the polygon. Any consecutive duplicate points will be combined.\r\n   * \r\n   * Note: The points are counter-clockwise *with respect to the coordinate system*. If you directly draw the points on a screen \r\n   * that has the origin at the top-left corner it will _appear_ visually that the points are being specified clockwise. This is \r\n   * just because of the inversion of the Y-axis when being displayed.\r\n   * \r\n   * @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.\r\n   *    * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setPoints(points: Array<Vector>): Polygon {\r\n    // Only re-allocate if this is a new polygon or the number of points has changed.\r\n    const lengthChanged: boolean = !this.points || this.points.length !== points.length;\r\n\r\n    if (lengthChanged) {\r\n      let i: number;\r\n\r\n      const calcPoints: Array<Vector> = this._calcPoints = [];\r\n      const edges: Array<Vector> = this._edges = [];\r\n      const normals: Array<Vector> = this._normals = [];\r\n\r\n      // Allocate the vector arrays for the calculated properties\r\n      for (i = 0; i < points.length; i++) {\r\n        // Remove consecutive duplicate points\r\n        const p1: Vector = points[i];\r\n        const p2: Vector = i < points.length - 1 ? points[i + 1] : points[0];\r\n\r\n        if (p1 !== p2 && p1.x === p2.x && p1.y === p2.y) {\r\n          points.splice(i, 1);\r\n          i -= 1;\r\n          continue;\r\n        }\r\n\r\n        calcPoints.push(new Vector());\r\n        edges.push(new Vector());\r\n        normals.push(new Vector());\r\n      }\r\n    }\r\n\r\n    this._points = points;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Set the current rotation angle of the polygon.\r\n   * \r\n   * @param {number} angle The current rotation angle (in radians).\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setAngle(angle: number): Polygon {\r\n    this._angle = angle;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Set the current offset to apply to the `points` before applying the `angle` rotation.\r\n   * \r\n   * @param {Vector} offset The new offset Vector.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  setOffset(offset: Vector): Polygon {\r\n    this._offset = offset;\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Rotates this Polygon counter-clockwise around the origin of *its local coordinate system* (i.e. `position`).\r\n   * \r\n   * Note: This changes the **original** points (so any `angle` will be applied on top of this rotation).\r\n   * \r\n   * @param {number} angle The angle to rotate (in radians).\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  rotate(angle: number): Polygon {\r\n    const points: Array<Vector> = this.points;\r\n    const len: number = points.length;\r\n\r\n    for (let i = 0; i < len; i++) points[i].rotate(angle);\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Translates the points of this polygon by a specified amount relative to the origin of *its own coordinate system* (i.e. `position`).\r\n   * \r\n   * Note: This changes the **original** points (so any `offset` will be applied on top of this translation)\r\n   * \r\n   * @param {number} x The horizontal amount to translate.\r\n   * @param {number} y The vertical amount to translate.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  translate(x: number, y: number): Polygon {\r\n    const points: Array<Vector> = this.points;\r\n    const len: number = points.length;\r\n\r\n    for (let i: number = 0; i < len; i++) {\r\n      points[i].x += x;\r\n      points[i].y += y;\r\n    }\r\n\r\n    this._recalc();\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Computes the calculated collision Polygon.\r\n   * \r\n   * This applies the `angle` and `offset` to the original points then recalculates the edges and normals of the collision Polygon.\r\n   * \r\n   * @private\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  private _recalc(): Polygon {\r\n    // Calculated points - this is what is used for underlying collisions and takes into account\r\n    // the angle/offset set on the polygon.\r\n    const calcPoints: Array<Vector> = this.calcPoints;\r\n\r\n    // The edges here are the direction of the `n`th edge of the polygon, relative to\r\n    // the `n`th point. If you want to draw a given edge from the edge value, you must\r\n    // first translate to the position of the starting point.\r\n    const edges: Array<Vector> = this._edges;\r\n\r\n    // The normals here are the direction of the normal for the `n`th edge of the polygon, relative\r\n    // to the position of the `n`th point. If you want to draw an edge normal, you must first\r\n    // translate to the position of the starting point.\r\n    const normals: Array<Vector> = this._normals;\r\n\r\n    // Copy the original points array and apply the offset/angle\r\n    const points: Array<Vector> = this.points;\r\n    const offset: Vector = this.offset;\r\n    const angle: number = this.angle;\r\n\r\n    const len: number = points.length;\r\n    let i: number;\r\n\r\n    for (i = 0; i < len; i++) {\r\n      const calcPoint: Vector = calcPoints[i].copy(points[i]);\r\n\r\n      calcPoint.x += offset.x;\r\n      calcPoint.y += offset.y;\r\n\r\n      if (angle !== 0) calcPoint.rotate(angle);\r\n    }\r\n\r\n    // Calculate the edges/normals\r\n    for (i = 0; i < len; i++) {\r\n      const p1: Vector = calcPoints[i];\r\n      const p2: Vector = i < len - 1 ? calcPoints[i + 1] : calcPoints[0];\r\n\r\n      const e: Vector = edges[i].copy(p2).sub(p1);\r\n\r\n      normals[i].copy(e).perp().normalize();\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Compute the axis-aligned bounding box.\r\n   * \r\n   * Any current state (translations/rotations) will be applied before constructing the AABB.\r\n   * \r\n   * Note: Returns a _new_ `Polygon` each time you call this.\r\n   * \r\n   * @returns {Polygon} Returns this for chaining.\r\n   */\r\n  getAABB(): Polygon {\r\n    const points: Array<Vector> = this.calcPoints;\r\n    const len: number = points.length;\r\n\r\n    let xMin: number = points[0].x;\r\n    let yMin: number = points[0].y;\r\n\r\n    let xMax: number = points[0].x;\r\n    let yMax: number = points[0].y;\r\n\r\n    for (let i: number = 1; i < len; i++) {\r\n      const point: Vector = points[i];\r\n\r\n      if (point[\"x\"] < xMin) xMin = point[\"x\"];\r\n      else if (point[\"x\"] > xMax) xMax = point[\"x\"];\r\n\r\n      if (point[\"y\"] < yMin) yMin = point[\"y\"];\r\n      else if (point[\"y\"] > yMax) yMax = point[\"y\"];\r\n\r\n    }\r\n\r\n    return new Box(this._position.clone().add(new Vector(xMin, yMin)), xMax - xMin, yMax - yMin).toPolygon();\r\n  }\r\n\r\n  /**\r\n   * Compute the centroid (geometric center) of the Polygon.\r\n   * \r\n   * Any current state (translations/rotations) will be applied before computing the centroid.\r\n   * \r\n   * See https://en.wikipedia.org/wiki/Centroid#Centroid_of_a_polygon\r\n   * \r\n   * Note: Returns a _new_ `Vector` each time you call this.\r\n   * \r\n   * @returns {Vector} Returns a Vector that contains the coordinates of the centroid.\r\n   */\r\n  getCentroid(): Vector {\r\n    const points: Array<Vector> = this.calcPoints;\r\n    const len: number = points.length;\r\n\r\n    let cx: number = 0;\r\n    let cy: number = 0;\r\n    let ar: number = 0;\r\n\r\n    for (var i: number = 0; i < len; i++) {\r\n      const p1: Vector = points[i];\r\n      const p2: Vector = i === len - 1 ? points[0] : points[i + 1]; // Loop around if last point\r\n\r\n      const a: number = p1[\"x\"] * p2[\"y\"] - p2[\"x\"] * p1[\"y\"];\r\n\r\n      cx += (p1[\"x\"] + p2[\"x\"]) * a;\r\n      cy += (p1[\"y\"] + p2[\"y\"]) * a;\r\n      ar += a;\r\n    }\r\n\r\n    ar = ar * 3; // we want 1 / 6 the area and we currently have 2*area\r\n    cx = cx / ar;\r\n    cy = cy / ar;\r\n\r\n    return new Vector(cx, cy);\r\n  }\r\n}"]}

2

package.json
{
"name": "collider2d",
"version": "0.1.1",
"version": "0.2.0",
"description": "A 2D collision checker for modern games.",

@@ -5,0 +5,0 @@ "main": "index.js",

@@ -81,2 +81,12 @@ 'use strict'

/**
* Translate the center of the cirlc.e
*
* @param {Vector} position A Vector representing the new center of this circle.
*/
translate(x: number, y: number) {
this._position.x += x;
this._position.y += y;
}
/**
* Compute the axis-aligned bounding box (AABB) of this Circle.

@@ -83,0 +93,0 @@ *

@@ -99,2 +99,31 @@ 'use strict'

/**
* **Note:** Not sure if this will be kept or not but for now it's disabled.
*
* Sets a new position for this polygon and recalculates the points.
*
* @param {Vector} position A Vector representing the new position of this polygon.
*/
// set position(position: Vector) {
// const diffX: number = -(this._position.x - position.x);
// const diffY: number = -(this._position.y - position.y);
// const diffPoint: Vector = new Vector(diffX, diffY);
// const points: Array<Vector> = [];
// this._points.map((point: Vector) => {
// const tempX: number = point.x;
// const tempY: number = point.y;
// const tempPoint: Vector = new Vector(tempX, tempY);
// const calculatedPoint: Vector = tempPoint.add(diffPoint);
// points.push(calculatedPoint);
// });
// this.setPoints(points, true);
// }
/**
* Returns the points of this polygon.

@@ -149,3 +178,3 @@ *

* @param {Array<Vector>} points An array of vectors representing the points in the polygon, in counter-clockwise order.
*
* *
* @returns {Polygon} Returns this for chaining.

@@ -152,0 +181,0 @@ */

@@ -194,3 +194,3 @@ 'use strict'

circle.offset = c2d.vector(-10, -10);
const collisionAfterOffsetChange = c2d.pointInCircle(c2d.vector(110, 110), circle);

@@ -233,1 +233,209 @@ chai.expect(collisionAfterOffsetChange).to.be.false;

});
describe('Collision - After moving from initial position', () => {
it("testCircleCircle - should not detect a collision after a circle is moved from collision range", () => {
const circle1 = c2d.circle(c2d.vector(0, 0), 20);
const circle2 = c2d.circle(c2d.vector(10, 0), 20);
// Test collision = true - without details.
const collided = c2d.testCircleCircle(circle1, circle2);
chai.expect(collided).to.be.true;
circle2.translate(40, 50);
// Test collision = false - moved from collision range.
const collidedAfterMove = c2d.testCircleCircle(circle1, circle2);
chai.expect(collidedAfterMove).to.be.false;
});
it("testCircleCircle - should detect a collision after a circle is moved to collision range", () => {
const circle1 = c2d.circle(c2d.vector(0, 0), 20);
const circle2 = c2d.circle(c2d.vector(10, 100), 20);
// Test collision = false.
const collided = c2d.testCircleCircle(circle1, circle2);
chai.expect(collided).to.be.false;
circle2.translate(-5, -90);
// Test collision = true - moved to collision range.
const collidedAfterMove = c2d.testCircleCircle(circle1, circle2);
chai.expect(collidedAfterMove).to.be.true;
});
it("testPolygonCircle - should not detect a collision after the polygon is moved - (x, y) greater", () => {
const circle = c2d.circle(c2d.vector(50, 50), 20);
const polygon = c2d.polygon(c2d.vector(10, 10), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = true - no details
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.true;
polygon.translate(200, 300);
// Test collision = false - after moving polygon to (200, 300);
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.false;
});
it("testPolygonCircle - should not detect a collision after the polygon is moved - (x, y) less", () => {
const circle = c2d.circle(c2d.vector(50, 50), 20);
const polygon = c2d.polygon(c2d.vector(10, 10), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = true - no details
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.true;
polygon.translate(-200, -150);
// Test collision = false - after moving polygon to (-200, -150);
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.false;
});
it("testPolygonCircle - should detect a collision after the polygon is moved - (x, y) greater", () => {
const circle = c2d.circle(c2d.vector(50, 50), 20);
const polygon = c2d.polygon(c2d.vector(-150, -125), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = false
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.false;
polygon.translate(180, 150);
// Test collision = true - after moving polygon to (30, 25);
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.true;
});
it("testPolygonCircle - should detect a collision after the polygon is moved - (x, y) less", () => {
const circle = c2d.circle(c2d.vector(50, 50), 20);
const polygon = c2d.polygon(c2d.vector(200, 300), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = false
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.false;
polygon.translate(-170, -275);
// Test collision = true - after moving polygon to (30, 25);
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.true;
});
it("testPolygonCircle - should not detect a collision after the circle is moved", () => {
const circle = c2d.circle(c2d.vector(50, 50), 20);
const polygon = c2d.polygon(c2d.vector(25, 25), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = false
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.true;
circle.translate(200, 300);
// Test collision = true - after moving polygon to (30, 25);
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.false;
});
it("testPolygonCircle - should detect a collision after the circle is moved", () => {
const circle = c2d.circle(c2d.vector(200, 150), 20);
const polygon = c2d.polygon(c2d.vector(0, 0), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
// Test collision = false
const collided = c2d.testPolygonCircle(polygon, circle);
chai.expect(collided).to.be.false;
circle.translate(-150, -100);
// Test collision = true - after moving circle to (50, 50).
const collidedAfterMoving = c2d.testPolygonCircle(polygon, circle);
chai.expect(collidedAfterMoving).to.be.true;
});
it("testPolygonPolygon - should not detect a collision after the polygon is moved - (x, y) greater", () => {
const polygon1 = c2d.polygon(c2d.vector(0, 0), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
const polygon2 = c2d.polygon(c2d.vector(30, 0), [
c2d.vector(0, 0),
c2d.vector(30, 0),
c2d.vector(0, 30)
]);
// Test collision = true.
const collided = c2d.testPolygonPolygon(polygon1, polygon2);
chai.expect(collided).to.be.true;
// Test collision = false - after moving polygon.
polygon2.translate(90, 150);
const collidedAfterMoving = c2d.testPolygonPolygon(polygon1, polygon2);
chai.expect(collidedAfterMoving).to.be.false;
});
it("testPolygonPolygon - should not detect a collision after the polygon is moved - (x, y) less", () => {
const polygon1 = c2d.polygon(c2d.vector(0, 0), [
c2d.vector(0, 0),
c2d.vector(40, 0),
c2d.vector(40, 40),
c2d.vector(0, 40)
]);
const polygon2 = c2d.polygon(c2d.vector(140, 150), [
c2d.vector(0, 0),
c2d.vector(30, 0),
c2d.vector(0, 30)
]);
// Test collision = false
const collided = c2d.testPolygonPolygon(polygon1, polygon2);
chai.expect(collided).to.be.false;
// Test collision = true - after moving polygon.
polygon2.translate(-110, -150);
const collidedAfterMoving = c2d.testPolygonPolygon(polygon1, polygon2);
chai.expect(collidedAfterMoving).to.be.true;
});
});
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc