ngx-spine
Version:
[](https://travis-ci.org/PoiScript/ngx-spine)
293 lines • 24.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.
*****************************************************************************/
class Assets {
/**
* @param {?} clientId
*/
constructor(clientId) {
this.toLoad = new Array();
this.assets = {};
this.clientId = clientId;
}
/**
* @return {?}
*/
loaded() {
/** @type {?} */
let i = 0;
for (let v in this.assets)
i++;
return i;
}
}
if (false) {
/** @type {?} */
Assets.prototype.clientId;
/** @type {?} */
Assets.prototype.toLoad;
/** @type {?} */
Assets.prototype.assets;
/** @type {?} */
Assets.prototype.textureLoader;
}
export class SharedAssetManager {
/**
* @param {?=} pathPrefix
*/
constructor(pathPrefix = "") {
this.clientAssets = {};
this.queuedAssets = {};
this.rawAssets = {};
this.errors = {};
this.pathPrefix = pathPrefix;
}
/**
* @private
* @param {?} clientId
* @param {?} textureLoader
* @param {?} path
* @return {?}
*/
queueAsset(clientId, textureLoader, path) {
/** @type {?} */
let clientAssets = this.clientAssets[clientId];
if (clientAssets === null || clientAssets === undefined) {
clientAssets = new Assets(clientId);
this.clientAssets[clientId] = clientAssets;
}
if (textureLoader !== null)
clientAssets.textureLoader = textureLoader;
clientAssets.toLoad.push(path);
// check if already queued, in which case we can skip actual
// loading
if (this.queuedAssets[path] === path) {
return false;
}
else {
this.queuedAssets[path] = path;
return true;
}
}
/**
* @param {?} clientId
* @param {?} path
* @return {?}
*/
loadText(clientId, path) {
path = this.pathPrefix + path;
if (!this.queueAsset(clientId, null, path))
return;
/** @type {?} */
let request = new XMLHttpRequest();
request.onreadystatechange = (/**
* @return {?}
*/
() => {
if (request.readyState == XMLHttpRequest.DONE) {
if (request.status >= 200 && request.status < 300) {
this.rawAssets[path] = request.responseText;
}
else {
this.errors[path] = `Couldn't load text ${path}: status ${request.status}, ${request.responseText}`;
}
}
});
request.open("GET", path, true);
request.send();
}
/**
* @param {?} clientId
* @param {?} path
* @return {?}
*/
loadJson(clientId, path) {
path = this.pathPrefix + path;
if (!this.queueAsset(clientId, null, path))
return;
/** @type {?} */
let request = new XMLHttpRequest();
request.onreadystatechange = (/**
* @return {?}
*/
() => {
if (request.readyState == XMLHttpRequest.DONE) {
if (request.status >= 200 && request.status < 300) {
this.rawAssets[path] = JSON.parse(request.responseText);
}
else {
this.errors[path] = `Couldn't load text ${path}: status ${request.status}, ${request.responseText}`;
}
}
});
request.open("GET", path, true);
request.send();
}
/**
* @param {?} clientId
* @param {?} textureLoader
* @param {?} path
* @return {?}
*/
loadTexture(clientId, textureLoader, path) {
path = this.pathPrefix + path;
if (!this.queueAsset(clientId, textureLoader, path))
return;
/** @type {?} */
let img = new Image();
img.src = path;
img.crossOrigin = "anonymous";
img.onload = (/**
* @param {?} ev
* @return {?}
*/
ev => {
this.rawAssets[path] = img;
});
img.onerror = (/**
* @param {?} ev
* @return {?}
*/
ev => {
this.errors[path] = `Couldn't load image ${path}`;
});
}
/**
* @param {?} clientId
* @param {?} path
* @return {?}
*/
get(clientId, path) {
path = this.pathPrefix + path;
/** @type {?} */
let clientAssets = this.clientAssets[clientId];
if (clientAssets === null || clientAssets === undefined)
return true;
return clientAssets.assets[path];
}
/**
* @private
* @param {?} clientAssets
* @return {?}
*/
updateClientAssets(clientAssets) {
for (let i = 0; i < clientAssets.toLoad.length; i++) {
/** @type {?} */
let path = clientAssets.toLoad[i];
/** @type {?} */
let asset = clientAssets.assets[path];
if (asset === null || asset === undefined) {
/** @type {?} */
let rawAsset = this.rawAssets[path];
if (rawAsset === null || rawAsset === undefined)
continue;
if (rawAsset instanceof HTMLImageElement) {
clientAssets.assets[path] = clientAssets.textureLoader((/** @type {?} */ (rawAsset)));
}
else {
clientAssets.assets[path] = rawAsset;
}
}
}
}
/**
* @param {?} clientId
* @return {?}
*/
isLoadingComplete(clientId) {
/** @type {?} */
let clientAssets = this.clientAssets[clientId];
if (clientAssets === null || clientAssets === undefined)
return true;
this.updateClientAssets(clientAssets);
return clientAssets.toLoad.length == clientAssets.loaded();
}
/*remove (clientId: string, path: string) {
path = this.pathPrefix + path;
let asset = this.assets[path];
if ((<any>asset).dispose) (<any>asset).dispose();
this.assets[path] = null;
}
removeAll () {
for (let key in this.assets) {
let asset = this.assets[key];
if ((<any>asset).dispose) (<any>asset).dispose();
}
this.assets = {};
}*/
/**
* @return {?}
*/
dispose() {
// this.removeAll();
}
/**
* @return {?}
*/
hasErrors() {
return Object.keys(this.errors).length > 0;
}
/**
* @return {?}
*/
getErrors() {
return this.errors;
}
}
if (false) {
/**
* @type {?}
* @private
*/
SharedAssetManager.prototype.pathPrefix;
/**
* @type {?}
* @private
*/
SharedAssetManager.prototype.clientAssets;
/**
* @type {?}
* @private
*/
SharedAssetManager.prototype.queuedAssets;
/**
* @type {?}
* @private
*/
SharedAssetManager.prototype.rawAssets;
/**
* @type {?}
* @private
*/
SharedAssetManager.prototype.errors;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SharedAssetManager.js","sourceRoot":"ng://ngx-spine/","sources":["lib/spine-ts/core/SharedAssetManager.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 { Map, Disposable } from \"./Utils\";\r\n\r\nclass Assets {\r\n  clientId: string;\r\n  toLoad = new Array<string>();\r\n  assets: Map<any> = {};\r\n  textureLoader: (image: HTMLImageElement) => any;\r\n  constructor(clientId: string) {\r\n    this.clientId = clientId;\r\n  }\r\n  loaded() {\r\n    let i = 0;\r\n    for (let v in this.assets) i++;\r\n    return i;\r\n  }\r\n}\r\nexport class SharedAssetManager implements Disposable {\r\n  private pathPrefix: string;\r\n  private clientAssets: Map<Assets> = {};\r\n  private queuedAssets: Map<string> = {};\r\n  private rawAssets: Map<any> = {};\r\n  private errors: Map<string> = {};\r\n  constructor(pathPrefix: string = \"\") {\r\n    this.pathPrefix = pathPrefix;\r\n  }\r\n  private queueAsset(\r\n    clientId: string,\r\n    textureLoader: (image: HTMLImageElement) => any,\r\n    path: string\r\n  ): boolean {\r\n    let clientAssets = this.clientAssets[clientId];\r\n    if (clientAssets === null || clientAssets === undefined) {\r\n      clientAssets = new Assets(clientId);\r\n      this.clientAssets[clientId] = clientAssets;\r\n    }\r\n    if (textureLoader !== null) clientAssets.textureLoader = textureLoader;\r\n    clientAssets.toLoad.push(path);\r\n    // check if already queued, in which case we can skip actual\r\n    // loading\r\n    if (this.queuedAssets[path] === path) {\r\n      return false;\r\n    } else {\r\n      this.queuedAssets[path] = path;\r\n      return true;\r\n    }\r\n  }\r\n  loadText(clientId: string, path: string) {\r\n    path = this.pathPrefix + path;\r\n    if (!this.queueAsset(clientId, null, path)) return;\r\n    let request = new XMLHttpRequest();\r\n    request.onreadystatechange = () => {\r\n      if (request.readyState == XMLHttpRequest.DONE) {\r\n        if (request.status >= 200 && request.status < 300) {\r\n          this.rawAssets[path] = request.responseText;\r\n        } else {\r\n          this.errors[\r\n            path\r\n          ] = `Couldn't load text ${path}: status ${request.status}, ${request.responseText}`;\r\n        }\r\n      }\r\n    };\r\n    request.open(\"GET\", path, true);\r\n    request.send();\r\n  }\r\n  loadJson(clientId: string, path: string) {\r\n    path = this.pathPrefix + path;\r\n    if (!this.queueAsset(clientId, null, path)) return;\r\n    let request = new XMLHttpRequest();\r\n    request.onreadystatechange = () => {\r\n      if (request.readyState == XMLHttpRequest.DONE) {\r\n        if (request.status >= 200 && request.status < 300) {\r\n          this.rawAssets[path] = JSON.parse(request.responseText);\r\n        } else {\r\n          this.errors[\r\n            path\r\n          ] = `Couldn't load text ${path}: status ${request.status}, ${request.responseText}`;\r\n        }\r\n      }\r\n    };\r\n    request.open(\"GET\", path, true);\r\n    request.send();\r\n  }\r\n  loadTexture(\r\n    clientId: string,\r\n    textureLoader: (image: HTMLImageElement) => any,\r\n    path: string\r\n  ) {\r\n    path = this.pathPrefix + path;\r\n    if (!this.queueAsset(clientId, textureLoader, path)) return;\r\n    let img = new Image();\r\n    img.src = path;\r\n    img.crossOrigin = \"anonymous\";\r\n    img.onload = ev => {\r\n      this.rawAssets[path] = img;\r\n    };\r\n    img.onerror = ev => {\r\n      this.errors[path] = `Couldn't load image ${path}`;\r\n    };\r\n  }\r\n  get(clientId: string, path: string) {\r\n    path = this.pathPrefix + path;\r\n    let clientAssets = this.clientAssets[clientId];\r\n    if (clientAssets === null || clientAssets === undefined) return true;\r\n    return clientAssets.assets[path];\r\n  }\r\n  private updateClientAssets(clientAssets: Assets): void {\r\n    for (let i = 0; i < clientAssets.toLoad.length; i++) {\r\n      let path = clientAssets.toLoad[i];\r\n      let asset = clientAssets.assets[path];\r\n      if (asset === null || asset === undefined) {\r\n        let rawAsset = this.rawAssets[path];\r\n        if (rawAsset === null || rawAsset === undefined) continue;\r\n        if (rawAsset instanceof HTMLImageElement) {\r\n          clientAssets.assets[path] = clientAssets.textureLoader(<\r\n            HTMLImageElement\r\n          >rawAsset);\r\n        } else {\r\n          clientAssets.assets[path] = rawAsset;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  isLoadingComplete(clientId: string): boolean {\r\n    let clientAssets = this.clientAssets[clientId];\r\n    if (clientAssets === null || clientAssets === undefined) return true;\r\n    this.updateClientAssets(clientAssets);\r\n    return clientAssets.toLoad.length == clientAssets.loaded();\r\n  }\r\n  /*remove (clientId: string, path: string) {\r\n\t\t\tpath = this.pathPrefix + path;\r\n\t\t\tlet asset = this.assets[path];\r\n\t\t\tif ((<any>asset).dispose) (<any>asset).dispose();\r\n\t\t\tthis.assets[path] = null;\r\n\t\t}\r\n\t\tremoveAll () {\r\n\t\t\tfor (let key in this.assets) {\r\n\t\t\t\tlet asset = this.assets[key];\r\n\t\t\t\tif ((<any>asset).dispose) (<any>asset).dispose();\r\n\t\t\t}\r\n\t\t\tthis.assets = {};\r\n\t\t}*/\r\n  dispose() {\r\n    // this.removeAll();\r\n  }\r\n  hasErrors() {\r\n    return Object.keys(this.errors).length > 0;\r\n  }\r\n  getErrors() {\r\n    return this.errors;\r\n  }\r\n}\r\n"]}