UNPKG

ngx-spine

Version:

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

174 lines 16.8 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 { BlendMode } from "../core/BlendMode"; export class ManagedWebGLRenderingContext { /** * @param {?} canvasOrContext * @param {?=} contextConfig */ constructor(canvasOrContext, contextConfig = { alpha: "true" }) { this.restorables = new Array(); if (canvasOrContext instanceof HTMLCanvasElement) { /** @type {?} */ let canvas = canvasOrContext; this.gl = (/** @type {?} */ (((canvas.getContext("webgl", contextConfig) || canvas.getContext("experimental-webgl", contextConfig))))); this.canvas = canvas; canvas.addEventListener("webglcontextlost", (/** * @param {?} e * @return {?} */ (e) => { /** @type {?} */ let event = (/** @type {?} */ (e)); if (e) { e.preventDefault(); } })); canvas.addEventListener("webglcontextrestored", (/** * @param {?} e * @return {?} */ (e) => { for (let i = 0, n = this.restorables.length; i < n; i++) { this.restorables[i].restore(); } })); } else { this.gl = canvasOrContext; this.canvas = (/** @type {?} */ (this.gl.canvas)); } } /** * @param {?} restorable * @return {?} */ addRestorable(restorable) { this.restorables.push(restorable); } /** * @param {?} restorable * @return {?} */ removeRestorable(restorable) { /** @type {?} */ let index = this.restorables.indexOf(restorable); if (index > -1) this.restorables.splice(index, 1); } } if (false) { /** @type {?} */ ManagedWebGLRenderingContext.prototype.canvas; /** @type {?} */ ManagedWebGLRenderingContext.prototype.gl; /** * @type {?} * @private */ ManagedWebGLRenderingContext.prototype.restorables; } export class WebGLBlendModeConverter { /** * @param {?} blendMode * @return {?} */ static getDestGLBlendMode(blendMode) { switch (blendMode) { case BlendMode.Normal: return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA; case BlendMode.Additive: return WebGLBlendModeConverter.ONE; case BlendMode.Multiply: return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA; case BlendMode.Screen: return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA; default: throw new Error("Unknown blend mode: " + blendMode); } } /** * @param {?} blendMode * @param {?=} premultipliedAlpha * @return {?} */ static getSourceGLBlendMode(blendMode, premultipliedAlpha = false) { switch (blendMode) { case BlendMode.Normal: return premultipliedAlpha ? WebGLBlendModeConverter.ONE : WebGLBlendModeConverter.SRC_ALPHA; case BlendMode.Additive: return premultipliedAlpha ? WebGLBlendModeConverter.ONE : WebGLBlendModeConverter.SRC_ALPHA; case BlendMode.Multiply: return WebGLBlendModeConverter.DST_COLOR; case BlendMode.Screen: return WebGLBlendModeConverter.ONE; default: throw new Error("Unknown blend mode: " + blendMode); } } } WebGLBlendModeConverter.ZERO = 0; WebGLBlendModeConverter.ONE = 1; WebGLBlendModeConverter.SRC_COLOR = 0x0300; WebGLBlendModeConverter.ONE_MINUS_SRC_COLOR = 0x0301; WebGLBlendModeConverter.SRC_ALPHA = 0x0302; WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA = 0x0303; WebGLBlendModeConverter.DST_ALPHA = 0x0304; WebGLBlendModeConverter.ONE_MINUS_DST_ALPHA = 0x0305; WebGLBlendModeConverter.DST_COLOR = 0x0306; if (false) { /** @type {?} */ WebGLBlendModeConverter.ZERO; /** @type {?} */ WebGLBlendModeConverter.ONE; /** @type {?} */ WebGLBlendModeConverter.SRC_COLOR; /** @type {?} */ WebGLBlendModeConverter.ONE_MINUS_SRC_COLOR; /** @type {?} */ WebGLBlendModeConverter.SRC_ALPHA; /** @type {?} */ WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA; /** @type {?} */ WebGLBlendModeConverter.DST_ALPHA; /** @type {?} */ WebGLBlendModeConverter.ONE_MINUS_DST_ALPHA; /** @type {?} */ WebGLBlendModeConverter.DST_COLOR; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"WebGL.js","sourceRoot":"ng://ngx-spine/","sources":["lib/spine-ts/webgl/WebGL.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 { Restorable } from \"../core/Utils\";\r\nimport { BlendMode } from \"../core/BlendMode\";\r\n\r\nexport class ManagedWebGLRenderingContext {\r\n  public canvas: HTMLCanvasElement;\r\n  public gl: WebGLRenderingContext;\r\n  private restorables = new Array<Restorable>();\r\n  constructor(\r\n    canvasOrContext: HTMLCanvasElement | WebGLRenderingContext,\r\n    contextConfig: any = { alpha: \"true\" }\r\n  ) {\r\n    if (canvasOrContext instanceof HTMLCanvasElement) {\r\n      let canvas = canvasOrContext;\r\n      this.gl = <WebGLRenderingContext>(\r\n        (canvas.getContext(\"webgl\", contextConfig) ||\r\n          canvas.getContext(\"experimental-webgl\", contextConfig))\r\n      );\r\n      this.canvas = canvas;\r\n      canvas.addEventListener(\"webglcontextlost\", (e: any) => {\r\n        let event = <WebGLContextEvent>e;\r\n        if (e) {\r\n          e.preventDefault();\r\n        }\r\n      });\r\n      canvas.addEventListener(\"webglcontextrestored\", (e: any) => {\r\n        for (let i = 0, n = this.restorables.length; i < n; i++) {\r\n          this.restorables[i].restore();\r\n        }\r\n      });\r\n    } else {\r\n      this.gl = canvasOrContext;\r\n      this.canvas = this.gl.canvas as HTMLCanvasElement;\r\n    }\r\n  }\r\n  addRestorable(restorable: Restorable) {\r\n    this.restorables.push(restorable);\r\n  }\r\n  removeRestorable(restorable: Restorable) {\r\n    let index = this.restorables.indexOf(restorable);\r\n    if (index > -1) this.restorables.splice(index, 1);\r\n  }\r\n}\r\nexport class WebGLBlendModeConverter {\r\n  static ZERO = 0;\r\n  static ONE = 1;\r\n  static SRC_COLOR = 0x0300;\r\n  static ONE_MINUS_SRC_COLOR = 0x0301;\r\n  static SRC_ALPHA = 0x0302;\r\n  static ONE_MINUS_SRC_ALPHA = 0x0303;\r\n  static DST_ALPHA = 0x0304;\r\n  static ONE_MINUS_DST_ALPHA = 0x0305;\r\n  static DST_COLOR = 0x0306;\r\n  static getDestGLBlendMode(blendMode: BlendMode) {\r\n    switch (blendMode) {\r\n      case BlendMode.Normal:\r\n        return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA;\r\n      case BlendMode.Additive:\r\n        return WebGLBlendModeConverter.ONE;\r\n      case BlendMode.Multiply:\r\n        return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA;\r\n      case BlendMode.Screen:\r\n        return WebGLBlendModeConverter.ONE_MINUS_SRC_ALPHA;\r\n      default:\r\n        throw new Error(\"Unknown blend mode: \" + blendMode);\r\n    }\r\n  }\r\n  static getSourceGLBlendMode(\r\n    blendMode: BlendMode,\r\n    premultipliedAlpha: boolean = false\r\n  ) {\r\n    switch (blendMode) {\r\n      case BlendMode.Normal:\r\n        return premultipliedAlpha\r\n          ? WebGLBlendModeConverter.ONE\r\n          : WebGLBlendModeConverter.SRC_ALPHA;\r\n      case BlendMode.Additive:\r\n        return premultipliedAlpha\r\n          ? WebGLBlendModeConverter.ONE\r\n          : WebGLBlendModeConverter.SRC_ALPHA;\r\n      case BlendMode.Multiply:\r\n        return WebGLBlendModeConverter.DST_COLOR;\r\n      case BlendMode.Screen:\r\n        return WebGLBlendModeConverter.ONE;\r\n      default:\r\n        throw new Error(\"Unknown blend mode: \" + blendMode);\r\n    }\r\n  }\r\n}\r\n"]}