ngx-spine
Version:
[](https://travis-ci.org/PoiScript/ngx-spine)
361 lines • 34.5 kB
JavaScript
/**
* @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"]}