UNPKG

ngx-spine

Version:

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

361 lines 34.5 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 { Pool } from "../core/Utils"; export class Input { /** * @param {?} element */ constructor(element) { this.lastX = 0; this.lastY = 0; this.buttonDown = false; this.currTouch = null; this.touchesPool = new Pool((/** * @return {?} */ () => { return new Touch(0, 0, 0); })); this.listeners = new Array(); this.element = element; this.setupCallbacks(element); } /** * @private * @param {?} element * @return {?} */ setupCallbacks(element) { /** @type {?} */ let mouseDown = (/** * @param {?} ev * @return {?} */ (ev) => { if (ev instanceof MouseEvent) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = ev.clientX - rect.left; /** @type {?} */ let y = ev.clientY - rect.top; /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].down(x, y); } this.lastX = x; this.lastY = y; this.buttonDown = true; document.addEventListener("mousemove", mouseMove); document.addEventListener("mouseup", mouseUp); } }); /** @type {?} */ let mouseMove = (/** * @param {?} ev * @return {?} */ (ev) => { if (ev instanceof MouseEvent) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = ev.clientX - rect.left; /** @type {?} */ let y = ev.clientY - rect.top; /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { if (this.buttonDown) { listeners[i].dragged(x, y); } else { listeners[i].moved(x, y); } } this.lastX = x; this.lastY = y; } }); /** @type {?} */ let mouseUp = (/** * @param {?} ev * @return {?} */ (ev) => { if (ev instanceof MouseEvent) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = ev.clientX - rect.left; /** @type {?} */ let y = ev.clientY - rect.top; /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].up(x, y); } this.lastX = x; this.lastY = y; this.buttonDown = false; document.removeEventListener("mousemove", mouseMove); document.removeEventListener("mouseup", mouseUp); } }); element.addEventListener("mousedown", mouseDown, true); element.addEventListener("mousemove", mouseMove, true); element.addEventListener("mouseup", mouseUp, true); element.addEventListener("touchstart", (/** * @param {?} ev * @return {?} */ (ev) => { if (this.currTouch != null) return; /** @type {?} */ var touches = ev.changedTouches; for (var i = 0; i < touches.length; i++) { /** @type {?} */ var touch = touches[i]; /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = touch.clientX - rect.left; /** @type {?} */ let y = touch.clientY - rect.top; this.currTouch = this.touchesPool.obtain(); this.currTouch.identifier = touch.identifier; this.currTouch.x = x; this.currTouch.y = y; break; } /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].down(this.currTouch.x, this.currTouch.y); } console.log("Start " + this.currTouch.x + ", " + this.currTouch.y); this.lastX = this.currTouch.x; this.lastY = this.currTouch.y; this.buttonDown = true; ev.preventDefault(); }), false); element.addEventListener("touchend", (/** * @param {?} ev * @return {?} */ (ev) => { /** @type {?} */ var touches = ev.changedTouches; for (var i = 0; i < touches.length; i++) { /** @type {?} */ var touch = touches[i]; if (this.currTouch.identifier === touch.identifier) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = (this.currTouch.x = touch.clientX - rect.left); /** @type {?} */ let y = (this.currTouch.y = touch.clientY - rect.top); this.touchesPool.free(this.currTouch); /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].up(x, y); } console.log("End " + x + ", " + y); this.lastX = x; this.lastY = y; this.buttonDown = false; this.currTouch = null; break; } } ev.preventDefault(); }), false); element.addEventListener("touchcancel", (/** * @param {?} ev * @return {?} */ (ev) => { /** @type {?} */ var touches = ev.changedTouches; for (var i = 0; i < touches.length; i++) { /** @type {?} */ var touch = touches[i]; if (this.currTouch.identifier === touch.identifier) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = (this.currTouch.x = touch.clientX - rect.left); /** @type {?} */ let y = (this.currTouch.y = touch.clientY - rect.top); this.touchesPool.free(this.currTouch); /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].up(x, y); } console.log("End " + x + ", " + y); this.lastX = x; this.lastY = y; this.buttonDown = false; this.currTouch = null; break; } } ev.preventDefault(); }), false); element.addEventListener("touchmove", (/** * @param {?} ev * @return {?} */ (ev) => { if (this.currTouch == null) return; /** @type {?} */ var touches = ev.changedTouches; for (var i = 0; i < touches.length; i++) { /** @type {?} */ var touch = touches[i]; if (this.currTouch.identifier === touch.identifier) { /** @type {?} */ let rect = element.getBoundingClientRect(); /** @type {?} */ let x = touch.clientX - rect.left; /** @type {?} */ let y = touch.clientY - rect.top; /** @type {?} */ let listeners = this.listeners; for (let i = 0; i < listeners.length; i++) { listeners[i].dragged(x, y); } console.log("Drag " + x + ", " + y); this.lastX = this.currTouch.x = x; this.lastY = this.currTouch.y = y; break; } } ev.preventDefault(); }), false); } /** * @param {?} listener * @return {?} */ addListener(listener) { this.listeners.push(listener); } /** * @param {?} listener * @return {?} */ removeListener(listener) { /** @type {?} */ let idx = this.listeners.indexOf(listener); if (idx > -1) { this.listeners.splice(idx, 1); } } } if (false) { /** @type {?} */ Input.prototype.element; /** @type {?} */ Input.prototype.lastX; /** @type {?} */ Input.prototype.lastY; /** @type {?} */ Input.prototype.buttonDown; /** @type {?} */ Input.prototype.currTouch; /** @type {?} */ Input.prototype.touchesPool; /** * @type {?} * @private */ Input.prototype.listeners; } export class Touch { /** * @param {?} identifier * @param {?} x * @param {?} y */ constructor(identifier, x, y) { this.identifier = identifier; this.x = x; this.y = y; } } if (false) { /** @type {?} */ Touch.prototype.identifier; /** @type {?} */ Touch.prototype.x; /** @type {?} */ Touch.prototype.y; } /** * @record */ export function InputListener() { } if (false) { /** * @param {?} x * @param {?} y * @return {?} */ InputListener.prototype.down = function (x, y) { }; /** * @param {?} x * @param {?} y * @return {?} */ InputListener.prototype.up = function (x, y) { }; /** * @param {?} x * @param {?} y * @return {?} */ InputListener.prototype.moved = function (x, y) { }; /** * @param {?} x * @param {?} y * @return {?} */ InputListener.prototype.dragged = function (x, y) { }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Input.js","sourceRoot":"ng://ngx-spine/","sources":["lib/spine-ts/webgl/Input.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\n\r\nimport { Pool } from \"../core/Utils\";\r\n\r\nexport class Input {\r\n  element: HTMLElement;\r\n  lastX = 0;\r\n  lastY = 0;\r\n  buttonDown = false;\r\n  currTouch: Touch = null;\r\n  touchesPool = new Pool<Touch>(() => {\r\n    return new Touch(0, 0, 0);\r\n  });\r\n  private listeners = new Array<InputListener>();\r\n  constructor(element: HTMLElement) {\r\n    this.element = element;\r\n    this.setupCallbacks(element);\r\n  }\r\n  private setupCallbacks(element: HTMLElement) {\r\n    let mouseDown = (ev: UIEvent) => {\r\n      if (ev instanceof MouseEvent) {\r\n        let rect = element.getBoundingClientRect();\r\n        let x = ev.clientX - rect.left;\r\n        let y = ev.clientY - rect.top;\r\n        let listeners = this.listeners;\r\n        for (let i = 0; i < listeners.length; i++) {\r\n          listeners[i].down(x, y);\r\n        }\r\n        this.lastX = x;\r\n        this.lastY = y;\r\n        this.buttonDown = true;\r\n        document.addEventListener(\"mousemove\", mouseMove);\r\n        document.addEventListener(\"mouseup\", mouseUp);\r\n      }\r\n    };\r\n    let mouseMove = (ev: UIEvent) => {\r\n      if (ev instanceof MouseEvent) {\r\n        let rect = element.getBoundingClientRect();\r\n        let x = ev.clientX - rect.left;\r\n        let y = ev.clientY - rect.top;\r\n        let listeners = this.listeners;\r\n        for (let i = 0; i < listeners.length; i++) {\r\n          if (this.buttonDown) {\r\n            listeners[i].dragged(x, y);\r\n          } else {\r\n            listeners[i].moved(x, y);\r\n          }\r\n        }\r\n        this.lastX = x;\r\n        this.lastY = y;\r\n      }\r\n    };\r\n    let mouseUp = (ev: UIEvent) => {\r\n      if (ev instanceof MouseEvent) {\r\n        let rect = element.getBoundingClientRect();\r\n        let x = ev.clientX - rect.left;\r\n        let y = ev.clientY - rect.top;\r\n        let listeners = this.listeners;\r\n        for (let i = 0; i < listeners.length; i++) {\r\n          listeners[i].up(x, y);\r\n        }\r\n        this.lastX = x;\r\n        this.lastY = y;\r\n        this.buttonDown = false;\r\n        document.removeEventListener(\"mousemove\", mouseMove);\r\n        document.removeEventListener(\"mouseup\", mouseUp);\r\n      }\r\n    };\r\n    element.addEventListener(\"mousedown\", mouseDown, true);\r\n    element.addEventListener(\"mousemove\", mouseMove, true);\r\n    element.addEventListener(\"mouseup\", mouseUp, true);\r\n    element.addEventListener(\r\n      \"touchstart\",\r\n      (ev: TouchEvent) => {\r\n        if (this.currTouch != null) return;\r\n        var touches = ev.changedTouches;\r\n        for (var i = 0; i < touches.length; i++) {\r\n          var touch = touches[i];\r\n          let rect = element.getBoundingClientRect();\r\n          let x = touch.clientX - rect.left;\r\n          let y = touch.clientY - rect.top;\r\n          this.currTouch = this.touchesPool.obtain();\r\n          this.currTouch.identifier = touch.identifier;\r\n          this.currTouch.x = x;\r\n          this.currTouch.y = y;\r\n          break;\r\n        }\r\n        let listeners = this.listeners;\r\n        for (let i = 0; i < listeners.length; i++) {\r\n          listeners[i].down(this.currTouch.x, this.currTouch.y);\r\n        }\r\n        console.log(\"Start \" + this.currTouch.x + \", \" + this.currTouch.y);\r\n        this.lastX = this.currTouch.x;\r\n        this.lastY = this.currTouch.y;\r\n        this.buttonDown = true;\r\n        ev.preventDefault();\r\n      },\r\n      false\r\n    );\r\n    element.addEventListener(\r\n      \"touchend\",\r\n      (ev: TouchEvent) => {\r\n        var touches = ev.changedTouches;\r\n        for (var i = 0; i < touches.length; i++) {\r\n          var touch = touches[i];\r\n          if (this.currTouch.identifier === touch.identifier) {\r\n            let rect = element.getBoundingClientRect();\r\n            let x = (this.currTouch.x = touch.clientX - rect.left);\r\n            let y = (this.currTouch.y = touch.clientY - rect.top);\r\n            this.touchesPool.free(this.currTouch);\r\n            let listeners = this.listeners;\r\n            for (let i = 0; i < listeners.length; i++) {\r\n              listeners[i].up(x, y);\r\n            }\r\n            console.log(\"End \" + x + \", \" + y);\r\n            this.lastX = x;\r\n            this.lastY = y;\r\n            this.buttonDown = false;\r\n            this.currTouch = null;\r\n            break;\r\n          }\r\n        }\r\n        ev.preventDefault();\r\n      },\r\n      false\r\n    );\r\n    element.addEventListener(\r\n      \"touchcancel\",\r\n      (ev: TouchEvent) => {\r\n        var touches = ev.changedTouches;\r\n        for (var i = 0; i < touches.length; i++) {\r\n          var touch = touches[i];\r\n          if (this.currTouch.identifier === touch.identifier) {\r\n            let rect = element.getBoundingClientRect();\r\n            let x = (this.currTouch.x = touch.clientX - rect.left);\r\n            let y = (this.currTouch.y = touch.clientY - rect.top);\r\n            this.touchesPool.free(this.currTouch);\r\n            let listeners = this.listeners;\r\n            for (let i = 0; i < listeners.length; i++) {\r\n              listeners[i].up(x, y);\r\n            }\r\n            console.log(\"End \" + x + \", \" + y);\r\n            this.lastX = x;\r\n            this.lastY = y;\r\n            this.buttonDown = false;\r\n            this.currTouch = null;\r\n            break;\r\n          }\r\n        }\r\n        ev.preventDefault();\r\n      },\r\n      false\r\n    );\r\n    element.addEventListener(\r\n      \"touchmove\",\r\n      (ev: TouchEvent) => {\r\n        if (this.currTouch == null) return;\r\n        var touches = ev.changedTouches;\r\n        for (var i = 0; i < touches.length; i++) {\r\n          var touch = touches[i];\r\n          if (this.currTouch.identifier === touch.identifier) {\r\n            let rect = element.getBoundingClientRect();\r\n            let x = touch.clientX - rect.left;\r\n            let y = touch.clientY - rect.top;\r\n            let listeners = this.listeners;\r\n            for (let i = 0; i < listeners.length; i++) {\r\n              listeners[i].dragged(x, y);\r\n            }\r\n            console.log(\"Drag \" + x + \", \" + y);\r\n            this.lastX = this.currTouch.x = x;\r\n            this.lastY = this.currTouch.y = y;\r\n            break;\r\n          }\r\n        }\r\n        ev.preventDefault();\r\n      },\r\n      false\r\n    );\r\n  }\r\n  addListener(listener: InputListener) {\r\n    this.listeners.push(listener);\r\n  }\r\n  removeListener(listener: InputListener) {\r\n    let idx = this.listeners.indexOf(listener);\r\n    if (idx > -1) {\r\n      this.listeners.splice(idx, 1);\r\n    }\r\n  }\r\n}\r\nexport class Touch {\r\n  constructor(public identifier: number, public x: number, public y: number) {}\r\n}\r\nexport interface InputListener {\r\n  down(x: number, y: number): void;\r\n  up(x: number, y: number): void;\r\n  moved(x: number, y: number): void;\r\n  dragged(x: number, y: number): void;\r\n}\r\n"]}