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 1.0.0 to 1.1.0

14

build/geometry/polygon.d.ts

@@ -28,2 +28,10 @@ import Vector from './vector';

/**
* An Array of the points of this polygon as numbers instead of Vectors.
*
* @private
*
* @property {Array<number>}
*/
private _pointsGeneric;
/**
* The angle of this polygon.

@@ -96,2 +104,8 @@ *

/**
* Returns the points of this polygon as numbers instead of Vectors.
*
* @returns {Array<number>}
*/
get pointsGeneric(): Array<number>;
/**
* Returns the calculated points of this polygon.

@@ -98,0 +112,0 @@ *

27

build/geometry/polygon.js

@@ -46,2 +46,10 @@ 'use strict';

/**
* An Array of the points of this polygon as numbers instead of Vectors.
*
* @private
*
* @property {Array<number>}
*/
/**
* The angle of this polygon.

@@ -103,2 +111,4 @@ *

_defineProperty(this, "_pointsGeneric", []);
_defineProperty(this, "_angle", 0);

@@ -151,4 +161,6 @@

var p1 = points[i];
var p2 = i < points.length - 1 ? points[i + 1] : points[0];
var p2 = i < points.length - 1 ? points[i + 1] : points[0]; // Push the points to the generic points Array.
this._pointsGeneric.push(points[i].x, points[i].y);
if (p1 !== p2 && p1.x === p2.x && p1.y === p2.y) {

@@ -408,2 +420,13 @@ points.splice(i, 1);

/**
* Returns the points of this polygon as numbers instead of Vectors.
*
* @returns {Array<number>}
*/
}, {
key: "pointsGeneric",
get: function get() {
return this._pointsGeneric;
}
/**
* Returns the calculated points of this polygon.

@@ -469,2 +492,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","clone","add","cx","cy","ar","a"],"mappings":"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","sourcesContent":["'use strict'\r\n\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    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 Polygon(this._position.clone().add(new Vector(xMin, yMin)), [\r\n      new Vector(), new Vector(xMax - xMin, 0),\r\n      new Vector(xMax - xMin, yMax - yMin), new Vector(0, yMax - yMin)\r\n    ]);\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","_pointsGeneric","push","x","y","splice","_points","_recalc","angle","_angle","offset","_offset","len","rotate","calcPoint","copy","e","sub","perp","normalize","xMin","yMin","xMax","yMax","point","clone","add","cx","cy","ar","a"],"mappings":"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","sourcesContent":["'use strict'\r\n\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   * An Array of the points of this polygon as numbers instead of Vectors.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {Array<number>}\r\n   */\r\n  private _pointsGeneric: Array<number> = []\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    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 points of this polygon as numbers instead of Vectors.\r\n   * \r\n   * @returns {Array<number>}\r\n   */\r\n  get pointsGeneric(): Array<number> { return this._pointsGeneric; }\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        // Push the points to the generic points Array.\r\n        this._pointsGeneric.push(points[i].x, points[i].y);\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 Polygon(this._position.clone().add(new Vector(xMin, yMin)), [\r\n      new Vector(), new Vector(xMax - xMin, 0),\r\n      new Vector(xMax - xMin, yMax - yMin), new Vector(0, yMax - yMin)\r\n    ]);\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}"]}

@@ -0,1 +1,7 @@

## 1.1.0 / 2020-09-30
- [FEATURE] Added `genericPoints` Array to Polygon which is an Array of all of the points in the Polygon as just numbers instead of Vectors. This is useful for creating triangles from Polygons.
## 1.0.1 / 2020-09-29
- [HOTFIX] Fixed the location of the typings.
## 1.0.0 / 2020-09-28

@@ -2,0 +8,0 @@ - [FEATURE] Made the Vector, Box, Circle, and Polygon classes into their own individual exports instead of having to be created through the Collider2d class.

@@ -390,2 +390,10 @@ function _classCallCheck(instance, Constructor) {

/**
* An Array of the points of this polygon as numbers instead of Vectors.
*
* @private
*
* @property {Array<number>}
*/
/**
* The angle of this polygon.

@@ -447,2 +455,4 @@ *

_defineProperty(this, "_pointsGeneric", []);
_defineProperty(this, "_angle", 0);

@@ -495,4 +505,6 @@

var p1 = points[i];
var p2 = i < points.length - 1 ? points[i + 1] : points[0];
var p2 = i < points.length - 1 ? points[i + 1] : points[0]; // Push the points to the generic points Array.
this._pointsGeneric.push(points[i].x, points[i].y);
if (p1 !== p2 && p1.x === p2.x && p1.y === p2.y) {

@@ -752,2 +764,13 @@ points.splice(i, 1);

/**
* Returns the points of this polygon as numbers instead of Vectors.
*
* @returns {Array<number>}
*/
}, {
key: "pointsGeneric",
get: function get() {
return this._pointsGeneric;
}
/**
* Returns the calculated points of this polygon.

@@ -754,0 +777,0 @@ *

9

package.json
{
"name": "collider2d",
"version": "1.0.0",
"version": "1.1.0",
"description": "A 2D collision checker for modern JavaScript games.",
"main": "index.js",
"main": "build/index.js",
"module": "collider2d.js",

@@ -18,4 +18,3 @@ "scripts": {

"bundle:watch": "rollup -c --watch",
"test": "mocha",
"prepare": "npm run build && npm run bundle"
"test": "mocha"
},

@@ -37,3 +36,3 @@ "repository": {

],
"typings": "lib/index.d.ts",
"typings": "build/index.d.ts",
"author": "Robert Corponoi",

@@ -40,0 +39,0 @@ "license": "MIT",

@@ -19,5 +19,2 @@ 'use strict'

output: [{
file: pkg.main,
format: 'cjs',
}, {
file: pkg.module,

@@ -24,0 +21,0 @@ format: 'esm',

@@ -33,2 +33,11 @@ 'use strict'

/**
* An Array of the points of this polygon as numbers instead of Vectors.
*
* @private
*
* @property {Array<number>}
*/
private _pointsGeneric: Array<number> = []
/**
* The angle of this polygon.

@@ -134,2 +143,9 @@ *

/**
* Returns the points of this polygon as numbers instead of Vectors.
*
* @returns {Array<number>}
*/
get pointsGeneric(): Array<number> { return this._pointsGeneric; }
/**
* Returns the calculated points of this polygon.

@@ -197,2 +213,5 @@ *

// Push the points to the generic points Array.
this._pointsGeneric.push(points[i].x, points[i].y);
if (p1 !== p2 && p1.x === p2.x && p1.y === p2.y) {

@@ -199,0 +218,0 @@ points.splice(i, 1);

'use strict'
const chai = require('chai');
const { Vector, Box, Circle, Polygon, Collider2d } = require('../index');
const { Vector, Box, Circle, Polygon, Collider2d } = require('../build/index.js');

@@ -27,29 +27,44 @@ const collider2d = new Collider2d();

describe("Polygon Centroids", () => {
it("should calculate the correct value for a square", () => {
const polygon = new Polygon(
new Vector(0, 0), [
new Vector(0, 0),
new Vector(40, 0),
new Vector(40, 40),
new Vector(0, 40)
]);
describe("Generic Points", () => {
it("should return the generic points of the Polygon", () => {
const polygon = new Polygon(new Vector(100, 100), [
new Vector(0, 0),
new Vector(200, 0),
new Vector(100, 200),
new Vector(0, 200),
]);
const c = polygon.getCentroid();
chai.expect(c.x).to.equal(20);
chai.expect(c.y).to.equal(20);
chai.expect(polygon.pointsGeneric).to.deep.equal([0, 0, 200, 0, 100, 200, 0, 200]);
});
});
it("should calculate the correct value for a triangle", () => {
const polygon = new Polygon(
new Vector(0, 0), [
new Vector(0, 0),
new Vector(100, 0),
new Vector(50, 99)
]);
describe("Centroids", () => {
it("should calculate the correct value for a square", () => {
const polygon = new Polygon(
new Vector(0, 0), [
new Vector(0, 0),
new Vector(40, 0),
new Vector(40, 40),
new Vector(0, 40)
]);
const c = polygon.getCentroid();
const c = polygon.getCentroid();
chai.expect(c.x).to.equal(50);
chai.expect(c.y).to.equal(33);
chai.expect(c.x).to.equal(20);
chai.expect(c.y).to.equal(20);
});
it("should calculate the correct value for a triangle", () => {
const polygon = new Polygon(
new Vector(0, 0), [
new Vector(0, 0),
new Vector(100, 0),
new Vector(50, 99)
]);
const c = polygon.getCentroid();
chai.expect(c.x).to.equal(50);
chai.expect(c.y).to.equal(33);
});
});

@@ -56,0 +71,0 @@ });

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