New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.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.1.0 to 1.1.1

2

build/collision_details.js

@@ -110,2 +110,2 @@ 'use strict';

exports["default"] = CollisionDetails;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2xsaXNpb25fZGV0YWlscy50cyJdLCJuYW1lcyI6WyJDb2xsaXNpb25EZXRhaWxzIiwiVmVjdG9yIiwiTnVtYmVyIiwiTUFYX1ZBTFVFIiwiY2xlYXIiLCJhSW5CIiwiYkluQSIsIm92ZXJsYXAiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7OztBQUlBOzs7Ozs7SUFNcUJBLGdCO0FBQ25COzs7Ozs7QUFPQTs7Ozs7O0FBT0E7Ozs7OztBQU9BOzs7Ozs7QUFPQTs7Ozs7O0FBT0E7Ozs7OztBQU9BOzs7OztBQU9BLDhCQUFjO0FBQUE7O0FBQUE7O0FBQUE7O0FBQUEsc0NBOUJLLElBQUlDLGtCQUFKLEVBOEJMOztBQUFBLHNDQXZCSyxJQUFJQSxrQkFBSixFQXVCTDs7QUFBQSxxQ0FoQklDLE1BQU0sQ0FBQ0MsU0FnQlg7O0FBQUEsa0NBVEUsSUFTRjs7QUFBQSxrQ0FGRSxJQUVGOztBQUNaLFNBQUtDLEtBQUw7QUFDRDtBQUVEOzs7Ozs7Ozs7Ozs0QkFPMEI7QUFDeEIsV0FBS0MsSUFBTCxHQUFZLElBQVo7QUFDQSxXQUFLQyxJQUFMLEdBQVksSUFBWjtBQUVBLFdBQUtDLE9BQUwsR0FBZUwsTUFBTSxDQUFDQyxTQUF0QjtBQUVBLGFBQU8sSUFBUDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnXHJcblxyXG5pbXBvcnQgVmVjdG9yIGZyb20gJy4vZ2VvbWV0cnkvdmVjdG9yJztcclxuaW1wb3J0IENpcmNsZSBmcm9tICcuL2dlb21ldHJ5L2NpcmNsZSc7XHJcbmltcG9ydCBQb2x5Z29uIGZyb20gJy4vZ2VvbWV0cnkvcG9seWdvbic7XHJcblxyXG4vKipcclxuICogQW4gb2JqZWN0IHJlcHJlc2VudGluZyB0aGUgcmVzdWx0IG9mIGFuIGludGVyc2VjdGlvbiBjb250YWluaW5nOlxyXG4gKiAtIFRoZSB0d28gb2JqZWN0cyBwYXJ0aWNpcGF0aW5nIGluIHRoZSBpbnRlcnNlY3Rpb25cclxuICogLSBUaGUgdmVjdG9yIHJlcHJlc2VudGluZyB0aGUgbWluaW11bSBjaGFuZ2UgbmVjZXNzYXJ5IHRvIGV4dHJhY3QgdGhlIGZpcnN0IG9iamVjdCBmcm9tIHRoZSBzZWNvbmQgb25lIChhcyB3ZWxsIGFzIGEgdW5pdCB2ZWN0b3IgaW4gdGhhdCBkaXJlY3Rpb24gYW5kIHRoZSBtYWduaXR1ZGUgb2YgdGhlIG92ZXJsYXApXHJcbiAqIC0gV2hldGhlciB0aGUgZmlyc3Qgb2JqZWN0IGlzIGVudGlyZWx5IGluc2lkZSB0aGUgc2Vjb25kLCBhbmQgdmljZSB2ZXJzYS5cclxuICovXHJcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbGxpc2lvbkRldGFpbHMge1xyXG4gIC8qKlxyXG4gICAqIFRoZSBmaXJzdCBjb2xsaXNpb24gb2JqZWN0LlxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7Q2lyY2xlfFBvbHlnb259XHJcbiAgICovXHJcbiAgYSE6IChDaXJjbGV8UG9seWdvbik7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBzZWNvbmQgY29sbGlzaW9uIG9iamVjdC5cclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge0NpcmNsZXxQb2x5Z29ufVxyXG4gICAqL1xyXG4gIGIhOiAoQ2lyY2xlfFBvbHlnb24pO1xyXG5cclxuICAvKipcclxuICAgKiBBIHVuaXQgdmVjdG9yIHJlcHJlc2VudGluZyB0aGUgZGlyZWN0aW9uIGFuZCBtYWduaXR1ZGUgb2YgdGhlIG92ZXJsYXAuXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtWZWN0b3J9XHJcbiAgICovXHJcbiAgb3ZlcmxhcE46IFZlY3RvciA9IG5ldyBWZWN0b3IoKTtcclxuXHJcbiAgLyoqXHJcbiAgICogQSB2ZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBtaW5pbXVtIGNoYW5nZSBuZWNlc3NhcnkgdG8gZXh0cmFjdCB0aGUgZmlyc3Qgb2JqZWN0IGZyb20gdGhlIHNlY29uZCBvbmUuXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtWZWN0b3J9XHJcbiAgICovXHJcbiAgb3ZlcmxhcFY6IFZlY3RvciA9IG5ldyBWZWN0b3IoKTtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIGFtb3VudCB0aGF0IGlzIG92ZXJsYXBwaW5nLlxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7bnVtYmVyfVxyXG4gICAqL1xyXG4gIG92ZXJsYXA6IG51bWJlciA9IE51bWJlci5NQVhfVkFMVUU7XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZmlyc3QgY29sbGlzaW9uIG9iamVjdCBpcyBjb21wbGV0ZWx5IGluIHRoZSBzZWNvbmQgY29sbGlzaW9uIG9iamVjdC5cclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge2Jvb2xlYW59XHJcbiAgICovXHJcbiAgYUluQjogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgc2Vjb25kIGNvbGxpc2lvbiBvYmplY3QgaXMgY29tcGxldGVseSBpbiB0aGUgZmlyc3QgY29sbGlzaW9uIG9iamVjdC5cclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge2Jvb2xlYW59XHJcbiAgICovXHJcbiAgYkluQTogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgdGhpcy5jbGVhcigpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2V0IHNvbWUgdmFsdWVzIG9mIHRoZSByZXNwb25zZSBiYWNrIHRvIHRoZWlyIGRlZmF1bHRzLlxyXG4gICAqIFxyXG4gICAqIENhbGwgdGhpcyBiZXR3ZWVuIHRlc3RzIGlmIHlvdSBhcmUgZ29pbmcgdG8gcmV1c2UgYSBzaW5nbGUgQ29sbGlzaW9uRGV0YWlscyBvYmplY3QgZm9yIG11bHRpcGxlIGludGVyc2VjdGlvbiB0ZXN0cyAocmVjb21tZW5kZWQgYXMgaXQgd2lsbCBhdm9pZCBhbGxjYXRpbmcgZXh0cmEgbWVtb3J5KVxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtDb2xsaXNpb25EZXRhaWxzfSBSZXR1cm5zIHRoaXMgZm9yIGNoYWluaW5nLlxyXG4gICAqL1xyXG4gIGNsZWFyKCk6IENvbGxpc2lvbkRldGFpbHMge1xyXG4gICAgdGhpcy5hSW5CID0gdHJ1ZTtcclxuICAgIHRoaXMuYkluQSA9IHRydWU7XHJcblxyXG4gICAgdGhpcy5vdmVybGFwID0gTnVtYmVyLk1BWF9WQUxVRTtcclxuXHJcbiAgICByZXR1cm4gdGhpcztcclxuICB9XHJcbn0iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2xsaXNpb25fZGV0YWlscy50cyJdLCJuYW1lcyI6WyJDb2xsaXNpb25EZXRhaWxzIiwiVmVjdG9yIiwiTnVtYmVyIiwiTUFYX1ZBTFVFIiwiY2xlYXIiLCJhSW5CIiwiYkluQSIsIm92ZXJsYXAiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBRUE7Ozs7Ozs7Ozs7OztBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtJQUNxQkEsZ0I7QUFDbkI7QUFDRjtBQUNBO0FBQ0E7QUFDQTs7QUFHRTtBQUNGO0FBQ0E7QUFDQTtBQUNBOztBQUdFO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7O0FBR0U7QUFDRjtBQUNBO0FBQ0E7QUFDQTs7QUFHRTtBQUNGO0FBQ0E7QUFDQTtBQUNBOztBQUdFO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7O0FBR0U7QUFDRjtBQUNBO0FBQ0E7QUFDQTtBQUdFLDhCQUFjO0FBQUE7O0FBQUE7O0FBQUE7O0FBQUEsc0NBOUJLLElBQUlDLGtCQUFKLEVBOEJMOztBQUFBLHNDQXZCSyxJQUFJQSxrQkFBSixFQXVCTDs7QUFBQSxxQ0FoQklDLE1BQU0sQ0FBQ0MsU0FnQlg7O0FBQUEsa0NBVEUsSUFTRjs7QUFBQSxrQ0FGRSxJQUVGOztBQUNaLFNBQUtDLEtBQUw7QUFDRDtBQUVEO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7OztXQUNFLGlCQUEwQjtBQUN4QixXQUFLQyxJQUFMLEdBQVksSUFBWjtBQUNBLFdBQUtDLElBQUwsR0FBWSxJQUFaO0FBRUEsV0FBS0MsT0FBTCxHQUFlTCxNQUFNLENBQUNDLFNBQXRCO0FBRUEsYUFBTyxJQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCdcclxuXHJcbmltcG9ydCBWZWN0b3IgZnJvbSAnLi9nZW9tZXRyeS92ZWN0b3InO1xyXG5pbXBvcnQgQ2lyY2xlIGZyb20gJy4vZ2VvbWV0cnkvY2lyY2xlJztcclxuaW1wb3J0IFBvbHlnb24gZnJvbSAnLi9nZW9tZXRyeS9wb2x5Z29uJztcclxuXHJcbi8qKlxyXG4gKiBBbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSByZXN1bHQgb2YgYW4gaW50ZXJzZWN0aW9uIGNvbnRhaW5pbmc6XHJcbiAqIC0gVGhlIHR3byBvYmplY3RzIHBhcnRpY2lwYXRpbmcgaW4gdGhlIGludGVyc2VjdGlvblxyXG4gKiAtIFRoZSB2ZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBtaW5pbXVtIGNoYW5nZSBuZWNlc3NhcnkgdG8gZXh0cmFjdCB0aGUgZmlyc3Qgb2JqZWN0IGZyb20gdGhlIHNlY29uZCBvbmUgKGFzIHdlbGwgYXMgYSB1bml0IHZlY3RvciBpbiB0aGF0IGRpcmVjdGlvbiBhbmQgdGhlIG1hZ25pdHVkZSBvZiB0aGUgb3ZlcmxhcClcclxuICogLSBXaGV0aGVyIHRoZSBmaXJzdCBvYmplY3QgaXMgZW50aXJlbHkgaW5zaWRlIHRoZSBzZWNvbmQsIGFuZCB2aWNlIHZlcnNhLlxyXG4gKi9cclxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQ29sbGlzaW9uRGV0YWlscyB7XHJcbiAgLyoqXHJcbiAgICogVGhlIGZpcnN0IGNvbGxpc2lvbiBvYmplY3QuXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtDaXJjbGV8UG9seWdvbn1cclxuICAgKi9cclxuICBhITogKENpcmNsZXxQb2x5Z29uKTtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHNlY29uZCBjb2xsaXNpb24gb2JqZWN0LlxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7Q2lyY2xlfFBvbHlnb259XHJcbiAgICovXHJcbiAgYiE6IChDaXJjbGV8UG9seWdvbik7XHJcblxyXG4gIC8qKlxyXG4gICAqIEEgdW5pdCB2ZWN0b3IgcmVwcmVzZW50aW5nIHRoZSBkaXJlY3Rpb24gYW5kIG1hZ25pdHVkZSBvZiB0aGUgb3ZlcmxhcC5cclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge1ZlY3Rvcn1cclxuICAgKi9cclxuICBvdmVybGFwTjogVmVjdG9yID0gbmV3IFZlY3RvcigpO1xyXG5cclxuICAvKipcclxuICAgKiBBIHZlY3RvciByZXByZXNlbnRpbmcgdGhlIG1pbmltdW0gY2hhbmdlIG5lY2Vzc2FyeSB0byBleHRyYWN0IHRoZSBmaXJzdCBvYmplY3QgZnJvbSB0aGUgc2Vjb25kIG9uZS5cclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge1ZlY3Rvcn1cclxuICAgKi9cclxuICBvdmVybGFwVjogVmVjdG9yID0gbmV3IFZlY3RvcigpO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgYW1vdW50IHRoYXQgaXMgb3ZlcmxhcHBpbmcuXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtudW1iZXJ9XHJcbiAgICovXHJcbiAgb3ZlcmxhcDogbnVtYmVyID0gTnVtYmVyLk1BWF9WQUxVRTtcclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0cnVlIGlmIHRoZSBmaXJzdCBjb2xsaXNpb24gb2JqZWN0IGlzIGNvbXBsZXRlbHkgaW4gdGhlIHNlY29uZCBjb2xsaXNpb24gb2JqZWN0LlxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn1cclxuICAgKi9cclxuICBhSW5COiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0cnVlIGlmIHRoZSBzZWNvbmQgY29sbGlzaW9uIG9iamVjdCBpcyBjb21wbGV0ZWx5IGluIHRoZSBmaXJzdCBjb2xsaXNpb24gb2JqZWN0LlxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn1cclxuICAgKi9cclxuICBiSW5BOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICB0aGlzLmNsZWFyKCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBTZXQgc29tZSB2YWx1ZXMgb2YgdGhlIHJlc3BvbnNlIGJhY2sgdG8gdGhlaXIgZGVmYXVsdHMuXHJcbiAgICogXHJcbiAgICogQ2FsbCB0aGlzIGJldHdlZW4gdGVzdHMgaWYgeW91IGFyZSBnb2luZyB0byByZXVzZSBhIHNpbmdsZSBDb2xsaXNpb25EZXRhaWxzIG9iamVjdCBmb3IgbXVsdGlwbGUgaW50ZXJzZWN0aW9uIHRlc3RzIChyZWNvbW1lbmRlZCBhcyBpdCB3aWxsIGF2b2lkIGFsbGNhdGluZyBleHRyYSBtZW1vcnkpXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge0NvbGxpc2lvbkRldGFpbHN9IFJldHVybnMgdGhpcyBmb3IgY2hhaW5pbmcuXHJcbiAgICovXHJcbiAgY2xlYXIoKTogQ29sbGlzaW9uRGV0YWlscyB7XHJcbiAgICB0aGlzLmFJbkIgPSB0cnVlO1xyXG4gICAgdGhpcy5iSW5BID0gdHJ1ZTtcclxuXHJcbiAgICB0aGlzLm92ZXJsYXAgPSBOdW1iZXIuTUFYX1ZBTFVFO1xyXG5cclxuICAgIHJldHVybiB0aGlzO1xyXG4gIH1cclxufSJdfQ==

@@ -94,2 +94,2 @@ 'use strict';

exports["default"] = Box;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW9tZXRyeS9ib3gudHMiXSwibmFtZXMiOlsiQm94IiwicG9zaXRpb24iLCJWZWN0b3IiLCJ3aWR0aCIsImhlaWdodCIsIl9wb3NpdGlvbiIsIl93aWR0aCIsIl9oZWlnaHQiLCJQb2x5Z29uIiwieCIsInkiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBRUE7O0FBQ0E7Ozs7Ozs7Ozs7OztBQUVBOzs7SUFHcUJBLEc7QUFDbkI7Ozs7Ozs7O0FBU0E7Ozs7Ozs7O0FBU0E7Ozs7Ozs7O0FBU0E7Ozs7Ozs7OztBQVNBLGlCQUFvRjtBQUFBLFFBQXhFQyxRQUF3RSx1RUFBckQsSUFBSUMsa0JBQUosRUFBcUQ7QUFBQSxRQUF2Q0MsS0FBdUMsdUVBQXZCLENBQXVCO0FBQUEsUUFBcEJDLE1BQW9CLHVFQUFILENBQUc7O0FBQUE7O0FBQUEsdUNBN0J4RCxJQUFJRixrQkFBSixFQTZCd0Q7O0FBQUEsb0NBcEIzRCxDQW9CMkQ7O0FBQUEscUNBWDFELENBVzBEOztBQUNsRixTQUFLRyxTQUFMLEdBQWlCSixRQUFqQjtBQUNBLFNBQUtLLE1BQUwsR0FBY0gsS0FBZDtBQUNBLFNBQUtJLE9BQUwsR0FBZUgsTUFBZjtBQUNEO0FBRUQ7Ozs7Ozs7OztnQ0FLcUI7QUFDbkIsYUFBTyxJQUFJSSxtQkFBSixDQUFZLElBQUlOLGtCQUFKLENBQVcsS0FBS0csU0FBTCxDQUFlSSxDQUExQixFQUE2QixLQUFLSixTQUFMLENBQWVLLENBQTVDLENBQVosRUFBNEQsQ0FDakUsSUFBSVIsa0JBQUosRUFEaUUsRUFDbkQsSUFBSUEsa0JBQUosQ0FBVyxLQUFLSSxNQUFoQixFQUF3QixDQUF4QixDQURtRCxFQUVqRSxJQUFJSixrQkFBSixDQUFXLEtBQUtJLE1BQWhCLEVBQXdCLEtBQUtDLE9BQTdCLENBRmlFLEVBRTFCLElBQUlMLGtCQUFKLENBQVcsQ0FBWCxFQUFjLEtBQUtLLE9BQW5CLENBRjBCLENBQTVELENBQVA7QUFJRCIsInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0J1xyXG5cclxuaW1wb3J0IFZlY3RvciBmcm9tICcuL3ZlY3Rvcic7XHJcbmltcG9ydCBQb2x5Z29uIGZyb20gJy4vcG9seWdvbic7XHJcblxyXG4vKipcclxuICogQSBib3ggcmVwcmVzZW50cyBhbiBheGlzLWFsaWduZWQgYm94IHdpdGggYSB3aWR0aCBhbmQgaGVpZ2h0LlxyXG4gKi9cclxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQm94IHtcclxuICAvKipcclxuICAgKiBUaGUgcG9zaXRpb24gb2YgdGhpcyBib3ggYXMgYSBWZWN0b3IuXHJcbiAgICogXHJcbiAgICogQHByaXZhdGVcclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge1ZlY3Rvcn1cclxuICAgKi9cclxuICBwcml2YXRlIF9wb3NpdGlvbjogVmVjdG9yID0gbmV3IFZlY3RvcigpO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgd2lkdGggb2YgdGhpcyBib3guXHJcbiAgICogXHJcbiAgICogQHByaXZhdGVcclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge251bWJlcn1cclxuICAgKi9cclxuICBwcml2YXRlIF93aWR0aDogbnVtYmVyID0gMDtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIGhlaWdodCBvZiB0aGlzIGJveC5cclxuICAgKiBcclxuICAgKiBAcHJpdmF0ZVxyXG4gICAqIFxyXG4gICAqIEBwcm9wZXJ0eSB7bnVtYmVyfVxyXG4gICAqL1xyXG4gIHByaXZhdGUgX2hlaWdodDogbnVtYmVyID0gMDtcclxuXHJcbiAgLyoqXHJcbiAgICogQ3JlYXRlcyBhIG5ldyBCb3gsIHdpdGggdGhlIHNwZWNpZmllZCBwb3NpdGlvbiwgd2lkdGgsIGFuZCBoZWlnaHQuXHJcbiAgICogXHJcbiAgICogSWYgbm8gcG9zaXRpb24gaXMgZ2l2ZW4sIHRoZSBwb3NpdGlvbiB3aWxsIGJlIGAoMCwgMClgLiBJZiBubyB3aWR0aCBvciBoZWlnaHQgYXJlIGdpdmVuLCB0aGV5IHdpbGwgYmUgc2V0IHRvIGAwYC5cclxuICAgKiBcclxuICAgKiBAcGFyYW0ge1ZlY3Rvcn0gW3Bvc2l0aW9uPW5ldyBWZWN0b3IoKV0gVGhlIHBvc2l0aW9uIG9mIHRoaXMgYm94IGFzIGEgVmVjdG9yLlxyXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBbd2lkdGg9MF0gVGhlIHdpZHRoIG9mIHRoaXMgYm94LlxyXG4gICAqIEBwYXJhbSB7bnVtYmVyfSBbaGVpZ2h0PTBdIFRoZSBoZWlnaHQgb2YgdGhpcyBib3guXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocG9zaXRpb246IFZlY3RvciA9IG5ldyBWZWN0b3IoKSwgd2lkdGg6IG51bWJlciA9IDAsIGhlaWdodDogbnVtYmVyID0gMCkge1xyXG4gICAgdGhpcy5fcG9zaXRpb24gPSBwb3NpdGlvbjtcclxuICAgIHRoaXMuX3dpZHRoID0gd2lkdGg7XHJcbiAgICB0aGlzLl9oZWlnaHQgPSBoZWlnaHQ7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZXR1cm5zIGEgUG9seWdvbiB3aG9zZSBlZGdlcyBhcmUgdGhlIHNhbWUgYXMgdGhpcyBCb3guXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge1BvbHlnb259IEEgbmV3IFBvbHlnb24gdGhhdCByZXByZXNlbnRzIHRoaXMgQm94LlxyXG4gICAqL1xyXG4gIHRvUG9seWdvbigpOiBQb2x5Z29uIHtcclxuICAgIHJldHVybiBuZXcgUG9seWdvbihuZXcgVmVjdG9yKHRoaXMuX3Bvc2l0aW9uLngsIHRoaXMuX3Bvc2l0aW9uLnkpLCBbXHJcbiAgICAgIG5ldyBWZWN0b3IoKSwgbmV3IFZlY3Rvcih0aGlzLl93aWR0aCwgMCksXHJcbiAgICAgIG5ldyBWZWN0b3IodGhpcy5fd2lkdGgsIHRoaXMuX2hlaWdodCksIG5ldyBWZWN0b3IoMCwgdGhpcy5faGVpZ2h0KVxyXG4gICAgXSk7XHJcbiAgfVxyXG59Il19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9nZW9tZXRyeS9ib3gudHMiXSwibmFtZXMiOlsiQm94IiwicG9zaXRpb24iLCJWZWN0b3IiLCJ3aWR0aCIsImhlaWdodCIsIl9wb3NpdGlvbiIsIl93aWR0aCIsIl9oZWlnaHQiLCJQb2x5Z29uIiwieCIsInkiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBRUE7O0FBQ0E7Ozs7Ozs7Ozs7OztBQUVBO0FBQ0E7QUFDQTtJQUNxQkEsRztBQUNuQjtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFHRTtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFHRTtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFHRTtBQUNGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDRSxpQkFBb0Y7QUFBQSxRQUF4RUMsUUFBd0UsdUVBQXJELElBQUlDLGtCQUFKLEVBQXFEO0FBQUEsUUFBdkNDLEtBQXVDLHVFQUF2QixDQUF1QjtBQUFBLFFBQXBCQyxNQUFvQix1RUFBSCxDQUFHOztBQUFBOztBQUFBLHVDQTdCeEQsSUFBSUYsa0JBQUosRUE2QndEOztBQUFBLG9DQXBCM0QsQ0FvQjJEOztBQUFBLHFDQVgxRCxDQVcwRDs7QUFDbEYsU0FBS0csU0FBTCxHQUFpQkosUUFBakI7QUFDQSxTQUFLSyxNQUFMLEdBQWNILEtBQWQ7QUFDQSxTQUFLSSxPQUFMLEdBQWVILE1BQWY7QUFDRDtBQUVEO0FBQ0Y7QUFDQTtBQUNBO0FBQ0E7Ozs7O1dBQ0UscUJBQXFCO0FBQ25CLGFBQU8sSUFBSUksbUJBQUosQ0FBWSxJQUFJTixrQkFBSixDQUFXLEtBQUtHLFNBQUwsQ0FBZUksQ0FBMUIsRUFBNkIsS0FBS0osU0FBTCxDQUFlSyxDQUE1QyxDQUFaLEVBQTRELENBQ2pFLElBQUlSLGtCQUFKLEVBRGlFLEVBQ25ELElBQUlBLGtCQUFKLENBQVcsS0FBS0ksTUFBaEIsRUFBd0IsQ0FBeEIsQ0FEbUQsRUFFakUsSUFBSUosa0JBQUosQ0FBVyxLQUFLSSxNQUFoQixFQUF3QixLQUFLQyxPQUE3QixDQUZpRSxFQUUxQixJQUFJTCxrQkFBSixDQUFXLENBQVgsRUFBYyxLQUFLSyxPQUFuQixDQUYwQixDQUE1RCxDQUFQO0FBSUQiLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCdcclxuXHJcbmltcG9ydCBWZWN0b3IgZnJvbSAnLi92ZWN0b3InO1xyXG5pbXBvcnQgUG9seWdvbiBmcm9tICcuL3BvbHlnb24nO1xyXG5cclxuLyoqXHJcbiAqIEEgYm94IHJlcHJlc2VudHMgYW4gYXhpcy1hbGlnbmVkIGJveCB3aXRoIGEgd2lkdGggYW5kIGhlaWdodC5cclxuICovXHJcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEJveCB7XHJcbiAgLyoqXHJcbiAgICogVGhlIHBvc2l0aW9uIG9mIHRoaXMgYm94IGFzIGEgVmVjdG9yLlxyXG4gICAqIFxyXG4gICAqIEBwcml2YXRlXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtWZWN0b3J9XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBfcG9zaXRpb246IFZlY3RvciA9IG5ldyBWZWN0b3IoKTtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHdpZHRoIG9mIHRoaXMgYm94LlxyXG4gICAqIFxyXG4gICAqIEBwcml2YXRlXHJcbiAgICogXHJcbiAgICogQHByb3BlcnR5IHtudW1iZXJ9XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBfd2lkdGg6IG51bWJlciA9IDA7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBoZWlnaHQgb2YgdGhpcyBib3guXHJcbiAgICogXHJcbiAgICogQHByaXZhdGVcclxuICAgKiBcclxuICAgKiBAcHJvcGVydHkge251bWJlcn1cclxuICAgKi9cclxuICBwcml2YXRlIF9oZWlnaHQ6IG51bWJlciA9IDA7XHJcblxyXG4gIC8qKlxyXG4gICAqIENyZWF0ZXMgYSBuZXcgQm94LCB3aXRoIHRoZSBzcGVjaWZpZWQgcG9zaXRpb24sIHdpZHRoLCBhbmQgaGVpZ2h0LlxyXG4gICAqIFxyXG4gICAqIElmIG5vIHBvc2l0aW9uIGlzIGdpdmVuLCB0aGUgcG9zaXRpb24gd2lsbCBiZSBgKDAsIDApYC4gSWYgbm8gd2lkdGggb3IgaGVpZ2h0IGFyZSBnaXZlbiwgdGhleSB3aWxsIGJlIHNldCB0byBgMGAuXHJcbiAgICogXHJcbiAgICogQHBhcmFtIHtWZWN0b3J9IFtwb3NpdGlvbj1uZXcgVmVjdG9yKCldIFRoZSBwb3NpdGlvbiBvZiB0aGlzIGJveCBhcyBhIFZlY3Rvci5cclxuICAgKiBAcGFyYW0ge251bWJlcn0gW3dpZHRoPTBdIFRoZSB3aWR0aCBvZiB0aGlzIGJveC5cclxuICAgKiBAcGFyYW0ge251bWJlcn0gW2hlaWdodD0wXSBUaGUgaGVpZ2h0IG9mIHRoaXMgYm94LlxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHBvc2l0aW9uOiBWZWN0b3IgPSBuZXcgVmVjdG9yKCksIHdpZHRoOiBudW1iZXIgPSAwLCBoZWlnaHQ6IG51bWJlciA9IDApIHtcclxuICAgIHRoaXMuX3Bvc2l0aW9uID0gcG9zaXRpb247XHJcbiAgICB0aGlzLl93aWR0aCA9IHdpZHRoO1xyXG4gICAgdGhpcy5faGVpZ2h0ID0gaGVpZ2h0O1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyBhIFBvbHlnb24gd2hvc2UgZWRnZXMgYXJlIHRoZSBzYW1lIGFzIHRoaXMgQm94LlxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtQb2x5Z29ufSBBIG5ldyBQb2x5Z29uIHRoYXQgcmVwcmVzZW50cyB0aGlzIEJveC5cclxuICAgKi9cclxuICB0b1BvbHlnb24oKTogUG9seWdvbiB7XHJcbiAgICByZXR1cm4gbmV3IFBvbHlnb24obmV3IFZlY3Rvcih0aGlzLl9wb3NpdGlvbi54LCB0aGlzLl9wb3NpdGlvbi55KSwgW1xyXG4gICAgICBuZXcgVmVjdG9yKCksIG5ldyBWZWN0b3IodGhpcy5fd2lkdGgsIDApLFxyXG4gICAgICBuZXcgVmVjdG9yKHRoaXMuX3dpZHRoLCB0aGlzLl9oZWlnaHQpLCBuZXcgVmVjdG9yKDAsIHRoaXMuX2hlaWdodClcclxuICAgIF0pO1xyXG4gIH1cclxufSJdfQ==

@@ -81,5 +81,38 @@ 'use strict';

_createClass(Circle, [{
key: "translate",
key: "position",
get: function get() {
return this._position;
}
/**
* Returns the radius of this circle.
*
* @returns {number}
*/
}, {
key: "radius",
get: function get() {
return this._radius;
}
/**
* Returns the offset of this circle.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Set a new offset for this circle.
*
* @param {Vector} offset The new offset for this circle.
*/
,
set: function set(offset) {
this._offset = offset;
}
/**
* Translate the center of the cirlc.e

@@ -89,2 +122,5 @@ *

*/
}, {
key: "translate",
value: function translate(x, y) {

@@ -123,38 +159,2 @@ this._position.x += x;

}
}, {
key: "position",
get: function get() {
return this._position;
}
/**
* Returns the radius of this circle.
*
* @returns {number}
*/
}, {
key: "radius",
get: function get() {
return this._radius;
}
/**
* Returns the offset of this circle.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Set a new offset for this circle.
*
* @param {Vector} offset The new offset for this circle.
*/
,
set: function set(offset) {
this._offset = offset;
}
}]);

@@ -166,2 +166,2 @@

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

@@ -133,5 +133,106 @@ 'use strict';

_createClass(Polygon, [{
key: "setPoints",
key: "position",
get: function get() {
return this._position;
}
/**
* **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.
*
* @returns {Array<Vector>}
*/
}, {
key: "points",
get: function get() {
return this._points;
}
/**
* 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.
*
* @returns {Array<Vector>}
*/
}, {
key: "calcPoints",
get: function get() {
return this._calcPoints;
}
/**
* Returns the offset of this polygon.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Returns the angle of this polygon.
*
* @returns {number}
*/
}, {
key: "angle",
get: function get() {
return this._angle;
}
/**
* Returns the edges of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "edges",
get: function get() {
return this._edges;
}
/**
* Returns the normals of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "normals",
get: function get() {
return this._normals;
}
/**
* Set the points of the polygon. Any consecutive duplicate points will be combined.

@@ -147,2 +248,5 @@ *

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

@@ -380,106 +484,2 @@ // Only re-allocate if this is a new polygon or the number of points has changed.

}
}, {
key: "position",
get: function get() {
return this._position;
}
/**
* **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.
*
* @returns {Array<Vector>}
*/
}, {
key: "points",
get: function get() {
return this._points;
}
/**
* 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.
*
* @returns {Array<Vector>}
*/
}, {
key: "calcPoints",
get: function get() {
return this._calcPoints;
}
/**
* Returns the offset of this polygon.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Returns the angle of this polygon.
*
* @returns {number}
*/
}, {
key: "angle",
get: function get() {
return this._angle;
}
/**
* Returns the edges of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "edges",
get: function get() {
return this._edges;
}
/**
* Returns the normals of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "normals",
get: function get() {
return this._normals;
}
}]);

@@ -491,2 +491,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","_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}"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/geometry/polygon.ts"],"names":["Polygon","position","Vector","points","_position","setPoints","_points","_pointsGeneric","_calcPoints","_offset","_angle","_edges","_normals","lengthChanged","length","i","calcPoints","edges","normals","p1","p2","push","x","y","splice","_recalc","angle","offset","len","rotate","calcPoint","copy","e","sub","perp","normalize","xMin","yMin","xMax","yMax","point","clone","add","cx","cy","ar","a"],"mappings":"AAAA;;;;;;;AAEA;;;;;;;;;;;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;IACqBA,O;AACnB;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;;AAGE;AACF;AACA;AACA;AACA;AACA;AACA;AACE,qBAAyE;AAAA,QAA7DC,QAA6D,uEAA1C,IAAIC,kBAAJ,EAA0C;AAAA,QAA5BC,MAA4B,uEAAJ,EAAI;;AAAA;;AAAA,uCAxE7C,IAAID,kBAAJ,EAwE6C;;AAAA,qCA/DxC,EA+DwC;;AAAA,4CAtDjC,EAsDiC;;AAAA,oCA7ChD,CA6CgD;;AAAA,qCApC/C,IAAIA,kBAAJ,EAoC+C;;AAAA,yCA3BpC,EA2BoC;;AAAA,oCAlBzC,EAkByC;;AAAA,sCATvC,EASuC;;AACvE,SAAKE,SAAL,GAAiBH,QAAjB;AACA,SAAKI,SAAL,CAAeF,MAAf;AACD;AAED;AACF;AACA;AACA;AACA;;;;;SACE,eAAuB;AAAE,aAAO,KAAKC,SAAZ;AAAwB;AAEjD;AACF;AACA;AACA;AACA;AACA;AACA;AACE;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;;AAEA;AACF;AACA;AACA;AACA;;;;SACE,eAA4B;AAAE,aAAO,KAAKE,OAAZ;AAAsB;AAEpD;AACF;AACA;AACA;AACA;;;;SACE,eAAmC;AAAE,aAAO,KAAKC,cAAZ;AAA6B;AAElE;AACF;AACA;AACA;AACA;;;;SACE,eAAgC;AAAE,aAAO,KAAKC,WAAZ;AAA0B;AAE5D;AACF;AACA;AACA;AACA;;;;SACE,eAAqB;AAAE,aAAO,KAAKC,OAAZ;AAAsB;AAE7C;AACF;AACA;AACA;AACA;;;;SACE,eAAoB;AAAE,aAAO,KAAKC,MAAZ;AAAqB;AAE3C;AACF;AACA;AACA;AACA;;;;SACE,eAA2B;AAAE,aAAO,KAAKC,MAAZ;AAAqB;AAElD;AACF;AACA;AACA;AACA;;;;SACE,eAA6B;AAAE,aAAO,KAAKC,QAAZ;AAAuB;AAEtD;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,mBAAUT,MAAV,EAA0C;AACxC;AACA,UAAMU,aAAsB,GAAG,CAAC,KAAKV,MAAN,IAAgB,KAAKA,MAAL,CAAYW,MAAZ,KAAuBX,MAAM,CAACW,MAA7E;;AAEA,UAAID,aAAJ,EAAmB;AACjB,YAAIE,CAAJ;AAEA,YAAMC,UAAyB,GAAG,KAAKR,WAAL,GAAmB,EAArD;AACA,YAAMS,KAAoB,GAAG,KAAKN,MAAL,GAAc,EAA3C;AACA,YAAMO,OAAsB,GAAG,KAAKN,QAAL,GAAgB,EAA/C,CALiB,CAOjB;;AACA,aAAKG,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGZ,MAAM,CAACW,MAAvB,EAA+BC,CAAC,EAAhC,EAAoC;AAClC;AACA,cAAMI,EAAU,GAAGhB,MAAM,CAACY,CAAD,CAAzB;AACA,cAAMK,EAAU,GAAGL,CAAC,GAAGZ,MAAM,CAACW,MAAP,GAAgB,CAApB,GAAwBX,MAAM,CAACY,CAAC,GAAG,CAAL,CAA9B,GAAwCZ,MAAM,CAAC,CAAD,CAAjE,CAHkC,CAKlC;;AACA,eAAKI,cAAL,CAAoBc,IAApB,CAAyBlB,MAAM,CAACY,CAAD,CAAN,CAAUO,CAAnC,EAAsCnB,MAAM,CAACY,CAAD,CAAN,CAAUQ,CAAhD;;AAEA,cAAIJ,EAAE,KAAKC,EAAP,IAAaD,EAAE,CAACG,CAAH,KAASF,EAAE,CAACE,CAAzB,IAA8BH,EAAE,CAACI,CAAH,KAASH,EAAE,CAACG,CAA9C,EAAiD;AAC/CpB,YAAAA,MAAM,CAACqB,MAAP,CAAcT,CAAd,EAAiB,CAAjB;AACAA,YAAAA,CAAC,IAAI,CAAL;AACA;AACD;;AAEDC,UAAAA,UAAU,CAACK,IAAX,CAAgB,IAAInB,kBAAJ,EAAhB;AACAe,UAAAA,KAAK,CAACI,IAAN,CAAW,IAAInB,kBAAJ,EAAX;AACAgB,UAAAA,OAAO,CAACG,IAAR,CAAa,IAAInB,kBAAJ,EAAb;AACD;AACF;;AAED,WAAKI,OAAL,GAAeH,MAAf;;AAEA,WAAKsB,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;WACE,kBAASC,KAAT,EAAiC;AAC/B,WAAKhB,MAAL,GAAcgB,KAAd;;AAEA,WAAKD,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;;;;WACE,mBAAUE,MAAV,EAAmC;AACjC,WAAKlB,OAAL,GAAekB,MAAf;;AAEA,WAAKF,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,gBAAOC,KAAP,EAA+B;AAC7B,UAAMvB,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMyB,GAAW,GAAGzB,MAAM,CAACW,MAA3B;;AAEA,WAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGa,GAApB,EAAyBb,CAAC,EAA1B;AAA8BZ,QAAAA,MAAM,CAACY,CAAD,CAAN,CAAUc,MAAV,CAAiBH,KAAjB;AAA9B;;AAEA,WAAKD,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,mBAAUH,CAAV,EAAqBC,CAArB,EAAyC;AACvC,UAAMpB,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMyB,GAAW,GAAGzB,MAAM,CAACW,MAA3B;;AAEA,WAAK,IAAIC,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGa,GAA5B,EAAiCb,CAAC,EAAlC,EAAsC;AACpCZ,QAAAA,MAAM,CAACY,CAAD,CAAN,CAAUO,CAAV,IAAeA,CAAf;AACAnB,QAAAA,MAAM,CAACY,CAAD,CAAN,CAAUQ,CAAV,IAAeA,CAAf;AACD;;AAED,WAAKE,OAAL;;AAEA,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,mBAA2B;AACzB;AACA;AACA,UAAMT,UAAyB,GAAG,KAAKA,UAAvC,CAHyB,CAKzB;AACA;AACA;;AACA,UAAMC,KAAoB,GAAG,KAAKN,MAAlC,CARyB,CAUzB;AACA;AACA;;AACA,UAAMO,OAAsB,GAAG,KAAKN,QAApC,CAbyB,CAezB;;AACA,UAAMT,MAAqB,GAAG,KAAKA,MAAnC;AACA,UAAMwB,MAAc,GAAG,KAAKA,MAA5B;AACA,UAAMD,KAAa,GAAG,KAAKA,KAA3B;AAEA,UAAME,GAAW,GAAGzB,MAAM,CAACW,MAA3B;AACA,UAAIC,CAAJ;;AAEA,WAAKA,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGa,GAAhB,EAAqBb,CAAC,EAAtB,EAA0B;AACxB,YAAMe,SAAiB,GAAGd,UAAU,CAACD,CAAD,CAAV,CAAcgB,IAAd,CAAmB5B,MAAM,CAACY,CAAD,CAAzB,CAA1B;AAEAe,QAAAA,SAAS,CAACR,CAAV,IAAeK,MAAM,CAACL,CAAtB;AACAQ,QAAAA,SAAS,CAACP,CAAV,IAAeI,MAAM,CAACJ,CAAtB;AAEA,YAAIG,KAAK,KAAK,CAAd,EAAiBI,SAAS,CAACD,MAAV,CAAiBH,KAAjB;AAClB,OA9BwB,CAgCzB;;;AACA,WAAKX,CAAC,GAAG,CAAT,EAAYA,CAAC,GAAGa,GAAhB,EAAqBb,CAAC,EAAtB,EAA0B;AACxB,YAAMI,EAAU,GAAGH,UAAU,CAACD,CAAD,CAA7B;AACA,YAAMK,EAAU,GAAGL,CAAC,GAAGa,GAAG,GAAG,CAAV,GAAcZ,UAAU,CAACD,CAAC,GAAG,CAAL,CAAxB,GAAkCC,UAAU,CAAC,CAAD,CAA/D;AAEA,YAAMgB,CAAS,GAAGf,KAAK,CAACF,CAAD,CAAL,CAASgB,IAAT,CAAcX,EAAd,EAAkBa,GAAlB,CAAsBd,EAAtB,CAAlB;AAEAD,QAAAA,OAAO,CAACH,CAAD,CAAP,CAAWgB,IAAX,CAAgBC,CAAhB,EAAmBE,IAAnB,GAA0BC,SAA1B;AACD;;AAED,aAAO,IAAP;AACD;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,mBAAmB;AACjB,UAAMhC,MAAqB,GAAG,KAAKa,UAAnC;AACA,UAAMY,GAAW,GAAGzB,MAAM,CAACW,MAA3B;AAEA,UAAIsB,IAAY,GAAGjC,MAAM,CAAC,CAAD,CAAN,CAAUmB,CAA7B;AACA,UAAIe,IAAY,GAAGlC,MAAM,CAAC,CAAD,CAAN,CAAUoB,CAA7B;AAEA,UAAIe,IAAY,GAAGnC,MAAM,CAAC,CAAD,CAAN,CAAUmB,CAA7B;AACA,UAAIiB,IAAY,GAAGpC,MAAM,CAAC,CAAD,CAAN,CAAUoB,CAA7B;;AAEA,WAAK,IAAIR,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGa,GAA5B,EAAiCb,CAAC,EAAlC,EAAsC;AACpC,YAAMyB,KAAa,GAAGrC,MAAM,CAACY,CAAD,CAA5B;AAEA,YAAIyB,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,IAAIxC,OAAJ,CAAY,KAAKI,SAAL,CAAeqC,KAAf,GAAuBC,GAAvB,CAA2B,IAAIxC,kBAAJ,CAAWkC,IAAX,EAAiBC,IAAjB,CAA3B,CAAZ,EAAgE,CACrE,IAAInC,kBAAJ,EADqE,EACvD,IAAIA,kBAAJ,CAAWoC,IAAI,GAAGF,IAAlB,EAAwB,CAAxB,CADuD,EAErE,IAAIlC,kBAAJ,CAAWoC,IAAI,GAAGF,IAAlB,EAAwBG,IAAI,GAAGF,IAA/B,CAFqE,EAE/B,IAAInC,kBAAJ,CAAW,CAAX,EAAcqC,IAAI,GAAGF,IAArB,CAF+B,CAAhE,CAAP;AAID;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,uBAAsB;AACpB,UAAMlC,MAAqB,GAAG,KAAKa,UAAnC;AACA,UAAMY,GAAW,GAAGzB,MAAM,CAACW,MAA3B;AAEA,UAAI6B,EAAU,GAAG,CAAjB;AACA,UAAIC,EAAU,GAAG,CAAjB;AACA,UAAIC,EAAU,GAAG,CAAjB;;AAEA,WAAK,IAAI9B,CAAS,GAAG,CAArB,EAAwBA,CAAC,GAAGa,GAA5B,EAAiCb,CAAC,EAAlC,EAAsC;AACpC,YAAMI,EAAU,GAAGhB,MAAM,CAACY,CAAD,CAAzB;AACA,YAAMK,EAAU,GAAGL,CAAC,KAAKa,GAAG,GAAG,CAAZ,GAAgBzB,MAAM,CAAC,CAAD,CAAtB,GAA4BA,MAAM,CAACY,CAAC,GAAG,CAAL,CAArD,CAFoC,CAE0B;;AAE9D,YAAM+B,CAAS,GAAG3B,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAZ,GAAoBA,EAAE,CAAC,GAAD,CAAF,GAAUD,EAAE,CAAC,GAAD,CAAlD;AAEAwB,QAAAA,EAAE,IAAI,CAACxB,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAb,IAAsB0B,CAA5B;AACAF,QAAAA,EAAE,IAAI,CAACzB,EAAE,CAAC,GAAD,CAAF,GAAUC,EAAE,CAAC,GAAD,CAAb,IAAsB0B,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,IAAI3C,kBAAJ,CAAWyC,EAAX,EAAeC,EAAf,CAAP;AACD","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}"]}

@@ -63,4 +63,35 @@ 'use strict';

_createClass(Vector, [{
key: "copy",
key: "x",
get: function get() {
return this._x;
}
/**
* Returns the y value of this vector.
*
* @returns {number}
*/
,
set:
/**
* Sets a new x value for this vector.
*
* @param {number} x The new x value for this vector.
*/
function set(x) {
this._x = x;
}
/**
* Sets a new y value for this vector.
*
* @param {number} y The new y value for this vector.
*/
}, {
key: "y",
get: function get() {
return this._y;
},
set: function set(y) {
this._y = y;
}
/**

@@ -73,2 +104,5 @@ * Copy the values of another Vector into this one.

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

@@ -309,36 +343,2 @@ this._x = other.x;

}
}, {
key: "x",
get: function get() {
return this._x;
}
/**
* Returns the y value of this vector.
*
* @returns {number}
*/
,
/**
* Sets a new x value for this vector.
*
* @param {number} x The new x value for this vector.
*/
set: function set(x) {
this._x = x;
}
/**
* Sets a new y value for this vector.
*
* @param {number} y The new y value for this vector.
*/
}, {
key: "y",
get: function get() {
return this._y;
},
set: function set(y) {
this._y = y;
}
}]);

@@ -350,2 +350,2 @@

exports["default"] = Vector;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/geometry/vector.ts"],"names":["Vector","x","y","_x","_y","other","angle","Math","cos","sin","d","len","amt","dot","len2","axis","project","scale","projectN","sqrt"],"mappings":"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","sourcesContent":["'use strict'\r\n\r\n/**\r\n * Represents a vector in two dimensions with `x` and `y` properties.\r\n * \r\n * Create a new Vector, optionally passing in the `x` and `y` coordinates. If a coordinate is not specified, it will be set to `0`.\r\n */\r\nexport default class Vector {\r\n  /**\r\n   * The x coordinate of this vector.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _x: number = 0;\r\n\r\n  /**\r\n   * The y coordinate of this vector.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _y: number = 0;\r\n\r\n  /**\r\n   * @param {number} [x=0] The x coordinate of this vector.\r\n   * @param {number} [y=0] The y coordinate of this vector.\r\n   */\r\n  constructor(x: number = 0, y: number = 0) {\r\n    this._x = x;\r\n\r\n    this._y = y;\r\n  }\r\n\r\n  /**\r\n   * Returns the x value of this vector.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get x(): number { return this._x; }\r\n\r\n  /**\r\n   * Returns the y value of this vector.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get y(): number { return this._y; }\r\n\r\n  /**\r\n   * Sets a new x value for this vector.\r\n   * \r\n   * @param {number} x The new x value for this vector.\r\n   */\r\n  set x(x: number) { this._x = x; }\r\n\r\n  /**\r\n   * Sets a new y value for this vector.\r\n   * \r\n   * @param {number} y The new y value for this vector.\r\n   */\r\n  set y(y: number) { this._y = y; }\r\n\r\n  /**\r\n   * Copy the values of another Vector into this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  copy(other: Vector): Vector {\r\n    this._x = other.x;\r\n    this._y = other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Create a new Vector with the same coordinates as the one.\r\n   * \r\n   * @returns {Vector} The new cloned Vector.\r\n   */\r\n  clone(): Vector {\r\n    return new Vector(this.x, this.y);\r\n  }\r\n\r\n  /**\r\n   * Change this Vector to be perpendicular to what it was before.\r\n   * \r\n   * Effectively this rotates it 90 degrees in a clockwise direction.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  perp(): Vector {\r\n    const x: number = this.x;\r\n\r\n    this._x = this.y;\r\n    this._y = -x;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Rotate this Vector (counter-clockwise) by the specified angle (in radians).\r\n   * \r\n   * @param {number} angle The angle to rotate (in radians).\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  rotate(angle: number): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this._x = x * Math.cos(angle) - y * Math.sin(angle);\r\n    this._y = x * Math.sin(angle) + y * Math.cos(angle);\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reverse this Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reverse(): Vector {\r\n    this._x = -this.x;\r\n    this._y = -this.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Normalize this vector (make it have a length of `1`).\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  normalize(): Vector {\r\n    const d: number = this.len();\r\n\r\n    if (d > 0) {\r\n      this._x = this.x / d;\r\n      this._y = this.y / d;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Add another Vector to this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  add(other: Vector): Vector {\r\n    this._x += other.x;\r\n    this._y += other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Subtract another Vector from this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  sub(other: Vector): Vector {\r\n    this._x -= other.x;\r\n    this._y -= other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Scale this Vector.\r\n   * \r\n   * An independent scaling factor can be provided for each axis, or a single scaling factor will scale both `x` and `y`.\r\n   * \r\n   * @param {number} x The scaling factor in the x direction.\r\n   * @param {number} [y] The scaling factor in the y direction.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  scale(x: number, y?: number): Vector {\r\n    this._x *= x;\r\n    this._y *= typeof y != 'undefined' ? y : x;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Project this Vector onto another Vector.\r\n   * \r\n   * @param {Vector} other The Vector to project onto.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  project(other: Vector): Vector {\r\n    const amt: number = this.dot(other) / other.len2();\r\n\r\n    this._x = amt * other.x;\r\n    this._y = amt * other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Project this Vector onto a Vector of unit length.\r\n   * \r\n   * This is slightly more efficient than `project` when dealing with unit vectors.\r\n   * \r\n   * @param {Vector} other The unit vector to project onto.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  projectN(other: Vector): Vector {\r\n    const amt: number = this.dot(other);\r\n\r\n    this._x = amt * other.x;\r\n    this._y = amt * other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reflect this Vector on an arbitrary axis.\r\n   * \r\n   * @param {Vector} axis The Vector representing the axis.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reflect(axis: Vector): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this.project(axis).scale(2);\r\n\r\n    this._x -= x;\r\n    this._y -= y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reflect this Vector on an arbitrary axis.\r\n   * \r\n   * This is slightly more efficient than `reflect` when dealing with an axis that is a unit vector.\r\n   * \r\n   * @param {Vector} axis The Vector representing the axis.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reflectN(axis: Vector): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this.projectN(axis).scale(2);\r\n\r\n    this._x -= x;\r\n    this._y -= y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Get the dot product of this Vector and another.\r\n   * \r\n   * @param {Vector} other The Vector to dot this one against.\r\n   * \r\n   * @returns {number} Returns the dot product of this vector.\r\n   */\r\n  dot(other: Vector): number {\r\n    return this.x * other.x + this.y * other.y;\r\n  }\r\n\r\n  /**\r\n   * Get the squared length of this Vector.\r\n   * \r\n   * @returns {number} Returns the squared length of this vector.\r\n   */\r\n  len2(): number {\r\n    return this.dot(this);\r\n  }\r\n\r\n  /**\r\n   * Get the length of this Vector.\r\n   * \r\n   * @returns {number} Returns the length of this vector.\r\n   */\r\n  len(): number {\r\n    return Math.sqrt(this.len2());\r\n  }\r\n}"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/geometry/vector.ts"],"names":["Vector","x","y","_x","_y","other","angle","Math","cos","sin","d","len","amt","dot","len2","axis","project","scale","projectN","sqrt"],"mappings":"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","sourcesContent":["'use strict'\r\n\r\n/**\r\n * Represents a vector in two dimensions with `x` and `y` properties.\r\n * \r\n * Create a new Vector, optionally passing in the `x` and `y` coordinates. If a coordinate is not specified, it will be set to `0`.\r\n */\r\nexport default class Vector {\r\n  /**\r\n   * The x coordinate of this vector.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _x: number = 0;\r\n\r\n  /**\r\n   * The y coordinate of this vector.\r\n   * \r\n   * @private\r\n   * \r\n   * @property {number}\r\n   */\r\n  private _y: number = 0;\r\n\r\n  /**\r\n   * @param {number} [x=0] The x coordinate of this vector.\r\n   * @param {number} [y=0] The y coordinate of this vector.\r\n   */\r\n  constructor(x: number = 0, y: number = 0) {\r\n    this._x = x;\r\n\r\n    this._y = y;\r\n  }\r\n\r\n  /**\r\n   * Returns the x value of this vector.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get x(): number { return this._x; }\r\n\r\n  /**\r\n   * Returns the y value of this vector.\r\n   * \r\n   * @returns {number}\r\n   */\r\n  get y(): number { return this._y; }\r\n\r\n  /**\r\n   * Sets a new x value for this vector.\r\n   * \r\n   * @param {number} x The new x value for this vector.\r\n   */\r\n  set x(x: number) { this._x = x; }\r\n\r\n  /**\r\n   * Sets a new y value for this vector.\r\n   * \r\n   * @param {number} y The new y value for this vector.\r\n   */\r\n  set y(y: number) { this._y = y; }\r\n\r\n  /**\r\n   * Copy the values of another Vector into this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  copy(other: Vector): Vector {\r\n    this._x = other.x;\r\n    this._y = other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Create a new Vector with the same coordinates as the one.\r\n   * \r\n   * @returns {Vector} The new cloned Vector.\r\n   */\r\n  clone(): Vector {\r\n    return new Vector(this.x, this.y);\r\n  }\r\n\r\n  /**\r\n   * Change this Vector to be perpendicular to what it was before.\r\n   * \r\n   * Effectively this rotates it 90 degrees in a clockwise direction.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  perp(): Vector {\r\n    const x: number = this.x;\r\n\r\n    this._x = this.y;\r\n    this._y = -x;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Rotate this Vector (counter-clockwise) by the specified angle (in radians).\r\n   * \r\n   * @param {number} angle The angle to rotate (in radians).\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  rotate(angle: number): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this._x = x * Math.cos(angle) - y * Math.sin(angle);\r\n    this._y = x * Math.sin(angle) + y * Math.cos(angle);\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reverse this Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reverse(): Vector {\r\n    this._x = -this.x;\r\n    this._y = -this.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Normalize this vector (make it have a length of `1`).\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  normalize(): Vector {\r\n    const d: number = this.len();\r\n\r\n    if (d > 0) {\r\n      this._x = this.x / d;\r\n      this._y = this.y / d;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Add another Vector to this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  add(other: Vector): Vector {\r\n    this._x += other.x;\r\n    this._y += other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Subtract another Vector from this one.\r\n   * \r\n   * @param {Vector} other The other Vector.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  sub(other: Vector): Vector {\r\n    this._x -= other.x;\r\n    this._y -= other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Scale this Vector.\r\n   * \r\n   * An independent scaling factor can be provided for each axis, or a single scaling factor will scale both `x` and `y`.\r\n   * \r\n   * @param {number} x The scaling factor in the x direction.\r\n   * @param {number} [y] The scaling factor in the y direction.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  scale(x: number, y?: number): Vector {\r\n    this._x *= x;\r\n    this._y *= typeof y != 'undefined' ? y : x;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Project this Vector onto another Vector.\r\n   * \r\n   * @param {Vector} other The Vector to project onto.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  project(other: Vector): Vector {\r\n    const amt: number = this.dot(other) / other.len2();\r\n\r\n    this._x = amt * other.x;\r\n    this._y = amt * other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Project this Vector onto a Vector of unit length.\r\n   * \r\n   * This is slightly more efficient than `project` when dealing with unit vectors.\r\n   * \r\n   * @param {Vector} other The unit vector to project onto.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  projectN(other: Vector): Vector {\r\n    const amt: number = this.dot(other);\r\n\r\n    this._x = amt * other.x;\r\n    this._y = amt * other.y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reflect this Vector on an arbitrary axis.\r\n   * \r\n   * @param {Vector} axis The Vector representing the axis.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reflect(axis: Vector): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this.project(axis).scale(2);\r\n\r\n    this._x -= x;\r\n    this._y -= y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Reflect this Vector on an arbitrary axis.\r\n   * \r\n   * This is slightly more efficient than `reflect` when dealing with an axis that is a unit vector.\r\n   * \r\n   * @param {Vector} axis The Vector representing the axis.\r\n   * \r\n   * @returns {Vector} Returns this for chaining.\r\n   */\r\n  reflectN(axis: Vector): Vector {\r\n    const x: number = this.x;\r\n    const y: number = this.y;\r\n\r\n    this.projectN(axis).scale(2);\r\n\r\n    this._x -= x;\r\n    this._y -= y;\r\n\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Get the dot product of this Vector and another.\r\n   * \r\n   * @param {Vector} other The Vector to dot this one against.\r\n   * \r\n   * @returns {number} Returns the dot product of this vector.\r\n   */\r\n  dot(other: Vector): number {\r\n    return this.x * other.x + this.y * other.y;\r\n  }\r\n\r\n  /**\r\n   * Get the squared length of this Vector.\r\n   * \r\n   * @returns {number} Returns the squared length of this vector.\r\n   */\r\n  len2(): number {\r\n    return this.dot(this);\r\n  }\r\n\r\n  /**\r\n   * Get the length of this Vector.\r\n   * \r\n   * @returns {number} Returns the length of this vector.\r\n   */\r\n  len(): number {\r\n    return Math.sqrt(this.len2());\r\n  }\r\n}"]}

@@ -0,1 +1,4 @@

## 1.1.1 / 2021-02-20
- [MISC] Updated dependencies to their latest versions.
## 1.1.0 / 2020-09-30

@@ -2,0 +5,0 @@ - [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.

@@ -80,4 +80,35 @@ function _classCallCheck(instance, Constructor) {

_createClass(Vector, [{
key: "copy",
key: "x",
get: function get() {
return this._x;
}
/**
* Returns the y value of this vector.
*
* @returns {number}
*/
,
set:
/**
* Sets a new x value for this vector.
*
* @param {number} x The new x value for this vector.
*/
function set(x) {
this._x = x;
}
/**
* Sets a new y value for this vector.
*
* @param {number} y The new y value for this vector.
*/
}, {
key: "y",
get: function get() {
return this._y;
},
set: function set(y) {
this._y = y;
}
/**

@@ -90,2 +121,5 @@ * Copy the values of another Vector into this one.

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

@@ -326,36 +360,2 @@ this._x = other.x;

}
}, {
key: "x",
get: function get() {
return this._x;
}
/**
* Returns the y value of this vector.
*
* @returns {number}
*/
,
/**
* Sets a new x value for this vector.
*
* @param {number} x The new x value for this vector.
*/
set: function set(x) {
this._x = x;
}
/**
* Sets a new y value for this vector.
*
* @param {number} y The new y value for this vector.
*/
}, {
key: "y",
get: function get() {
return this._y;
},
set: function set(y) {
this._y = y;
}
}]);

@@ -480,5 +480,106 @@

_createClass(Polygon, [{
key: "setPoints",
key: "position",
get: function get() {
return this._position;
}
/**
* **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.
*
* @returns {Array<Vector>}
*/
}, {
key: "points",
get: function get() {
return this._points;
}
/**
* 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.
*
* @returns {Array<Vector>}
*/
}, {
key: "calcPoints",
get: function get() {
return this._calcPoints;
}
/**
* Returns the offset of this polygon.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Returns the angle of this polygon.
*
* @returns {number}
*/
}, {
key: "angle",
get: function get() {
return this._angle;
}
/**
* Returns the edges of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "edges",
get: function get() {
return this._edges;
}
/**
* Returns the normals of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "normals",
get: function get() {
return this._normals;
}
/**
* Set the points of the polygon. Any consecutive duplicate points will be combined.

@@ -494,2 +595,5 @@ *

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

@@ -727,106 +831,2 @@ // Only re-allocate if this is a new polygon or the number of points has changed.

}
}, {
key: "position",
get: function get() {
return this._position;
}
/**
* **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.
*
* @returns {Array<Vector>}
*/
}, {
key: "points",
get: function get() {
return this._points;
}
/**
* 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.
*
* @returns {Array<Vector>}
*/
}, {
key: "calcPoints",
get: function get() {
return this._calcPoints;
}
/**
* Returns the offset of this polygon.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Returns the angle of this polygon.
*
* @returns {number}
*/
}, {
key: "angle",
get: function get() {
return this._angle;
}
/**
* Returns the edges of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "edges",
get: function get() {
return this._edges;
}
/**
* Returns the normals of this polygon.
*
* @returns {Array<Vector>}
*/
}, {
key: "normals",
get: function get() {
return this._normals;
}
}]);

@@ -968,5 +968,38 @@

_createClass(Circle, [{
key: "translate",
key: "position",
get: function get() {
return this._position;
}
/**
* Returns the radius of this circle.
*
* @returns {number}
*/
}, {
key: "radius",
get: function get() {
return this._radius;
}
/**
* Returns the offset of this circle.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Set a new offset for this circle.
*
* @param {Vector} offset The new offset for this circle.
*/
,
set: function set(offset) {
this._offset = offset;
}
/**
* Translate the center of the cirlc.e

@@ -976,2 +1009,5 @@ *

*/
}, {
key: "translate",
value: function translate(x, y) {

@@ -1010,38 +1046,2 @@ this._position.x += x;

}
}, {
key: "position",
get: function get() {
return this._position;
}
/**
* Returns the radius of this circle.
*
* @returns {number}
*/
}, {
key: "radius",
get: function get() {
return this._radius;
}
/**
* Returns the offset of this circle.
*
* @returns {Vector}
*/
}, {
key: "offset",
get: function get() {
return this._offset;
}
/**
* Set a new offset for this circle.
*
* @param {Vector} offset The new offset for this circle.
*/
,
set: function set(offset) {
this._offset = offset;
}
}]);

@@ -1048,0 +1048,0 @@

{
"name": "collider2d",
"version": "1.1.0",
"version": "1.1.1",
"description": "A 2D collision checker for modern JavaScript games.",

@@ -46,4 +46,4 @@ "main": "build/index.js",

"@babel/preset-typescript": "^7.10.4",
"@rollup/plugin-commonjs": "^15.1.0",
"@rollup/plugin-node-resolve": "^9.0.0",
"@rollup/plugin-commonjs": "^17.1.0",
"@rollup/plugin-node-resolve": "^11.2.0",
"chai": "^4.2.0",

@@ -50,0 +50,0 @@ "mocha": "^8.1.3",

Sorry, the diff of this file is too big to display

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