UNPKG

ngx-spine

Version:

[![Build Status](https://travis-ci.org/PoiScript/ngx-spine.svg?branch=master)](https://travis-ci.org/PoiScript/ngx-spine)

155 lines 14.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /****************************************************************************** * Spine Runtimes License Agreement * Last updated May 1, 2019. Replaces all prior versions. * * Copyright (c) 2013-2019, Esoteric Software LLC * * Integration of the Spine Runtimes into software or otherwise creating * derivative works of the Spine Runtimes is permitted under the terms and * conditions of Section 2 of the Spine Editor License Agreement: * http://esotericsoftware.com/spine-editor-license * * Otherwise, it is permitted to integrate the Spine Runtimes into software * or otherwise create derivative works of the Spine Runtimes (collectively, * "Products"), provided that each user of the Products must obtain their own * Spine Editor license and redistribution of the Products in any form must * include this license and copyright notice. * * THIS SOFTWARE IS PROVIDED BY ESOTERIC SOFTWARE LLC "AS IS" AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN * NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, BUSINESS * INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *****************************************************************************/ import { Vector3 } from "./Vector3"; import { Matrix4 } from "./Matrix4"; var OrthoCamera = /** @class */ (function () { function OrthoCamera(viewportWidth, viewportHeight) { this.position = new Vector3(0, 0, 0); this.direction = new Vector3(0, 0, -1); this.up = new Vector3(0, 1, 0); this.near = 0; this.far = 100; this.zoom = 1; this.viewportWidth = 0; this.viewportHeight = 0; this.projectionView = new Matrix4(); this.inverseProjectionView = new Matrix4(); this.projection = new Matrix4(); this.view = new Matrix4(); this.tmp = new Vector3(); this.viewportWidth = viewportWidth; this.viewportHeight = viewportHeight; this.update(); } /** * @return {?} */ OrthoCamera.prototype.update = /** * @return {?} */ function () { /** @type {?} */ var projection = this.projection; /** @type {?} */ var view = this.view; /** @type {?} */ var projectionView = this.projectionView; /** @type {?} */ var inverseProjectionView = this.inverseProjectionView; /** @type {?} */ var zoom = this.zoom; /** @type {?} */ var viewportWidth = this.viewportWidth; /** @type {?} */ var viewportHeight = this.viewportHeight; projection.ortho(zoom * (-viewportWidth / 2), zoom * (viewportWidth / 2), zoom * (-viewportHeight / 2), zoom * (viewportHeight / 2), this.near, this.far); view.lookAt(this.position, this.direction, this.up); projectionView.set(projection.values); projectionView.multiply(view); inverseProjectionView.set(projectionView.values).invert(); }; /** * @param {?} screenCoords * @param {?} screenWidth * @param {?} screenHeight * @return {?} */ OrthoCamera.prototype.screenToWorld = /** * @param {?} screenCoords * @param {?} screenWidth * @param {?} screenHeight * @return {?} */ function (screenCoords, screenWidth, screenHeight) { /** @type {?} */ var x = screenCoords.x; /** @type {?} */ var y = screenHeight - screenCoords.y - 1; /** @type {?} */ var tmp = this.tmp; tmp.x = (2 * x) / screenWidth - 1; tmp.y = (2 * y) / screenHeight - 1; tmp.z = 2 * screenCoords.z - 1; tmp.project(this.inverseProjectionView); screenCoords.set(tmp.x, tmp.y, tmp.z); return screenCoords; }; /** * @param {?} viewportWidth * @param {?} viewportHeight * @return {?} */ OrthoCamera.prototype.setViewport = /** * @param {?} viewportWidth * @param {?} viewportHeight * @return {?} */ function (viewportWidth, viewportHeight) { this.viewportWidth = viewportWidth; this.viewportHeight = viewportHeight; }; return OrthoCamera; }()); export { OrthoCamera }; if (false) { /** @type {?} */ OrthoCamera.prototype.position; /** @type {?} */ OrthoCamera.prototype.direction; /** @type {?} */ OrthoCamera.prototype.up; /** @type {?} */ OrthoCamera.prototype.near; /** @type {?} */ OrthoCamera.prototype.far; /** @type {?} */ OrthoCamera.prototype.zoom; /** @type {?} */ OrthoCamera.prototype.viewportWidth; /** @type {?} */ OrthoCamera.prototype.viewportHeight; /** @type {?} */ OrthoCamera.prototype.projectionView; /** @type {?} */ OrthoCamera.prototype.inverseProjectionView; /** @type {?} */ OrthoCamera.prototype.projection; /** @type {?} */ OrthoCamera.prototype.view; /** * @type {?} * @private */ OrthoCamera.prototype.tmp; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Camera.js","sourceRoot":"ng://ngx-spine/","sources":["lib/spine-ts/webgl/Camera.ts"],"names":[],"mappings":"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","sourcesContent":["/******************************************************************************\r\n * Spine Runtimes License Agreement\r\n * Last updated May 1, 2019. Replaces all prior versions.\r\n *\r\n * Copyright (c) 2013-2019, Esoteric Software LLC\r\n *\r\n * Integration of the Spine Runtimes into software or otherwise creating\r\n * derivative works of the Spine Runtimes is permitted under the terms and\r\n * conditions of Section 2 of the Spine Editor License Agreement:\r\n * http://esotericsoftware.com/spine-editor-license\r\n *\r\n * Otherwise, it is permitted to integrate the Spine Runtimes into software\r\n * or otherwise create derivative works of the Spine Runtimes (collectively,\r\n * \"Products\"), provided that each user of the Products must obtain their own\r\n * Spine Editor license and redistribution of the Products in any form must\r\n * include this license and copyright notice.\r\n *\r\n * THIS SOFTWARE IS PROVIDED BY ESOTERIC SOFTWARE LLC \"AS IS\" AND ANY EXPRESS\r\n * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES\r\n * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN\r\n * NO EVENT SHALL ESOTERIC SOFTWARE LLC BE LIABLE FOR ANY DIRECT, INDIRECT,\r\n * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\r\n * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, BUSINESS\r\n * INTERRUPTION, OR LOSS OF USE, DATA, OR PROFITS) HOWEVER CAUSED AND ON ANY\r\n * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\r\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\r\n * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r\n *****************************************************************************/\r\nimport { Vector3 } from \"./Vector3\";\r\nimport { Matrix4 } from \"./Matrix4\";\r\n\r\nexport class OrthoCamera {\r\n  position = new Vector3(0, 0, 0);\r\n  direction = new Vector3(0, 0, -1);\r\n  up = new Vector3(0, 1, 0);\r\n  near = 0;\r\n  far = 100;\r\n  zoom = 1;\r\n  viewportWidth = 0;\r\n  viewportHeight = 0;\r\n  projectionView = new Matrix4();\r\n  inverseProjectionView = new Matrix4();\r\n  projection = new Matrix4();\r\n  view = new Matrix4();\r\n  private tmp = new Vector3();\r\n  constructor(viewportWidth: number, viewportHeight: number) {\r\n    this.viewportWidth = viewportWidth;\r\n    this.viewportHeight = viewportHeight;\r\n    this.update();\r\n  }\r\n  update() {\r\n    let projection = this.projection;\r\n    let view = this.view;\r\n    let projectionView = this.projectionView;\r\n    let inverseProjectionView = this.inverseProjectionView;\r\n    let zoom = this.zoom,\r\n      viewportWidth = this.viewportWidth,\r\n      viewportHeight = this.viewportHeight;\r\n    projection.ortho(\r\n      zoom * (-viewportWidth / 2),\r\n      zoom * (viewportWidth / 2),\r\n      zoom * (-viewportHeight / 2),\r\n      zoom * (viewportHeight / 2),\r\n      this.near,\r\n      this.far\r\n    );\r\n    view.lookAt(this.position, this.direction, this.up);\r\n    projectionView.set(projection.values);\r\n    projectionView.multiply(view);\r\n    inverseProjectionView.set(projectionView.values).invert();\r\n  }\r\n  screenToWorld(\r\n    screenCoords: Vector3,\r\n    screenWidth: number,\r\n    screenHeight: number\r\n  ) {\r\n    let x = screenCoords.x,\r\n      y = screenHeight - screenCoords.y - 1;\r\n    let tmp = this.tmp;\r\n    tmp.x = (2 * x) / screenWidth - 1;\r\n    tmp.y = (2 * y) / screenHeight - 1;\r\n    tmp.z = 2 * screenCoords.z - 1;\r\n    tmp.project(this.inverseProjectionView);\r\n    screenCoords.set(tmp.x, tmp.y, tmp.z);\r\n    return screenCoords;\r\n  }\r\n  setViewport(viewportWidth: number, viewportHeight: number) {\r\n    this.viewportWidth = viewportWidth;\r\n    this.viewportHeight = viewportHeight;\r\n  }\r\n}\r\n"]}