Merge branch 'main' into dev

This commit is contained in:
Bill 2022-03-02 20:49:21 -05:00
commit 4e8e65ec28
607 changed files with 11990 additions and 8120 deletions

View File

@ -24,6 +24,9 @@
"SwitchCase": 1
}
],
"no-multi-spaces": [
"error"
],
"no-trailing-spaces": [
"error",
{

View File

@ -1,2 +1,17 @@
# Nitro Renderer
nitro-renderer is a Javascript library for rendering Nitro in the browser using PixiJS
## Installation
npm
```
npm install @nitrots/nitro-renderer
```
yarn
```
yarn add @nitrots/nitro-renderer
```

3050
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,30 +1,39 @@
{
"name": "@nitrots/nitro-renderer",
"version": "1.0.0",
"description": "Javascript library for rendering Nitro in the browser using PixiJS",
"version": "1.1.5",
"publishConfig": {
"access": "public"
},
"repository": {
"type": "git",
"url": "https://git.krews.org/nitro/nitro-renderer"
"url": "https://git.krews.org/nitro/nitro-renderer.git"
},
"main": "./index.ts",
"license": "GPL-3.0",
"bugs": {
"url": "https://git.krews.org/nitro/nitro-renderer/issues"
},
"homepage": "https://git.krews.org/nitro/nitro-renderer",
"type": "module",
"scripts": {
"compile": "tsc --project ./tsconfig.json",
"eslint": "eslint ./src --fix"
"eslint": "eslint ./src --fix",
"postinstall": "node ./post-install.js"
},
"private": true,
"dependencies": {
"@pixi/canvas-renderer": "^6.1.3",
"@pixi/extract": "^6.1.3",
"@pixi/canvas-renderer": "^6.2.2",
"@pixi/extract": "^6.2.2",
"@pixi/filter-adjustment": "^4.1.3",
"@pixi/tilemap": "^3.2.2",
"pako": "^2.0.4",
"pixi.js": "^6.1.3",
"tslib": "^2.3.1"
"pixi.js": "^6.2.2"
},
"devDependencies": {
"@types/pako": "^1.0.2",
"@typescript-eslint/eslint-plugin": "^4.33.0",
"@typescript-eslint/parser": "^4.33.0",
"eslint": "^7.32.0",
"typescript": "^4.4.4"
"@types/pako": "^1.0.3",
"@typescript-eslint/eslint-plugin": "^5.13.0",
"@typescript-eslint/parser": "^5.13.0",
"eslint": "^8.10.0",
"tslib": "^2.3.1",
"typescript": "~4.4.4"
}
}

34
post-install.js Normal file
View File

@ -0,0 +1,34 @@
import { request as httpsRequest } from 'https';
function install()
{
try
{
const params = {};
params['packageName'] = process.env.npm_package_name;
params['packageVersion'] = process.env.npm_package_version;
const data = JSON.stringify(params);
const request = httpsRequest({
hostname: 'install.nitrots.co',
port: 443,
path: '/collect',
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Content-Length': data.length
}
});
request.write(data);
request.end();
}
catch (e)
{
//
}
}
install();

View File

@ -6,7 +6,7 @@ import { ICommunicationManager } from './communication/ICommunicationManager';
import { ConfigurationManager } from './configuration/ConfigurationManager';
import { IConfigurationManager } from './configuration/IConfigurationManager';
import { INitroCore } from './INitroCore';
import { NitroVersion } from './NitroVersion';
import { SayHello } from './utils/SayHello';
export class NitroCore extends Disposable implements INitroCore
{
@ -18,13 +18,11 @@ export class NitroCore extends Disposable implements INitroCore
{
super();
window.console.log.apply(console, [
`\n%c _ ___ __ \n / | / (_) /__________ \n / |/ / / __/ ___/ __ \\ \n / /| / / /_/ / / /_/ / \n /_/ |_/_/\\__/_/ \\____/ \n \n Thanks for using Nitro \n To report bugs or issues \n join us on Discord \n https://nitrots.co/discord \n \n Renderer: v${ NitroVersion.RENDERER_VERSION } \n UI: v${ NitroVersion.UI_VERSION } \n \n`,
'color: #FFFFFF; background: #000000; padding:0px 0;' ]);
SayHello();
this._configuration = new ConfigurationManager();
this._communication = new CommunicationManager();
this._asset = new AssetManager();
this._asset = new AssetManager();
}
protected onDispose(): void

View File

@ -1,5 +1,5 @@
export class NitroVersion
{
public static RENDERER_VERSION: string = '1.1.0';
public static UI_VERSION: string = '';
public static RENDERER_VERSION: string = '1.1.5';
public static UI_VERSION: string = '';
}

View File

@ -1,4 +1,4 @@
import { BaseTexture, Resource, Texture } from '@pixi/core';
import { Resource, Texture } from '@pixi/core';
import { Loader, LoaderResource } from '@pixi/loaders';
import { Spritesheet } from '@pixi/spritesheet';
import { IGraphicAsset } from '../../room';
@ -21,9 +21,9 @@ export class AssetManager extends Disposable implements IAssetManager
{
super();
this._logger = new NitroLogger(this.constructor.name);
this._textures = new Map();
this._collections = new Map();
this._logger = new NitroLogger(this.constructor.name);
this._textures = new Map();
this._collections = new Map();
}
public static removeFileExtension(name: string): string
@ -167,10 +167,10 @@ export class AssetManager extends Disposable implements IAssetManager
if(resource.extension === 'nitro')
{
const nitroBundle = new NitroBundle(resource.data);
const assetData = (nitroBundle.jsonFile as IAssetData);
const nitroBundle = new NitroBundle(resource.data);
const assetData = (nitroBundle.jsonFile as IAssetData);
if(!assetData || !assetData.type)
if(!assetData)
{
onDownloaded(loader, resource, false);
@ -231,77 +231,7 @@ export class AssetManager extends Disposable implements IAssetManager
onDownloaded(loader, resource, true);
}
else if(resource.type === LoaderResource.TYPE.JSON)
{
const assetData = (resource.data as IAssetData);
if(!assetData || !assetData.type)
{
onDownloaded(loader, resource, false);
return;
}
if(assetData.spritesheet && Object.keys(assetData.spritesheet).length)
{
const imageName = (assetData.spritesheet.meta && assetData.spritesheet.meta.image);
if(!imageName || !imageName.length)
{
onDownloaded(loader, resource, false);
return;
}
const imageUrl = (resource.url.substring(0, (resource.url.lastIndexOf('/') + 1)) + imageName);
const baseTexture = BaseTexture.from(imageUrl);
if(baseTexture.valid)
{
const spritesheet = new Spritesheet(baseTexture, assetData.spritesheet);
spritesheet.parse(() =>
{
this.createCollection(assetData, spritesheet);
onDownloaded(loader, resource, true);
});
}
else
{
baseTexture.once('loaded', () =>
{
baseTexture.removeAllListeners();
const spritesheet = new Spritesheet(baseTexture, assetData.spritesheet);
spritesheet.parse(() =>
{
this.createCollection(assetData, spritesheet);
onDownloaded(loader, resource, true);
});
});
baseTexture.once('error', () =>
{
baseTexture.removeAllListeners();
onDownloaded(loader, resource, false);
});
}
return;
}
this.createCollection(assetData, null);
onDownloaded(loader, resource, true);
return;
}
if(resource.type === LoaderResource.TYPE.IMAGE)
else if(resource.type === LoaderResource.TYPE.IMAGE)
{
if(resource.texture.valid)
{

View File

@ -21,7 +21,7 @@ export class NitroBundle
let binary = '';
const bytes = new Uint8Array(buffer);
const len = bytes.byteLength;
const len = bytes.byteLength;
for(let i = 0; i < len; i++) (binary += String.fromCharCode(bytes[i]));
@ -36,10 +36,10 @@ export class NitroBundle
while(fileCount > 0)
{
const fileNameLength = binaryReader.readShort();
const fileName = binaryReader.readBytes(fileNameLength).toString();
const fileLength = binaryReader.readInt();
const buffer = binaryReader.readBytes(fileLength);
const fileNameLength = binaryReader.readShort();
const fileName = binaryReader.readBytes(fileNameLength).toString();
const fileLength = binaryReader.readInt();
const buffer = binaryReader.readBytes(fileLength);
if(fileName.endsWith('.json'))
{
@ -49,8 +49,8 @@ export class NitroBundle
}
else
{
const decompressed = inflate((buffer.toArrayBuffer() as Data));
const base64 = NitroBundle.arrayBufferToBase64(decompressed);
const decompressed = inflate((buffer.toArrayBuffer() as Data));
const base64 = NitroBundle.arrayBufferToBase64(decompressed);
this._baseTexture = new BaseTexture('data:image/png;base64,' + base64);
}

View File

@ -18,24 +18,24 @@ export class NitroManager extends Disposable implements INitroManager
{
super();
this._logger = logger instanceof NitroLogger ? logger : new NitroLogger(this.constructor.name);
this._logger = logger instanceof NitroLogger ? logger : new NitroLogger(this.constructor.name);
this._events = new EventDispatcher();
this._events = new EventDispatcher();
this._isLoaded = false;
this._isLoading = false;
this._isLoaded = false;
this._isLoading = false;
}
public init(): void
{
if(this._isLoaded || this._isLoading || this.isDisposing) return;
this._isLoading = true;
this._isLoading = true;
this.onInit();
this._isLoaded = true;
this._isLoading = false;
this._isLoaded = true;
this._isLoading = false;
}
protected onInit(): void

View File

@ -7,20 +7,20 @@ export class Disposable implements IDisposable
constructor()
{
this._isDisposed = false;
this._isDisposing = false;
this._isDisposed = false;
this._isDisposing = false;
}
public dispose(): void
{
if(this._isDisposed || this._isDisposing) return;
this._isDisposing = true;
this._isDisposing = true;
this.onDispose();
this._isDisposed = true;
this._isDisposing = false;
this._isDisposed = true;
this._isDisposing = false;
}
protected onDispose(): void

View File

@ -10,9 +10,9 @@ export class NitroLogger implements INitroLogger
constructor(name: string, description: string | number = null)
{
this._name = name;
this._description = description;
this._print = true;
this._name = name;
this._description = description;
this._print = true;
}
public log(message: string): void
@ -39,7 +39,7 @@ export class NitroLogger implements INitroLogger
public static log(message: string, name: string = 'Nitro', modus: string = null): void
{
const logString = `[Nitro] ${ new Date().toDateString() } [${ name }] ${ message } ${ this.getTimestamp() }`;
const logString = `[Nitro] [${ name }] ${ message } ${ this.getTimestamp() }`;
switch(modus)
{

View File

@ -7,7 +7,7 @@ import { ICommunicationManager } from './ICommunicationManager';
export class CommunicationManager extends Disposable implements ICommunicationManager, IUpdateReceiver
{
private _connections: IConnection[]
private _connections: IConnection[];
constructor()
{

View File

@ -76,7 +76,7 @@ export class BinaryWriter
{
if(!array) return;
const mergedArray = new Uint8Array( ((this.position + array.length) > this._buffer.length) ? (this.position + array.length) : this._buffer.length);
const mergedArray = new Uint8Array( ((this.position + array.length) > this._buffer.length) ? (this.position + array.length) : this._buffer.length);
mergedArray.set(this._buffer);
mergedArray.set(array, this.position);

View File

@ -8,8 +8,8 @@ export class EvaWireDataWrapper implements IMessageDataWrapper
constructor(header: number, buffer: BinaryReader)
{
this._header = header;
this._buffer = buffer;
this._header = header;
this._buffer = buffer;
}
public readBytes(length: number): BinaryReader
@ -61,8 +61,8 @@ export class EvaWireDataWrapper implements IMessageDataWrapper
public readString(): string
{
const length = this.readShort();
const buffer = this._buffer.readBytes(length);
const length = this.readShort();
const buffer = this._buffer.readBytes(length);
return buffer.toString('utf8');
}

View File

@ -21,8 +21,8 @@ export class EvaWireFormat implements ICodec
if(type === 'object')
{
if(value === null) type = 'null';
else if(value instanceof Byte) type = 'byte';
if(value === null) type = 'null';
else if(value instanceof Byte) type = 'byte';
else if(value instanceof Short) type = 'short';
else if(value instanceof ArrayBuffer) type = 'arraybuffer';
}
@ -75,7 +75,7 @@ export class EvaWireFormat implements ICodec
if(connection.dataBuffer.byteLength < 4) break;
const container = new BinaryReader(connection.dataBuffer);
const length = container.readInt();
const length = container.readInt();
if(length > (connection.dataBuffer.byteLength - 4)) break;

View File

@ -33,23 +33,23 @@ export class SocketConnection extends EventDispatcher implements IConnection
{
super();
this._communicationManager = communicationManager;
this._stateListener = stateListener;
this._socket = null;
this._messages = new MessageClassManager();
this._codec = new EvaWireFormat();
this._dataBuffer = null;
this._isReady = false;
this._communicationManager = communicationManager;
this._stateListener = stateListener;
this._socket = null;
this._messages = new MessageClassManager();
this._codec = new EvaWireFormat();
this._dataBuffer = null;
this._isReady = false;
this._pendingClientMessages = [];
this._pendingServerMessages = [];
this._isAuthenticated = false;
this._isAuthenticated = false;
this.onOpen = this.onOpen.bind(this);
this.onClose = this.onClose.bind(this);
this.onError = this.onError.bind(this);
this.onMessage = this.onMessage.bind(this);
this.onOpen = this.onOpen.bind(this);
this.onClose = this.onClose.bind(this);
this.onError = this.onError.bind(this);
this.onMessage = this.onMessage.bind(this);
}
public init(socketUrl: string): void
@ -68,11 +68,11 @@ export class SocketConnection extends EventDispatcher implements IConnection
this.destroySocket();
this._communicationManager = null;
this._stateListener = null;
this._messages = null;
this._codec = null;
this._dataBuffer = null;
this._communicationManager = null;
this._stateListener = null;
this._messages = null;
this._codec = null;
this._dataBuffer = null;
}
public onReady(): void
@ -95,8 +95,8 @@ export class SocketConnection extends EventDispatcher implements IConnection
this.destroySocket();
this._dataBuffer = new ArrayBuffer(0);
this._socket = new WebSocket(socketUrl);
this._dataBuffer = new ArrayBuffer(0);
this._socket = new WebSocket(socketUrl);
this._socket.addEventListener(WebSocketEventEnum.CONNECTION_OPENED, this.onOpen);
this._socket.addEventListener(WebSocketEventEnum.CONNECTION_CLOSED, this.onClose);
@ -189,8 +189,8 @@ export class SocketConnection extends EventDispatcher implements IConnection
continue;
}
const message = composer.getMessageArray();
const encoded = this._codec.encode(header, message);
const message = composer.getMessageArray();
const encoded = this._codec.encode(header, message);
if(!encoded)
{
@ -301,9 +301,12 @@ export class SocketConnection extends EventDispatcher implements IConnection
try
{
const parser = events[0].parser;
//@ts-ignore
const parser = new events[0].parserClass();
if(!parser || !parser.flush() || !parser.parse(wrapper)) return null;
for(const event of events) (event.parser = parser);
}
catch (e)

View File

@ -1,5 +1,5 @@
export class ClientDeviceCategoryEnum
{
public static UNKNOWN: number = 0;
public static BROWSER: number = 1;
public static UNKNOWN: number = 0;
public static BROWSER: number = 1;
}

View File

@ -1,7 +1,7 @@
export class ClientPlatformEnum
{
public static UNKNOWN: number = 0;
public static FLASH: number = 1;
public static HTML5: number = 2;
public static UNKNOWN: number = 0;
public static FLASH: number = 1;
public static HTML5: number = 2;
}

View File

@ -1,7 +1,7 @@
export class WebSocketEventEnum
{
public static CONNECTION_OPENED = 'open';
public static CONNECTION_CLOSED = 'close';
public static CONNECTION_ERROR = 'error';
public static CONNECTION_MESSAGE = 'message';
public static CONNECTION_OPENED = 'open';
public static CONNECTION_CLOSED = 'close';
public static CONNECTION_ERROR = 'error';
public static CONNECTION_MESSAGE = 'message';
}

View File

@ -3,10 +3,10 @@ import { IConnection } from '../connections/IConnection';
export class SocketConnectionEvent extends NitroEvent
{
public static CONNECTION_OPENED = 'SCE_OPEN';
public static CONNECTION_CLOSED = 'SCE_CLOSED';
public static CONNECTION_ERROR = 'SCE_ERROR';
public static CONNECTION_MESSAGE = 'SCE_MESSAGE';
public static CONNECTION_OPENED = 'SCE_OPEN';
public static CONNECTION_CLOSED = 'SCE_CLOSED';
public static CONNECTION_ERROR = 'SCE_ERROR';
public static CONNECTION_MESSAGE = 'SCE_MESSAGE';
private _connection: IConnection;
private _originalEvent: Event;
@ -15,7 +15,7 @@ export class SocketConnectionEvent extends NitroEvent
{
super(type);
this._connection = connection;
this._connection = connection;
this._originalEvent = event;
}

View File

@ -11,9 +11,9 @@ export class MessageClassManager
constructor()
{
this._messageIdByEvent = new Map();
this._messageIdByComposer = new Map();
this._messageInstancesById = new Map();
this._messageIdByEvent = new Map();
this._messageIdByComposer = new Map();
this._messageInstancesById = new Map();
}
public dispose(): void
@ -67,13 +67,6 @@ export class MessageClassManager
existing = [];
this._messageInstancesById.set(header, existing);
//@ts-ignore
event.parser = new event.parserClass();
}
else
{
event.parser = existing[0].parser;
}
existing.push(event);

View File

@ -11,18 +11,18 @@ export class MessageEvent implements IMessageEvent
constructor(callBack: Function, parser: { new(): IMessageParser })
{
this._callBack = callBack;
this._parserClass = parser;
this._parser = null;
this._connection = null;
this._callBack = callBack;
this._parserClass = parser;
this._parser = null;
this._connection = null;
}
public dispose(): void
{
this._callBack = null;
this._parserClass = null;
this._parser = null;
this._connection = null;
this._callBack = null;
this._parserClass = null;
this._parser = null;
this._connection = null;
}
public get callBack(): Function

View File

@ -2,8 +2,8 @@ import { NitroEvent } from '../events/NitroEvent';
export class ConfigurationEvent extends NitroEvent
{
public static LOADED: string = 'NCE_LOADED';
public static FAILED: string = 'NCE_FAILED';
public static LOADED: string = 'NCE_LOADED';
public static FAILED: string = 'NCE_FAILED';
constructor(type: string)
{

View File

@ -1,44 +1,29 @@
import { NitroManager } from '../common/NitroManager';
import { AdvancedMap } from '../utils/AdvancedMap';
import { ConfigurationEvent } from './ConfigurationEvent';
import { IConfigurationManager } from './IConfigurationManager';
export class ConfigurationManager extends NitroManager implements IConfigurationManager
{
private _definitions: AdvancedMap<string, unknown>;
private _definitions: Map<string, unknown>;
private _pendingUrls: string[];
private _missingKeys: string[];
constructor()
{
super();
this._definitions = new AdvancedMap();
this._definitions = new Map();
this._pendingUrls = [];
this._missingKeys = [];
this.onConfigurationLoaded = this.onConfigurationLoaded.bind(this);
}
protected onInit(): void
{
//@ts-ignore
let urls: string[] = NitroConfig.configurationUrls;
this.parseConfiguration(this.getDefaultConfig(), true);
if(!urls || !urls.length)
{
//@ts-ignore
const url: string = NitroConfig.configurationUrl;
if(url && url.length) urls = [ url ];
}
if(!urls || !urls.length)
{
this.dispatchConfigurationEvent(ConfigurationEvent.FAILED);
return;
}
this._pendingUrls = urls;
this._pendingUrls = this.getValue<string[]>('config.urls').slice();
this.loadNextConfiguration();
}
@ -98,7 +83,7 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
this.events && this.events.dispatchEvent(new ConfigurationEvent(type));
}
private parseConfiguration(data: { [index: string]: any }): boolean
private parseConfiguration(data: { [index: string]: any }, overrides: boolean = false): boolean
{
if(!data) return false;
@ -110,12 +95,16 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
{
let value = data[key];
if(typeof value === 'string')
{
value = this.interpolate((value as string), regex);
}
if(typeof value === 'string') value = this.interpolate((value as string), regex);
this._definitions.add(key, value);
if(this._definitions.has(key))
{
if(overrides) this.setValue(key, value);
}
else
{
this.setValue(key, value);
}
}
return true;
@ -139,7 +128,7 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
{
for(const piece of pieces)
{
const existing = (this._definitions.getValue(this.removeInterpolateKey(piece)) as string);
const existing = (this._definitions.get(this.removeInterpolateKey(piece)) as string);
if(existing) (value = value.replace(piece, existing));
}
@ -155,10 +144,13 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
public getValue<T>(key: string, value: T = null): T
{
let existing = this._definitions.getValue(key);
let existing = this._definitions.get(key);
if(existing === undefined)
{
if(this._missingKeys.indexOf(key) >= 0) return value;
this._missingKeys.push(key);
this.logger.warn(`Missing configuration key: ${ key }`);
existing = value;
@ -169,6 +161,12 @@ export class ConfigurationManager extends NitroManager implements IConfiguration
public setValue(key: string, value: string): void
{
this._definitions.add(key, value);
this._definitions.set(key, value);
}
public getDefaultConfig(): { [index: string]: any }
{
//@ts-ignore
return NitroConfig as { [index: string]: any };
}
}

View File

@ -15,7 +15,7 @@ export class EventDispatcher extends Disposable implements IEventDispatcher, IDi
{
super();
this._logger = new NitroLogger(this.constructor.name);
this._logger = new NitroLogger(this.constructor.name);
this._listeners = new Map();
}

View File

@ -9,10 +9,10 @@ export class AdvancedMap<T, U> implements IDisposable
constructor(map: Map<T, U> = null)
{
this._length = 0;
this._dictionary = new Map();
this._array = [];
this._keys = [];
this._length = 0;
this._dictionary = new Map();
this._array = [];
this._keys = [];
if(map) for(const [ key, value ] of map.entries()) this.add(key, value);
}
@ -36,18 +36,18 @@ export class AdvancedMap<T, U> implements IDisposable
this._dictionary = null;
}
this._length = 0;
this._array = null;
this._keys = null;
this._length = 0;
this._array = null;
this._keys = null;
}
public reset(): void
{
for(const key of this._dictionary.keys()) this._dictionary.delete(key);
this._length = 0;
this._array = [];
this._keys = [];
this._length = 0;
this._array = [];
this._keys = [];
}
public unshift(key: T, value: U): boolean
@ -70,8 +70,8 @@ export class AdvancedMap<T, U> implements IDisposable
this._dictionary.set(key, value);
this._array[this._length] = value;
this._keys[this._length] = key;
this._array[this._length] = value;
this._keys[this._length] = key;
this._length++;

View File

@ -6,9 +6,9 @@ export class NitroTimer
constructor(percision: number = 1)
{
this._elapsedTime = 0;
this._percision = percision;
this._timer = null;
this._elapsedTime = 0;
this._percision = percision;
this._timer = null;
this.start();
}

View File

@ -0,0 +1,93 @@
import { NitroBaseTexture, NitroFilter } from './proxy';
const vertex = `
attribute vec2 aVertexPosition;
attribute vec2 aTextureCoord;
uniform mat3 projectionMatrix;
varying vec2 vTextureCoord;
void main(void)
{
gl_Position = vec4((projectionMatrix * vec3(aVertexPosition, 1.0)).xy, 0.0, 1.0);
vTextureCoord = aTextureCoord;
}`;
const fragment = `
varying vec2 vTextureCoord;
uniform sampler2D uSampler;
uniform sampler2D lut;
uniform int channel;
void main(void) {
vec4 currentColor = texture2D(uSampler, vTextureCoord);
vec4 adjusted = currentColor;
if(currentColor.a > 0.0)
{
if(channel == 0)
{
adjusted = texture2D(lut, vec2((currentColor.r * 255.0 + 0.5) / 256.0, 0.5));
} else if(channel == 1) {
adjusted = texture2D(lut, vec2((currentColor.g * 255.0 + 0.5) / 256.0, 0.5));
} else if(channel == 2) {
adjusted = texture2D(lut, vec2((currentColor.b * 255.0 + 0.5) / 256.0, 0.5));
} else if(channel == 3) {
adjusted = texture2D(lut, vec2((currentColor.a * 255.0 + 0.5) / 256.0, 0.5));
}
}
gl_FragColor = vec4(adjusted.r, adjusted.g, adjusted.b, currentColor.a);
}`;
export class PaletteMapFilter extends NitroFilter
{
public static readonly CHANNEL_RED = 0;
public static readonly CHANNEL_GREEN = 1;
public static readonly CHANNEL_BLUE = 2;
public static readonly CHANNEL_ALPHA = 3;
private _lut: NitroBaseTexture;
private _channel: number;
constructor(palette: number[], channel = PaletteMapFilter.CHANNEL_RED)
{
super(vertex, fragment);
this._channel = channel;
let lut: number[] = [];
lut = this.getLutForPalette(palette);
this._lut = NitroBaseTexture.fromBuffer(Uint8Array.from(lut), lut.length / 4, 1, { mipmap: 0, scaleMode: 0 });
this.uniforms.lut = this._lut;
this.uniforms.channel = this._channel;
}
private getLutForPalette(data: number[]): number[]
{
const lut = [];
for(let i = 0; i < data.length; i++)
{
// R
lut[(i * 4) + PaletteMapFilter.CHANNEL_RED] = ((data[i] >> 16) & 0xFF);
// G
lut[(i * 4) + PaletteMapFilter.CHANNEL_GREEN] = ((data[i] >> 8) & 0xFF);
// B
lut[(i * 4) + PaletteMapFilter.CHANNEL_BLUE] = (data[i] & 0xFF);
// A
lut[(i * 4) + PaletteMapFilter.CHANNEL_ALPHA] = ((data[i] >> 24) & 0xFF);
}
return lut;
}
public get lut(): NitroBaseTexture
{
return this._lut;
}
public get channel(): number
{
return this._channel;
}
}

View File

@ -0,0 +1,26 @@
import { NitroVersion } from '..';
export const SayHello = () =>
{
if(navigator.userAgent.toLowerCase().indexOf('chrome') > -1)
{
const args = [
`\n %c %c %c Nitro ${ NitroVersion.UI_VERSION } - Renderer ${ NitroVersion.RENDERER_VERSION } %c %c %c https://nitrots.co/discord %c %c \n\n`,
'background: #ffffff; padding:5px 0;',
'background: #ffffff; padding:5px 0;',
'color: #ffffff; background: #000000; padding:5px 0;',
'background: #ffffff; padding:5px 0;',
'background: #ffffff; padding:5px 0;',
'background: #000000; padding:5px 0;',
'background: #ffffff; padding:5px 0;',
'background: #ffffff; padding:5px 0;'
];
self.console.log(...args);
}
else if(self.console)
{
self.console.log(`Nitro ${ NitroVersion.UI_VERSION } - Renderer ${ NitroVersion.RENDERER_VERSION } `);
}
};

View File

@ -0,0 +1,4 @@
import { Polygon } from '@pixi/math';
export class NitroPolygon extends Polygon
{}

View File

@ -5,6 +5,7 @@ export * from './NitroBaseTexture';
export * from './NitroContainer';
export * from './NitroFilter';
export * from './NitroPoint';
export * from './NitroPolygon';
export * from './NitroRectangle';
export * from './NitroRenderTexture';
export * from './NitroSprite';

View File

@ -44,9 +44,9 @@ settings.ROUND_PIXELS = true;
export class Nitro extends Application implements INitro
{
public static WEBGL_CONTEXT_LOST: string = 'NE_WEBGL_CONTEXT_LOST';
public static WEBGL_UNAVAILABLE: string = 'NE_WEBGL_UNAVAILABLE';
public static READY: string = 'NE_READY!';
public static WEBGL_CONTEXT_LOST: string = 'NE_WEBGL_CONTEXT_LOST';
public static WEBGL_UNAVAILABLE: string = 'NE_WEBGL_UNAVAILABLE';
public static READY: string = 'NE_READY!';
private static INSTANCE: INitro = null;
@ -75,24 +75,24 @@ export class Nitro extends Application implements INitro
if(!Nitro.INSTANCE) Nitro.INSTANCE = this;
this._nitroTimer = new NitroTimer();
this._worker = null;
this._core = core;
this._events = new EventDispatcher();
this._localization = new NitroLocalizationManager();
this._communication = new NitroCommunicationManager(core.communication);
this._avatar = new AvatarRenderManager();
this._roomEngine = new RoomEngine(this._communication);
this._sessionDataManager = new SessionDataManager(this._communication);
this._roomSessionManager = new RoomSessionManager(this._communication, this._roomEngine);
this._roomManager = new RoomManager(this._roomEngine, this._roomEngine.visualizationFactory, this._roomEngine.logicFactory);
this._cameraManager = new RoomCameraWidgetManager();
this._soundManager = new SoundManager();
this._linkTrackers = [];
this._workerTrackers = [];
this._nitroTimer = new NitroTimer();
this._worker = null;
this._core = core;
this._events = new EventDispatcher();
this._localization = new NitroLocalizationManager();
this._communication = new NitroCommunicationManager(core.communication);
this._avatar = new AvatarRenderManager();
this._roomEngine = new RoomEngine(this._communication);
this._sessionDataManager = new SessionDataManager(this._communication);
this._roomSessionManager = new RoomSessionManager(this._communication, this._roomEngine);
this._roomManager = new RoomManager(this._roomEngine, this._roomEngine.visualizationFactory, this._roomEngine.logicFactory);
this._cameraManager = new RoomCameraWidgetManager();
this._soundManager = new SoundManager();
this._linkTrackers = [];
this._workerTrackers = [];
this._isReady = false;
this._isDisposed = false;
this._isReady = false;
this._isDisposed = false;
this._core.configuration.events.addEventListener(ConfigurationEvent.LOADED, this.onConfigurationLoadedEvent.bind(this));
this._roomEngine.events.addEventListener(RoomEngineEvent.ENGINE_INITIALIZED, this.onRoomEngineReady.bind(this));
@ -112,8 +112,8 @@ export class Nitro extends Application implements INitro
const canvas = document.createElement('canvas');
canvas.id = 'client-wrapper';
canvas.className = 'client-canvas';
canvas.id = 'client-wrapper';
canvas.className = 'client-canvas';
const instance = new this(new NitroCore(), {
autoDensity: true,
@ -124,11 +124,6 @@ export class Nitro extends Application implements INitro
});
canvas.addEventListener('webglcontextlost', () => instance.events.dispatchEvent(new NitroEvent(Nitro.WEBGL_CONTEXT_LOST)));
//@ts-ignore
const sso = (NitroConfig.sso as string);
instance.communication.demo.setSSO(sso);
}
public init(): void
@ -143,7 +138,7 @@ export class Nitro extends Application implements INitro
{
this._roomEngine.sessionDataManager = this._sessionDataManager;
this._roomEngine.roomSessionManager = this._roomSessionManager;
this._roomEngine.roomManager = this._roomManager;
this._roomEngine.roomManager = this._roomManager;
if(this._sessionDataManager) this._sessionDataManager.init();
if(this._roomSessionManager) this._roomSessionManager.init();
@ -216,14 +211,14 @@ export class Nitro extends Application implements INitro
super.destroy();
this._isDisposed = true;
this._isReady = false;
this._isDisposed = true;
this._isReady = false;
}
private onConfigurationLoadedEvent(event: ConfigurationEvent): void
{
const animationFPS = this.getConfiguration<number>('system.animation.fps', 24);
const limitsFPS = this.getConfiguration<boolean>('system.limits.fps', true);
const animationFPS = this.getConfiguration<number>('system.animation.fps', 24);
const limitsFPS = this.getConfiguration<boolean>('system.limits.fps', true);
if(limitsFPS) Nitro.instance.ticker.maxFPS = animationFPS;
}

View File

@ -6,9 +6,9 @@ export class AvatarAssetDownloadLibrary extends EventDispatcher
{
public static DOWNLOAD_COMPLETE: string = 'AADL_DOWNLOAD_COMPLETE';
private static NOT_LOADED: number = 0;
private static LOADING: number = 1;
private static LOADED: number = 2;
private static NOT_LOADED: number = 0;
private static LOADING: number = 1;
private static LOADED: number = 2;
private _state: number;
private _libraryName: string;
@ -20,11 +20,11 @@ export class AvatarAssetDownloadLibrary extends EventDispatcher
{
super();
this._state = AvatarAssetDownloadLibrary.NOT_LOADED;
this._libraryName = id;
this._revision = revision;
this._downloadUrl = assetUrl;
this._assets = assets;
this._state = AvatarAssetDownloadLibrary.NOT_LOADED;
this._libraryName = id;
this._revision = revision;
this._downloadUrl = assetUrl;
this._assets = assets;
this._downloadUrl = this._downloadUrl.replace(/%libname%/gi, this._libraryName);
this._downloadUrl = this._downloadUrl.replace(/%revision%/gi, this._revision);

View File

@ -12,10 +12,10 @@ import { IAvatarImageListener } from './IAvatarImageListener';
export class AvatarAssetDownloadManager extends EventDispatcher
{
public static DOWNLOADER_READY: string = 'AADM_DOWNLOADER_READY';
public static LIBRARY_LOADED: string = 'AADM_LIBRARY_LOADED';
public static DOWNLOADER_READY: string = 'AADM_DOWNLOADER_READY';
public static LIBRARY_LOADED: string = 'AADM_LIBRARY_LOADED';
private static MAX_DOWNLOADS: number = 2;
private static MAX_DOWNLOADS: number = 2;
private _assets: IAssetManager;
private _structure: AvatarStructure;
@ -34,21 +34,21 @@ export class AvatarAssetDownloadManager extends EventDispatcher
{
super();
this._assets = assets;
this._structure = structure;
this._assets = assets;
this._structure = structure;
this._missingMandatoryLibs = Nitro.instance.getConfiguration<string[]>('avatar.mandatory.libraries');
this._figureMap = new Map();
this._pendingContainers = [];
this._figureListeners = new Map();
this._incompleteFigures = new Map();
this._pendingDownloadQueue = [];
this._currentDownloads = [];
this._libraryNames = [];
this._isReady = false;
this._missingMandatoryLibs = Nitro.instance.getConfiguration<string[]>('avatar.mandatory.libraries');
this._figureMap = new Map();
this._pendingContainers = [];
this._figureListeners = new Map();
this._incompleteFigures = new Map();
this._pendingDownloadQueue = [];
this._currentDownloads = [];
this._libraryNames = [];
this._isReady = false;
this.onLibraryLoaded = this.onLibraryLoaded.bind(this);
this.onAvatarRenderReady = this.onAvatarRenderReady.bind(this);
this.onLibraryLoaded = this.onLibraryLoaded.bind(this);
this.onAvatarRenderReady = this.onAvatarRenderReady.bind(this);
this.loadFigureMap();
@ -101,8 +101,8 @@ export class AvatarAssetDownloadManager extends EventDispatcher
{
if(!library) continue;
const id = (library.id as string);
const revision = (library.revision || '');
const id = (library.id as string);
const revision = (library.revision || '');
if(this._libraryNames.indexOf(id) >= 0) continue;
@ -114,9 +114,9 @@ export class AvatarAssetDownloadManager extends EventDispatcher
for(const part of library.parts)
{
const id = (part.id as string);
const type = (part.type as string);
const partString = (type + ':' + id);
const id = (part.id as string);
const type = (part.type as string);
const partString = (type + ':' + id);
let existing = this._figureMap.get(partString);
@ -256,8 +256,8 @@ export class AvatarAssetDownloadManager extends EventDispatcher
{
if(!part) continue;
const name = (part.type + ':' + part.id);
const existing = this._figureMap.get(name);
const name = (part.type + ':' + part.id);
const existing = this._figureMap.get(name);
if(existing === undefined) continue;
@ -284,8 +284,8 @@ export class AvatarAssetDownloadManager extends EventDispatcher
return;
}
const figure = container.getFigureString();
const pendingLibraries = this.getAvatarFigurePendingLibraries(container);
const figure = container.getFigureString();
const pendingLibraries = this.getAvatarFigurePendingLibraries(container);
if(pendingLibraries && pendingLibraries.length)
{

View File

@ -96,9 +96,9 @@ export class AvatarFigureContainer implements IAvatarFigureContainer
if(pieces.length >= 2)
{
const type = pieces[0];
const setId = parseInt(pieces[1]);
const colors = [];
const type = pieces[0];
const setId = parseInt(pieces[1]);
const colors = [];
let index = 2;

View File

@ -5,6 +5,7 @@ import { Rectangle } from '@pixi/math';
import { Sprite } from '@pixi/sprite';
import { NitroContainer, NitroSprite } from '../../core';
import { AdvancedMap } from '../../core/utils/AdvancedMap';
import { PaletteMapFilter } from '../../core/utils/PaletteMapFilter';
import { IGraphicAsset } from '../../room/object/visualization/utils/IGraphicAsset';
import { TextureUtils } from '../../room/utils/TextureUtils';
import { Nitro } from '../Nitro';
@ -30,15 +31,15 @@ import { IPartColor } from './structure/figure/IPartColor';
export class AvatarImage implements IAvatarImage, IAvatarEffectListener
{
private static CHANNELS_EQUAL: string = 'CHANNELS_EQUAL';
private static CHANNELS_UNIQUE: string = 'CHANNELS_UNIQUE';
private static CHANNELS_RED: string = 'CHANNELS_RED';
private static CHANNELS_GREEN: string = 'CHANNELS_GREEN';
private static CHANNELS_BLUE: string = 'CHANNELS_BLUE';
private static CHANNELS_EQUAL: string = 'CHANNELS_EQUAL';
private static CHANNELS_UNIQUE: string = 'CHANNELS_UNIQUE';
private static CHANNELS_RED: string = 'CHANNELS_RED';
private static CHANNELS_GREEN: string = 'CHANNELS_GREEN';
private static CHANNELS_BLUE: string = 'CHANNELS_BLUE';
private static CHANNELS_DESATURATED: string = 'CHANNELS_DESATURATED';
private static DEFAULT_ACTION: string = 'Default';
private static DEFAULT_DIRECTION: number = 2;
private static DEFAULT_AVATAR_SET: string = AvatarSetType.FULL;
private static DEFAULT_ACTION: string = 'Default';
private static DEFAULT_DIRECTION: number = 2;
private static DEFAULT_AVATAR_SET: string = AvatarSetType.FULL;
protected _structure: AvatarStructure;
protected _scale: string;
@ -332,7 +333,7 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
this._reusableTexture = null;
}
this._image = null;
this._image = null;
this._isCachedImage = false;
}
@ -342,8 +343,8 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
const container = new NitroContainer();
let isCachable = true;
let partCount = (_local_6.length - 1);
let isCachable = true;
let partCount = (_local_6.length - 1);
while(partCount >= 0)
{
@ -391,7 +392,19 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
partCount--;
}
if(this._avatarSpriteData && this._avatarSpriteData.paletteIsGrayscale) this.convertToGrayscale(container);
if(this._avatarSpriteData)
{
if(!container.filters) container.filters = [];
if(this._avatarSpriteData.colorTransform) container.filters.push(this._avatarSpriteData.colorTransform);
if(this._avatarSpriteData.paletteIsGrayscale)
{
this.convertToGrayscale(container);
container.filters.push(new PaletteMapFilter(this._avatarSpriteData.reds, PaletteMapFilter.CHANNEL_RED));
}
}
if(!cache)
{
@ -412,39 +425,72 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
if(!this._reusableTexture) return null;
if(this._avatarSpriteData && this._avatarSpriteData.paletteIsGrayscale)
/*
if(this._avatarSpriteData)
{
//this._reusableTexture = this.applyPalette(this._reusableTexture, this._avatarSpriteData.reds);
if(this._avatarSpriteData.paletteIsGrayscale)
{
this._reusableTexture = this.applyPalette(this._reusableTexture, this._avatarSpriteData.reds, [], []);
}
}
*/
this._image = this._reusableTexture;
this._changes = false;
this._image = this._reusableTexture;
this._changes = false;
return this._image;
}
// public applyPalette(texture: RenderTexture, reds: number[] = [], greens: number[] = [], blues: number[] = []): RenderTexture
// {
// const textureCanvas = Nitro.instance.renderer.extract.canvas(texture);
// const textureCtx = textureCanvas.getContext('2d');
// const textureImageData = textureCtx.getImageData(0, 0, textureCanvas.width, textureCanvas.height);
// const data = textureImageData.data;
public applyPalette(texture: RenderTexture, reds: number[] = [], greens: number[] = [], blues: number[] = []): RenderTexture
{
const textureCanvas = TextureUtils.generateCanvas(texture);
const textureCtx = textureCanvas.getContext('2d');
const textureImageData = textureCtx.getImageData(0, 0, textureCanvas.width, textureCanvas.height);
const data = textureImageData.data;
// for(const i = 0; i < data.length; i += 4)
// {
// let paletteColor = this._palette[data[ i + 1 ]];
for(let i = 0; i < data.length; i += 4)
{
if(reds.length == 256)
{
let paletteColor = reds[ data[i] ];
if(paletteColor === undefined) paletteColor = 0;
// if(paletteColor === undefined) paletteColor = [ 0, 0, 0 ];
data[ i ] = ((paletteColor >> 16) & 0xFF);
data[ i + 1] = ((paletteColor >> 8) & 0xFF);
data[ i + 2] = (paletteColor & 0xFF);
}
// data[ i ] = paletteColor[0];
// data[ i + 1 ] = paletteColor[1];
// data[ i + 2 ] = paletteColor[2];
// }
if(greens.length == 256)
{
let paletteColor = greens[ data[i + 1] ];
if(paletteColor === undefined) paletteColor = 0;
// textureCtx.putImageData(textureImageData, 0, 0);
data[ i ] = ((paletteColor >> 16) & 0xFF);
data[ i + 1] = ((paletteColor >> 8) & 0xFF);
data[ i + 2] = (paletteColor & 0xFF);
}
if(blues.length == 256)
{
let paletteColor = greens[ data[i + 2] ];
if(paletteColor === undefined) paletteColor = 0;
// return Texture.from(textureCanvas);
// }
data[ i ] = ((paletteColor >> 16) & 0xFF);
data[ i + 1] = ((paletteColor >> 8) & 0xFF);
data[ i + 2] = (paletteColor & 0xFF);
}
}
textureCtx.putImageData(textureImageData, 0, 0);
const newTexture = new Sprite(Texture.from(textureCanvas));
Nitro.instance.renderer.render(newTexture, {
renderTexture: texture,
clear: true
});
return texture;
}
public getImageAsSprite(setType: string, scale: number = 1): Sprite
{
@ -456,12 +502,12 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
if(!avatarCanvas) return null;
const setTypes = this.getBodyParts(setType, this._mainAction.definition.geometryType, this._mainDirection);
const setTypes = this.getBodyParts(setType, this._mainAction.definition.geometryType, this._mainDirection);
const container = new NitroSprite();
const sprite = new NitroSprite(Texture.EMPTY);
const sprite = new NitroSprite(Texture.EMPTY);
sprite.width = avatarCanvas.width;
sprite.height = avatarCanvas.height;
sprite.width = avatarCanvas.width;
sprite.height = avatarCanvas.height;
container.addChild(sprite);
@ -469,8 +515,8 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
while(partCount >= 0)
{
const set = setTypes[partCount];
const part = this._cache.getImageContainer(set, this._frameCounter);
const set = setTypes[partCount];
const part = this._cache.getImageContainer(set, this._frameCounter);
if(part)
{
@ -521,15 +567,15 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
if(!avatarCanvas) return null;
const setTypes = this.getBodyParts(setType, this._mainAction.definition.geometryType, this._mainDirection);
const setTypes = this.getBodyParts(setType, this._mainAction.definition.geometryType, this._mainDirection);
const container = new NitroContainer();
let partCount = (setTypes.length - 1);
while(partCount >= 0)
{
const set = setTypes[partCount];
const part = this._cache.getImageContainer(set, this._frameCounter);
const set = setTypes[partCount];
const part = this._cache.getImageContainer(set, this._frameCounter);
if(part)
{
@ -881,8 +927,8 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
{
if(!this._sortedActions == null) return;
const _local_3: number = Nitro.instance.time;
const _local_4: string[] = [];
const _local_3: number = Nitro.instance.time;
const _local_4: string[] = [];
for(const k of this._sortedActions) _local_4.push(k.actionType);
@ -1019,7 +1065,7 @@ export class AvatarImage implements IAvatarImage, IAvatarEffectListener
colorFilter.matrix = [_local_3, _local_4, _local_5, 0, 0, _local_3, _local_4, _local_5, 0, 0, _local_3, _local_4, _local_5, 0, 0, 0, 0, 0, 1, 0];
container.filters = [ colorFilter ];
container.filters.push(colorFilter);
return container;
}

View File

@ -10,11 +10,11 @@ export class AvatarImageBodyPartContainer
constructor(k: Container, _arg_2: Point, _arg_3: boolean)
{
this._image = k;
this._regPoint = _arg_2;
this._offset = new Point(0, 0);
this._regPoint = _arg_2;
this._isCacheable = _arg_3;
this._image = k;
this._regPoint = _arg_2;
this._offset = new Point(0, 0);
this._regPoint = _arg_2;
this._isCacheable = _arg_3;
this.cleanPoints();
}
@ -28,9 +28,9 @@ export class AvatarImageBodyPartContainer
});
}
this._image = null;
this._regPoint = null;
this._offset = null;
this._image = null;
this._regPoint = null;
this._offset = null;
}
private cleanPoints(): void

View File

@ -19,17 +19,17 @@ export class AvatarImagePartContainer
constructor(k: string, _arg_2: string, _arg_3: string, _arg_4: IPartColor, _arg_5: AvatarAnimationFrame[], _arg_6: IActionDefinition, _arg_7: boolean, _arg_8: number, _arg_9: string = '', _arg_10: boolean = false, _arg_11: number = 1)
{
this._bodyPartId = k;
this._partType = _arg_2;
this._partId = _arg_3;
this._color = _arg_4;
this._frames = _arg_5;
this._action = _arg_6;
this._isColorable = _arg_7;
this._paletteMapId = _arg_8;
this._flippedPartType = _arg_9;
this._isBlendable = _arg_10;
this._blendTransform = null;
this._bodyPartId = k;
this._partType = _arg_2;
this._partId = _arg_3;
this._color = _arg_4;
this._frames = _arg_5;
this._action = _arg_6;
this._isColorable = _arg_7;
this._paletteMapId = _arg_8;
this._flippedPartType = _arg_9;
this._isBlendable = _arg_10;
this._blendTransform = null;
if(this._partType === 'ey') this._isColorable = false;
}

View File

@ -53,24 +53,24 @@ export class AvatarRenderManager extends NitroManager implements IAvatarRenderMa
{
super();
this._structure = null;
this._avatarAssetDownloadManager = null;
this._structure = null;
this._avatarAssetDownloadManager = null;
this._placeHolderFigure = null;
this._placeHolderFigure = null;
this._figureMapReady = false;
this._effectMapReady = false;
this._actionsReady = false;
this._geometryReady = false;
this._partSetsReady = false;
this._animationsReady = false;
this._isReady = false;
this._figureMapReady = false;
this._effectMapReady = false;
this._actionsReady = false;
this._geometryReady = false;
this._partSetsReady = false;
this._animationsReady = false;
this._isReady = false;
this.onAvatarAssetDownloaderReady = this.onAvatarAssetDownloaderReady.bind(this);
this.onAvatarAssetDownloaded = this.onAvatarAssetDownloaded.bind(this);
this.onEffectAssetDownloaderReady = this.onEffectAssetDownloaderReady.bind(this);
this.onEffectAssetDownloaded = this.onEffectAssetDownloaded.bind(this);
this.onAvatarStructureDownloadDone = this.onAvatarStructureDownloadDone.bind(this);
this.onAvatarAssetDownloaderReady = this.onAvatarAssetDownloaderReady.bind(this);
this.onAvatarAssetDownloaded = this.onAvatarAssetDownloaded.bind(this);
this.onEffectAssetDownloaderReady = this.onEffectAssetDownloaderReady.bind(this);
this.onEffectAssetDownloaded = this.onEffectAssetDownloaded.bind(this);
this.onAvatarStructureDownloadDone = this.onAvatarStructureDownloadDone.bind(this);
}
public onInit(): void
@ -356,8 +356,8 @@ export class AvatarRenderManager extends NitroManager implements IAvatarRenderMa
{
if(!this._structure) return 0;
const figureData = this._structure.figureData;
const parts = Array.from(container.getPartTypeIds());
const figureData = this._structure.figureData;
const parts = Array.from(container.getPartTypeIds());
let clubLevel = 0;
@ -367,15 +367,15 @@ export class AvatarRenderManager extends NitroManager implements IAvatarRenderMa
if(!set) continue;
const setId = container.getPartSetId(part);
const partSet = set.getPartSet(setId);
const setId = container.getPartSetId(part);
const partSet = set.getPartSet(setId);
if(partSet)
{
clubLevel = Math.max(partSet.clubLevel, clubLevel);
const palette = figureData.getPalette(set.paletteID);
const colors = container.getPartColorIds(part);
const palette = figureData.getPalette(set.paletteID);
const colors = container.getPartColorIds(part);
for(const colorId of colors)
{
@ -405,7 +405,7 @@ export class AvatarRenderManager extends NitroManager implements IAvatarRenderMa
public isValidFigureSetForGender(setId: number, gender: string): boolean
{
const structure = this.structureData;
const partSet = structure.getFigurePartSet(setId);
const partSet = structure.getFigurePartSet(setId);
return !!(partSet && ((partSet.gender.toUpperCase() === 'U') || (partSet.gender.toUpperCase() === gender.toUpperCase())));
}
@ -428,8 +428,8 @@ export class AvatarRenderManager extends NitroManager implements IAvatarRenderMa
private resolveFigureSets(k: number[]): IFigurePartSet[]
{
const structure = this.structureData;
const partSets: IFigurePartSet[] = [];
const structure = this.structureData;
const partSets: IFigurePartSet[] = [];
for(const _local_4 of k)
{

View File

@ -43,15 +43,15 @@ export class AvatarStructure extends EventDispatcher
{
super();
this._renderManager = renderManager;
this._geometry = null;
this._figureData = new FigureSetData();
this._partSetsData = new PartSetsData();
this._animationData = new AvatarAnimationData();
this._animationManager = new AnimationManager();
this._mandatorySetTypeIds = {};
this._actionManager = null;
this._defaultAction = null;
this._renderManager = renderManager;
this._geometry = null;
this._figureData = new FigureSetData();
this._partSetsData = new PartSetsData();
this._animationData = new AvatarAnimationData();
this._animationManager = new AnimationManager();
this._mandatorySetTypeIds = {};
this._actionManager = null;
this._defaultAction = null;
}
public init(): void
@ -65,11 +65,11 @@ export class AvatarStructure extends EventDispatcher
super.dispose();
this._renderManager = null;
this._figureData = null;
this._partSetsData = null;
this._animationData = null;
this._mandatorySetTypeIds = null;
this._renderManager = null;
this._figureData = null;
this._partSetsData = null;
this._animationData = null;
this._mandatorySetTypeIds = null;
}
public initGeometry(k: any): void
@ -251,8 +251,8 @@ export class AvatarStructure extends EventDispatcher
{
let _local_3: string[] = [];
const _local_4: string[] = [];
const _local_5 = k.definition.geometryType;
const _local_4: string[] = [];
const _local_5 = k.definition.geometryType;
if(k.definition.isAnimation)
{
@ -356,10 +356,10 @@ export class AvatarStructure extends EventDispatcher
if(!_arg_3 == null) return [];
const _local_9 = this._partSetsData.getActiveParts(_arg_3.definition);
const _local_11: AvatarImagePartContainer[] = [];
let _local_14: any[] = [ 0 ];
const _local_15 = this._animationData.getAction(_arg_3.definition);
const _local_9 = this._partSetsData.getActiveParts(_arg_3.definition);
const _local_11: AvatarImagePartContainer[] = [];
let _local_14: any[] = [ 0 ];
const _local_15 = this._animationData.getAction(_arg_3.definition);
if(_arg_3.definition.isAnimation)
{
@ -388,8 +388,8 @@ export class AvatarStructure extends EventDispatcher
}
}
const _local_16 = this._geometry.getParts(_arg_4, k, _arg_5, _local_9, _arg_7);
const _local_21 = _arg_2.getPartTypeIds();
const _local_16 = this._geometry.getParts(_arg_4, k, _arg_5, _local_9, _arg_7);
const _local_21 = _arg_2.getPartTypeIds();
for(const _local_17 of _local_21)
{
@ -469,7 +469,7 @@ export class AvatarStructure extends EventDispatcher
for(const _local_12 of _local_16)
{
let _local_39: IPartColor = null;
let _local_38 = false;
let _local_38 = false;
const _local_40 = ((_arg_8) && (_arg_8.get(_local_12)));

View File

@ -7,9 +7,9 @@ export class EffectAssetDownloadLibrary extends EventDispatcher
{
public static DOWNLOAD_COMPLETE: string = 'EADL_DOWNLOAD_COMPLETE';
private static NOT_LOADED: number = 0;
private static LOADING: number = 1;
private static LOADED: number = 2;
private static NOT_LOADED: number = 0;
private static LOADING: number = 1;
private static LOADED: number = 2;
private _state: number;
private _libraryName: string;
@ -22,12 +22,12 @@ export class EffectAssetDownloadLibrary extends EventDispatcher
{
super();
this._state = EffectAssetDownloadLibrary.NOT_LOADED;
this._libraryName = id;
this._revision = revision;
this._downloadUrl = assetUrl;
this._assets = assets;
this._animation = null;
this._state = EffectAssetDownloadLibrary.NOT_LOADED;
this._libraryName = id;
this._revision = revision;
this._downloadUrl = assetUrl;
this._assets = assets;
this._animation = null;
this._downloadUrl = this._downloadUrl.replace(/%libname%/gi, this._libraryName);
this._downloadUrl = this._downloadUrl.replace(/%revision%/gi, this._revision);

View File

@ -11,10 +11,10 @@ import { IAvatarEffectListener } from './IAvatarEffectListener';
export class EffectAssetDownloadManager extends EventDispatcher
{
public static DOWNLOADER_READY: string = 'EADM_DOWNLOADER_READY';
public static LIBRARY_LOADED: string = 'EADM_LIBRARY_LOADED';
public static DOWNLOADER_READY: string = 'EADM_DOWNLOADER_READY';
public static LIBRARY_LOADED: string = 'EADM_LIBRARY_LOADED';
private static MAX_DOWNLOADS: number = 2;
private static MAX_DOWNLOADS: number = 2;
private _assets: IAssetManager;
private _structure: AvatarStructure;
@ -33,21 +33,21 @@ export class EffectAssetDownloadManager extends EventDispatcher
{
super();
this._assets = assets;
this._structure = structure;
this._assets = assets;
this._structure = structure;
this._missingMandatoryLibs = Nitro.instance.getConfiguration<string[]>('avatar.mandatory.effect.libraries');
this._effectMap = new Map();
this._effectListeners = new Map();
this._incompleteEffects = new Map();
this._initDownloadBuffer = [];
this._pendingDownloadQueue = [];
this._currentDownloads = [];
this._libraryNames = [];
this._isReady = false;
this._missingMandatoryLibs = Nitro.instance.getConfiguration<string[]>('avatar.mandatory.effect.libraries');
this._effectMap = new Map();
this._effectListeners = new Map();
this._incompleteEffects = new Map();
this._initDownloadBuffer = [];
this._pendingDownloadQueue = [];
this._currentDownloads = [];
this._libraryNames = [];
this._isReady = false;
this.onLibraryLoaded = this.onLibraryLoaded.bind(this);
this.onAvatarRenderReady = this.onAvatarRenderReady.bind(this);
this.onLibraryLoaded = this.onLibraryLoaded.bind(this);
this.onAvatarRenderReady = this.onAvatarRenderReady.bind(this);
this.loadEffectMap();
@ -100,9 +100,9 @@ export class EffectAssetDownloadManager extends EventDispatcher
{
if(!effect) continue;
const id = (effect.id as string);
const lib = (effect.lib as string);
const revision = (effect.revision || '');
const id = (effect.id as string);
const lib = (effect.lib as string);
const revision = (effect.revision || '');
if(this._libraryNames.indexOf(lib) >= 0) continue;

View File

@ -23,23 +23,23 @@ export class ActionDefinition implements IActionDefinition
constructor(data: any)
{
this._id = data.id;
this._state = data.state;
this._precedence = data.precedence;
this._activePartSet = data.activePartSet;
this._assetPartDefinition = data.assetPartDefinition;
this._lay = data.lay;
this._geometryType = data.geometryType;
this._isMain = data.main || false;
this._isDefault = data.isDefault || false;
this._isAnimation = data.animation || false;
this._startFromFrameZero = data.startFromFrameZero || false;
this._prevents = data.prevents || [];
this._preventHeadTurn = data.preventHeadTurn || false;
this._types = new Map();
this._params = new Map();
this._id = data.id;
this._state = data.state;
this._precedence = data.precedence;
this._activePartSet = data.activePartSet;
this._assetPartDefinition = data.assetPartDefinition;
this._lay = data.lay;
this._geometryType = data.geometryType;
this._isMain = data.main || false;
this._isDefault = data.isDefault || false;
this._isAnimation = data.animation || false;
this._startFromFrameZero = data.startFromFrameZero || false;
this._prevents = data.prevents || [];
this._preventHeadTurn = data.preventHeadTurn || false;
this._types = new Map();
this._params = new Map();
this._defaultParameterValue = '';
this._canvasOffsets = null;
this._canvasOffsets = null;
if(data.params && (data.params.length > 0))
{

View File

@ -8,11 +8,11 @@ export class ActionType
constructor(data: any)
{
this._id = parseInt(data.id);
this._value = parseInt(data.id);
this._prevents = data.prevents || [];
this._preventHeadTurn = data.preventHeadTurn || false;
this._isAnimated = true;
this._id = parseInt(data.id);
this._value = parseInt(data.id);
this._prevents = data.prevents || [];
this._preventHeadTurn = data.preventHeadTurn || false;
this._isAnimated = true;
if((data.animated !== undefined) && (data.animated === false)) this._isAnimated = false;
}

View File

@ -11,18 +11,18 @@ export class ActiveActionData implements IActiveActionData
constructor(action: string, parameter: string = '', startFrame: number = 0)
{
this._actionType = action || '';
this._actionParameter = parameter || '';
this._definition = null;
this._startFrame = startFrame || 0;
this._overridingAction = null;
this._actionType = action || '';
this._actionParameter = parameter || '';
this._definition = null;
this._startFrame = startFrame || 0;
this._overridingAction = null;
}
public dispose(): void
{
this._actionType = null;
this._actionParameter = null;
this._definition = null;
this._actionType = null;
this._actionParameter = null;
this._definition = null;
}
public get id(): string

View File

@ -10,8 +10,8 @@ export class AvatarActionManager
constructor(k: IAssetManager, data: any)
{
this._assets = k;
this._actions = new Map();
this._assets = k;
this._actions = new Map();
this._defaultAction = null;
this.updateActions(data);
@ -45,7 +45,7 @@ export class AvatarActionManager
for(const canvasOffset of offset.offsets)
{
const size = (canvasOffset.size || '');
const size = (canvasOffset.size || '');
const direction = canvasOffset.direction;
if((size === '') || (direction === undefined)) continue;
@ -106,8 +106,8 @@ export class AvatarActionManager
{
if(!activeAction) continue;
const action = this._actions.get(activeAction.actionType);
const offsets = action && action.getOffsets(_arg_2, _arg_3);
const action = this._actions.get(activeAction.actionType);
const offsets = action && action.getOffsets(_arg_2, _arg_3);
if(offsets) canvasOffsets = offsets;
}
@ -143,8 +143,8 @@ export class AvatarActionManager
private filterActions(actions: IActiveActionData[]): IActiveActionData[]
{
let preventions: string[] = [];
const activeActions: IActiveActionData[] = [];
let preventions: string[] = [];
const activeActions: IActiveActionData[] = [];
for(const action of actions)
{

View File

@ -9,8 +9,8 @@ export class AssetAlias
constructor(name: string, alias: IAssetAlias)
{
this._name = name;
this._link = alias.link;
this._name = name;
this._link = alias.link;
this._flipH = alias.flipH;
this._flipV = alias.flipV;
}

View File

@ -12,16 +12,16 @@ export class AssetAliasCollection
constructor(k: AvatarRenderManager, _arg_2: IAssetManager)
{
this._avatarRenderManager = k;
this._aliases = new Map();
this._assets = _arg_2;
this._missingAssetNames = [];
this._avatarRenderManager = k;
this._aliases = new Map();
this._assets = _arg_2;
this._missingAssetNames = [];
}
public dispose(): void
{
this._assets = null;
this._aliases = null;
this._assets = null;
this._aliases = null;
}
public reset(): void

View File

@ -10,10 +10,10 @@ export class AddDataContainer
constructor(k: IAssetAnimationAdd)
{
this._id = k.id || '';
this._id = k.id || '';
this._align = k.align || '';
this._base = k.base || '';
this._ink = k.ink || 0;
this._base = k.base || '';
this._ink = k.ink || 0;
this._blend = 0;
const _local_2 = k.blend;

View File

@ -25,17 +25,17 @@ export class Animation implements IAnimation
constructor(k: AvatarStructure, _arg_2: IAssetAnimation)
{
this._id = _arg_2.name;
this._description = this._id;
this._frames = [];
this._spriteData = null;
this._avatarData = null;
this._directionData = null;
this._removeData = null;
this._addData = null;
this._id = _arg_2.name;
this._description = this._id;
this._frames = [];
this._spriteData = null;
this._avatarData = null;
this._directionData = null;
this._removeData = null;
this._addData = null;
this._overriddenActions = null;
this._overrideFrames = null;
this._resetOnToggle = (_arg_2.resetOnToggle || false);
this._overrideFrames = null;
this._resetOnToggle = (_arg_2.resetOnToggle || false);
if(_arg_2.sprites && _arg_2.sprites.length)
{
@ -64,12 +64,12 @@ export class Animation implements IAnimation
if(_arg_2.overrides && _arg_2.overrides.length)
{
this._overrideFrames = new Map();
this._overrideFrames = new Map();
this._overriddenActions = new Map();
for(const override of _arg_2.overrides)
{
const name = override.name;
const name = override.name;
const value = override.override;
this._overriddenActions.set(value, name);
@ -105,8 +105,8 @@ export class Animation implements IAnimation
{
for(const bodyPart of frame.bodyparts)
{
const definition = _arg_3.getActionDefinition(bodyPart.action);
const layer = new AvatarAnimationLayerData(bodyPart, AvatarAnimationLayerData.BODYPART, definition);
const definition = _arg_3.getActionDefinition(bodyPart.action);
const layer = new AvatarAnimationLayerData(bodyPart, AvatarAnimationLayerData.BODYPART, definition);
layers.push(layer);
}
@ -116,8 +116,8 @@ export class Animation implements IAnimation
{
for(const fx of frame.fxs)
{
const definition = _arg_3.getActionDefinition(fx.action);
const layer = new AvatarAnimationLayerData(fx, AvatarAnimationLayerData.FX, definition);
const definition = _arg_3.getActionDefinition(fx.action);
const layer = new AvatarAnimationLayerData(fx, AvatarAnimationLayerData.FX, definition);
layers.push(layer);
}

View File

@ -22,15 +22,15 @@ export class AvatarAnimationLayerData implements IAnimationLayerData
constructor(k: IAssetAnimationFramePart, _arg_2: string, _arg_3: IActionDefinition)
{
this._id = k.id;
this._animationFrame = (k.frame || 0);
this._dx = (k.dx || 0);
this._dy = (k.dy || 0);
this._dz = (k.dz || 0);
this._directionOffset = (k.dd || 0);
this._type = _arg_2;
this._base = (k.base || '');
this._items = new Map();
this._id = k.id;
this._animationFrame = (k.frame || 0);
this._dx = (k.dx || 0);
this._dy = (k.dy || 0);
this._dz = (k.dz || 0);
this._directionOffset = (k.dd || 0);
this._type = _arg_2;
this._base = (k.base || '');
this._items = new Map();
if(k.items) for(const _local_4 of k.items) this._items.set(_local_4.id, _local_4.base);
@ -40,8 +40,8 @@ export class AvatarAnimationLayerData implements IAnimationLayerData
if(_arg_3)
{
this._action = new ActiveActionData(_arg_3.state, this.base);
this._action.definition = _arg_3;
this._action = new ActiveActionData(_arg_3.state, this.base);
this._action.definition = _arg_3;
}
}
@ -52,8 +52,8 @@ export class AvatarAnimationLayerData implements IAnimationLayerData
private baseAsInt(): number
{
let k = 0;
let index = 0;
let k = 0;
let index = 0;
while(index < this._base.length)
{

View File

@ -29,18 +29,18 @@ export class AvatarDataContainer implements IAvatarDataContainer
foreground = foreground.replace('#', '');
background = background.replace('#', '');
this._foreGround = parseInt(foreground, 16);
this._backGround = parseInt(background, 16);
this._colorTransform = null;
this._rgb = parseInt(foreground, 16);
this._r = ((this._rgb >> 16) & 0xFF);
this._g = ((this._rgb >> 8) & 0xFF);
this._b = ((this._rgb >> 0) & 0xFF);
this._redMultiplier = ((this._r / 0xFF) * 1);
this._greenMultiplier = ((this._g / 0xFF) * 1);
this._blueMultiplier = ((this._b / 0xFF) * 1);
this._alphaMultiplier = 1;
this._paletteIsGrayscale = true;
this._foreGround = parseInt(foreground, 16);
this._backGround = parseInt(background, 16);
this._colorTransform = null;
this._rgb = parseInt(foreground, 16);
this._r = ((this._rgb >> 16) & 0xFF);
this._g = ((this._rgb >> 8) & 0xFF);
this._b = ((this._rgb >> 0) & 0xFF);
this._redMultiplier = ((this._r / 0xFF) * 1);
this._greenMultiplier = ((this._g / 0xFF) * 1);
this._blueMultiplier = ((this._b / 0xFF) * 1);
this._alphaMultiplier = 1;
this._paletteIsGrayscale = true;
if(this._ink === 37)
{
@ -48,6 +48,7 @@ export class AvatarDataContainer implements IAvatarDataContainer
this._paletteIsGrayscale = false;
}
this._colorTransform = new AdjustmentFilter({ red: (this._r / 255), green: (this._g / 255), blue: (this._b / 255), alpha: this._alphaMultiplier });
this._colorMap = this.generatePaletteMapForGrayscale(this._backGround, this._foreGround);
}
@ -86,45 +87,44 @@ export class AvatarDataContainer implements IAvatarDataContainer
return this._paletteIsGrayscale;
}
private generatePaletteMapForGrayscale(k: number, _arg_2: number): Map<string, number[]>
private generatePaletteMapForGrayscale(background: number, foreground: number): Map<string, number[]>
{
const _local_3 = ((k >> 24) & 0xFF);
const _local_4 = ((k >> 16) & 0xFF);
const _local_5 = ((k >> 8) & 0xFF);
const _local_6 = ((k >> 0) & 0xFF);
const _local_7 = ((_arg_2 >> 24) & 0xFF);
const _local_8 = ((_arg_2 >> 16) & 0xFF);
const _local_9 = ((_arg_2 >> 8) & 0xFF);
const _local_10 = ((_arg_2 >> 0) & 0xFF);
const _local_11 = ((_local_7 - _local_3) / 0xFF);
const _local_12 = ((_local_8 - _local_4) / 0xFF);
const _local_13 = ((_local_9 - _local_5) / 0xFF);
const _local_14 = ((_local_10 - _local_6) / 0xFF);
const alphaBackground = ((background >> 24) & 0xFF);
const redBackground = ((background >> 16) & 0xFF);
const greenBackground = ((background >> 8) & 0xFF);
const blueBackground = ((background >> 0) & 0xFF);
const alphaForeground = ((foreground >> 24) & 0xFF);
const redForeground = ((foreground >> 16) & 0xFF);
const greenForeground = ((foreground >> 8) & 0xFF);
const blueForeground = ((foreground >> 0) & 0xFF);
const alphaDifference = ((alphaForeground - alphaBackground) / 0xFF);
const redDifference = ((redForeground - redBackground) / 0xFF);
const greenDifference = ((greenForeground - greenBackground) / 0xFF);
const blueDifference = ((blueForeground - blueBackground) / 0xFF);
const _local_15: Map<string, number[]> = new Map();
const _local_16: number[] = [];
const _local_17: number[] = [];
const _local_18: number[] = [];
const _local_19: number[] = [];
let _local_20 = _local_3;
let _local_21 = _local_4;
let _local_22 = _local_5;
let _local_23 = _local_6;
let _local_24 = 0;
while(_local_24 < 0x0100)
let _local_20 = alphaBackground;
let _local_21 = redBackground;
let _local_22 = greenBackground;
let _local_23 = blueBackground;
for(let i = 0; i < 256; i++)
{
if((((_local_21 == _local_4) && (_local_22 == _local_5)) && (_local_23 == _local_6)))
if((((_local_21 == redBackground) && (_local_22 == greenBackground)) && (_local_23 == blueBackground)))
{
_local_20 = 0;
}
_local_20 = (_local_20 + _local_11);
_local_21 = (_local_21 + _local_12);
_local_22 = (_local_22 + _local_13);
_local_23 = (_local_23 + _local_14);
_local_20 = (_local_20 + alphaDifference);
_local_21 = (_local_21 + redDifference);
_local_22 = (_local_22 + greenDifference);
_local_23 = (_local_23 + blueDifference);
_local_19.push((_local_20 << 24));
_local_16.push(((((_local_20 << 24) | (_local_21 << 16)) | (_local_22 << 8)) | _local_23));
_local_17.push(((((_local_20 << 24) | (_local_21 << 16)) | (_local_22 << 8)) | _local_23));
_local_18.push(((((_local_20 << 24) | (_local_21 << 16)) | (_local_22 << 8)) | _local_23));
_local_24++;
}
_local_15.set('alphas', _local_16);

View File

@ -16,15 +16,15 @@ export class SpriteDataContainer implements ISpriteDataContainer
constructor(k: IAnimation, _arg_2: IAssetAnimationSprite)
{
this._animation = k;
this._id = _arg_2.id;
this._ink = _arg_2.ink;
this._member = _arg_2.member;
this._hasStaticY = _arg_2.staticY ? true : false;
this._animation = k;
this._id = _arg_2.id;
this._ink = _arg_2.ink;
this._member = _arg_2.member;
this._hasStaticY = _arg_2.staticY ? true : false;
this._hasDirections = _arg_2.directions ? true : false;
this._dx = [];
this._dy = [];
this._dz = [];
this._dx = [];
this._dy = [];
this._dz = [];
const directions = _arg_2.directionList;

View File

@ -34,8 +34,8 @@ export class AvatarImageBodyPartCache
this._cache.clear();
this._cache = null;
this._disposed = true;
this._cache = null;
this._disposed = true;
}
}

View File

@ -38,16 +38,16 @@ export class AvatarImageCache
constructor(k: AvatarStructure, _arg_2: IAvatarImage, _arg_3: AssetAliasCollection, _arg_4: string)
{
this._structure = k;
this._avatar = _arg_2;
this._assets = _arg_3;
this._scale = _arg_4;
this._cache = new Map();
this._canvas = null;
this._disposed = false;
this._unionImages = [];
this._matrix = new Matrix();
this._serverRenderData = [];
this._structure = k;
this._avatar = _arg_2;
this._assets = _arg_3;
this._scale = _arg_4;
this._cache = new Map();
this._canvas = null;
this._disposed = false;
this._unionImages = [];
this._matrix = new Matrix();
this._serverRenderData = [];
}
public dispose(): void
@ -55,10 +55,10 @@ export class AvatarImageCache
if(this._disposed) return;
this._structure = null;
this._avatar = null;
this._assets = null;
this._canvas = null;
this._disposed = true;
this._avatar = null;
this._assets = null;
this._canvas = null;
this._disposed = true;
if(this._cache)
{
@ -148,16 +148,16 @@ export class AvatarImageCache
if((((this._geometryType === GeometryType.SITTING) && (k === GeometryType.VERTICAL)) || ((this._geometryType === GeometryType.VERTICAL) && (k === GeometryType.SITTING)) || ((this._geometryType === GeometryType.SNOWWARS_HORIZONTAL) && (k = GeometryType.SNOWWARS_HORIZONTAL))))
{
this._geometryType = k;
this._canvas = null;
this._geometryType = k;
this._canvas = null;
return;
}
this.disposeInactiveActions(0);
this._geometryType = k;
this._canvas = null;
this._geometryType = k;
this._canvas = null;
}
public getImageContainer(k: string, frameNumber: number, _arg_3: boolean = false): AvatarImageBodyPartContainer
@ -177,10 +177,10 @@ export class AvatarImageCache
if(_local_7.definition.startFromFrameZero) frameCount -= _local_7.startFrame;
let _local_8 = _local_7;
let _local_9: string[] = [];
let _local_10: Map<string, string> = new Map();
const _local_11 = new Point();
let _local_8 = _local_7;
let _local_9: string[] = [];
let _local_10: Map<string, string> = new Map();
const _local_11 = new Point();
if(!((!(_local_7)) || (!(_local_7.definition))))
{
@ -332,10 +332,10 @@ export class AvatarImageCache
if(!this._canvas) return null;
}
const isFlipped = AvatarDirectionAngle.DIRECTION_IS_FLIPPED[direction] || false;
const isFlipped = AvatarDirectionAngle.DIRECTION_IS_FLIPPED[direction] || false;
let assetPartDefinition = _arg_4.definition.assetPartDefinition;
let isCacheable = true;
let containerIndex = (containers.length - 1);
let isCacheable = true;
let containerIndex = (containers.length - 1);
while(containerIndex >= 0)
{
@ -347,10 +347,10 @@ export class AvatarImageCache
{
if(!((container.partType === 'ri') && !container.partId))
{
const partId = container.partId;
const animationFrame = container.getFrameDefinition(frameCount);
const partId = container.partId;
const animationFrame = container.getFrameDefinition(frameCount);
let partType = container.partType;
let partType = container.partType;
let frameNumber = 0;
if(animationFrame)
@ -361,8 +361,8 @@ export class AvatarImageCache
}
else frameNumber = container.getFrameIndex(frameCount);
let assetDirection = direction;
let flipH = false;
let assetDirection = direction;
let flipH = false;
if(isFlipped)
{
@ -372,21 +372,21 @@ export class AvatarImageCache
}
else
{
if(direction === 4) assetDirection = 2;
else if(direction === 5) assetDirection = 1;
else if(direction === 6) assetDirection = 0;
if(direction === 4) assetDirection = 2;
else if(direction === 5) assetDirection = 1;
else if(direction === 6) assetDirection = 0;
if(container.flippedPartType !== partType) partType = container.flippedPartType;
}
}
let assetName = (this._scale + '_' + assetPartDefinition + '_' + partType + '_' + partId + '_' + assetDirection + '_' + frameNumber);
let asset = this._assets.getAsset(assetName);
let assetName = (this._scale + '_' + assetPartDefinition + '_' + partType + '_' + partId + '_' + assetDirection + '_' + frameNumber);
let asset = this._assets.getAsset(assetName);
if(!asset)
{
assetName = (this._scale + '_std_' + partType + '_' + partId + '_' + assetDirection + '_0');
asset = this._assets.getAsset(assetName);
assetName = (this._scale + '_std_' + partType + '_' + partId + '_' + assetDirection + '_0');
asset = this._assets.getAsset(assetName);
}
if(asset)
@ -409,13 +409,13 @@ export class AvatarImageCache
{
const spriteData = new RoomObjectSpriteData();
spriteData.name = this._assets.getAssetName(assetName);
spriteData.x = (-(offset.x) - 33);
spriteData.y = -(offset.y);
spriteData.z = (this._serverRenderData.length * -0.0001);
spriteData.width = asset.rectangle.width;
spriteData.height = asset.rectangle.height;
spriteData.flipH = flipH;
spriteData.name = this._assets.getAssetName(assetName);
spriteData.x = (-(offset.x) - 33);
spriteData.y = -(offset.y);
spriteData.z = (this._serverRenderData.length * -0.0001);
spriteData.width = asset.rectangle.width;
spriteData.height = asset.rectangle.height;
spriteData.flipH = flipH;
if(assetPartDefinition === 'lay') spriteData.x = (spriteData.x + 53);
@ -443,9 +443,9 @@ export class AvatarImageCache
if(!this._unionImages.length) return null;
const imageData = this.createUnionImage(this._unionImages, isFlipped);
const canvasOffset = ((this._scale === AvatarScaleType.LARGE) ? (this._canvas.height - 16) : (this._canvas.height - 8));
const offset = new Point(-(imageData.regPoint.x), (canvasOffset - imageData.regPoint.y));
const imageData = this.createUnionImage(this._unionImages, isFlipped);
const canvasOffset = ((this._scale === AvatarScaleType.LARGE) ? (this._canvas.height - 16) : (this._canvas.height - 8));
const offset = new Point(-(imageData.regPoint.x), (canvasOffset - imageData.regPoint.y));
if(isFlipped && (assetPartDefinition !== 'lay')) offset.x = (offset.x + ((this._scale === AvatarScaleType.LARGE) ? 67 : 31));
@ -479,13 +479,13 @@ export class AvatarImageCache
for(const data of k) data && bounds.enlarge(data.offsetRect);
const point = new Point(-(bounds.x), -(bounds.y));
const point = new Point(-(bounds.x), -(bounds.y));
const container = new NitroContainer();
const sprite = new NitroSprite(Texture.EMPTY);
sprite.width = bounds.width;
sprite.height = bounds.height;
sprite.width = bounds.width;
sprite.height = bounds.height;
container.addChild(sprite);
@ -493,10 +493,10 @@ export class AvatarImageCache
{
if(!data) continue;
const texture = data.texture;
const color = data.colorTransform;
const flipH = (!(isFlipped && data.flipH) && (isFlipped || data.flipH));
const regPoint = point.clone();
const texture = data.texture;
const color = data.colorTransform;
const flipH = (!(isFlipped && data.flipH) && (isFlipped || data.flipH));
const regPoint = point.clone();
regPoint.x -= data.regPoint.x;
regPoint.y -= data.regPoint.y;
@ -505,7 +505,7 @@ export class AvatarImageCache
if(flipH)
{
this._matrix.a = -1;
this._matrix.a = -1;
this._matrix.tx = ((data.rect.x + data.rect.width) + regPoint.x);
this._matrix.ty = (regPoint.y - data.rect.y);
}

View File

@ -8,8 +8,8 @@ export class AvatarImageDirectionCache
constructor(k: AvatarImagePartContainer[])
{
this._partList = k;
this._images = new Map();
this._partList = k;
this._images = new Map();
}
public dispose(): void

View File

@ -13,21 +13,21 @@ export class ImageData
constructor(texture: Texture<Resource>, rectangle: Rectangle, _arg_3: Point, flipH: boolean, color: number, container: Container = null)
{
this._texture = texture;
this._texture = texture;
this._container = container;
this._rect = rectangle;
this._regPoint = _arg_3;
this._flipH = flipH;
this._colorTransform = color;
this._rect = rectangle;
this._regPoint = _arg_3;
this._flipH = flipH;
this._colorTransform = color;
if(flipH) this._regPoint.x = (-(this._regPoint.x) + rectangle.width);
}
public dispose(): void
{
this._texture = null;
this._regPoint = null;
this._colorTransform = null;
this._texture = null;
this._regPoint = null;
this._colorTransform = null;
}
public get texture(): Texture<Resource>

View File

@ -1,51 +1,51 @@
export class AvatarAction
{
public static CARRY_OBJECT = 'cri';
public static DANCE = 'dance';
public static EFFECT = 'fx';
public static EXPRESSION = 'expression';
public static EXPRESSION_BLOW_A_KISS = 'blow';
public static EXPRESSION_CRY = 'cry';
public static EXPRESSION_IDLE = 'idle';
public static EXPRESSION_LAUGH = 'laugh';
public static EXPRESSION_RESPECT = 'respect';
public static EXPRESSION_RIDE_JUMP = 'ridejump';
public static CARRY_OBJECT = 'cri';
public static DANCE = 'dance';
public static EFFECT = 'fx';
public static EXPRESSION = 'expression';
public static EXPRESSION_BLOW_A_KISS = 'blow';
public static EXPRESSION_CRY = 'cry';
public static EXPRESSION_IDLE = 'idle';
public static EXPRESSION_LAUGH = 'laugh';
public static EXPRESSION_RESPECT = 'respect';
public static EXPRESSION_RIDE_JUMP = 'ridejump';
public static EXPRESSION_SNOWBOARD_OLLIE = 'sbollie';
public static EXPRESSION_SNOWBORD_360 = 'sb360';
public static EXPRESSION_WAVE = 'wave';
public static GESTURE = 'gest';
public static GESTURE_AGGRAVATED = 'agr';
public static GESTURE_SAD = 'sad';
public static GESTURE_SMILE = 'sml';
public static GESTURE_SURPRISED = 'srp';
public static GUIDE_STATUS = 'guide';
public static MUTED = 'muted';
public static PET_GESTURE_BLINK = 'eyb';
public static PET_GESTURE_CRAZY = 'crz';
public static PET_GESTURE_JOY = 'joy';
public static PET_GESTURE_MISERABLE = 'mis';
public static PET_GESTURE_PUZZLED = 'puz';
public static PET_GESTURE_TONGUE = 'tng';
public static PLAYING_GAME = 'playing_game';
public static POSTURE = 'posture';
public static POSTURE_FLOAT = 'float';
public static POSTURE_LAY = 'lay';
public static POSTURE_SIT = 'sit';
public static POSTURE_STAND = 'std';
public static POSTURE_SWIM = 'swim';
public static POSTURE_WALK = 'mv';
public static SIGN = 'sign';
public static SLEEP = 'sleep';
public static SNOWWAR_DIE_BACK = 'swdieback';
public static SNOWWAR_DIE_FRONT = 'swdiefront';
public static SNOWWAR_PICK = 'swpick';
public static SNOWWAR_RUN = 'swrun';
public static SNOWWAR_THROW = 'swthrow';
public static TALK = 'talk';
public static BLINK = 'blink';
public static TYPING = 'typing';
public static USE_OBJECT = 'usei';
public static VOTE = 'vote';
public static EXPRESSION_SNOWBORD_360 = 'sb360';
public static EXPRESSION_WAVE = 'wave';
public static GESTURE = 'gest';
public static GESTURE_AGGRAVATED = 'agr';
public static GESTURE_SAD = 'sad';
public static GESTURE_SMILE = 'sml';
public static GESTURE_SURPRISED = 'srp';
public static GUIDE_STATUS = 'guide';
public static MUTED = 'muted';
public static PET_GESTURE_BLINK = 'eyb';
public static PET_GESTURE_CRAZY = 'crz';
public static PET_GESTURE_JOY = 'joy';
public static PET_GESTURE_MISERABLE = 'mis';
public static PET_GESTURE_PUZZLED = 'puz';
public static PET_GESTURE_TONGUE = 'tng';
public static PLAYING_GAME = 'playing_game';
public static POSTURE = 'posture';
public static POSTURE_FLOAT = 'float';
public static POSTURE_LAY = 'lay';
public static POSTURE_SIT = 'sit';
public static POSTURE_STAND = 'std';
public static POSTURE_SWIM = 'swim';
public static POSTURE_WALK = 'mv';
public static SIGN = 'sign';
public static SLEEP = 'sleep';
public static SNOWWAR_DIE_BACK = 'swdieback';
public static SNOWWAR_DIE_FRONT = 'swdiefront';
public static SNOWWAR_PICK = 'swpick';
public static SNOWWAR_RUN = 'swrun';
public static SNOWWAR_THROW = 'swthrow';
public static TALK = 'talk';
public static BLINK = 'blink';
public static TYPING = 'typing';
public static USE_OBJECT = 'usei';
public static VOTE = 'vote';
public static GESTURE_MAP = [ '', AvatarAction.GESTURE_SMILE, AvatarAction.GESTURE_AGGRAVATED, AvatarAction.GESTURE_SURPRISED, AvatarAction.GESTURE_SAD, AvatarAction.PET_GESTURE_JOY, AvatarAction.PET_GESTURE_CRAZY, AvatarAction.PET_GESTURE_TONGUE, AvatarAction.PET_GESTURE_BLINK, AvatarAction.PET_GESTURE_MISERABLE, AvatarAction.PET_GESTURE_PUZZLED ];
@ -108,19 +108,19 @@ export class AvatarAction
public static idToAvatarActionState(id: string): string
{
if(id === 'Lay') return 'lay';
if(id === 'Float') return 'float';
if(id === 'Swim') return 'swim';
if(id === 'Sit') return 'sit';
if(id === 'Respect') return 'respect';
if(id === 'Wave') return 'wave';
if(id === 'Idle') return 'idle';
if(id === 'Dance') return 'dance';
if(id === 'UseItem') return 'usei';
if(id === 'CarryItem') return 'cri';
if(id === 'Talk') return 'talk';
if(id === 'Sleep') return 'Sleep';
if(id === 'Move') return 'mv';
if(id === 'Lay') return 'lay';
if(id === 'Float') return 'float';
if(id === 'Swim') return 'swim';
if(id === 'Sit') return 'sit';
if(id === 'Respect') return 'respect';
if(id === 'Wave') return 'wave';
if(id === 'Idle') return 'idle';
if(id === 'Dance') return 'dance';
if(id === 'UseItem') return 'usei';
if(id === 'CarryItem') return 'cri';
if(id === 'Talk') return 'talk';
if(id === 'Sleep') return 'Sleep';
if(id === 'Move') return 'mv';
return 'std';
}

View File

@ -1,7 +1,7 @@
export class AvatarDirectionAngle
{
public static DIRECTION_TO_ANGLE: number[] = [45, 90, 135, 180, 225, 270, 315, 0]; //_Str_2204
public static DIRECTION_IS_FLIPPED: boolean[] = [false, false, false, false, true, true, true, false]; //_Str_1859
public static MIN_DIRECTION: number = 0; //_Str_1562
public static MAX_DIRECTION: number = 7; //_Str_1257
public static DIRECTION_TO_ANGLE: number[] = [45, 90, 135, 180, 225, 270, 315, 0]; //_Str_2204
public static DIRECTION_IS_FLIPPED: boolean[] = [false, false, false, false, true, true, true, false]; //_Str_1859
public static MIN_DIRECTION: number = 0; //_Str_1562
public static MAX_DIRECTION: number = 7; //_Str_1257
}

View File

@ -1,10 +1,10 @@
export class AvatarEditorFigureCategory
{
public static GENERIC: string = 'hd';
public static HEAD: string = 'head';
public static TORSO: string = 'torso';
public static LEGS: string = 'legs';
public static HOTLOOKS: string = 'hotlooks';
public static WARDROBE: string = 'wardrobe';
public static EFFECTS: string = 'effects';
public static GENERIC: string = 'hd';
public static HEAD: string = 'head';
public static TORSO: string = 'torso';
public static LEGS: string = 'legs';
public static HOTLOOKS: string = 'hotlooks';
public static WARDROBE: string = 'wardrobe';
public static EFFECTS: string = 'effects';
}

View File

@ -1,7 +1,7 @@
export class AvatarEditorInstanceId
{
public static OWN_AVATAR_EDITOR: number = 0;
public static FURNITURE_AVATAR_EDITOR: number = 1;
public static BOT_EDITOR: number = 2;
public static DEV_TOOL_EDITOR: number = 3;
public static OWN_AVATAR_EDITOR: number = 0;
public static FURNITURE_AVATAR_EDITOR: number = 1;
public static BOT_EDITOR: number = 2;
public static DEV_TOOL_EDITOR: number = 3;
}

View File

@ -1,5 +1,5 @@
export class AvatarEditorSideCategory
{
public static NOTHING: string = 'nothing';
public static WARDROBE: string = 'wardrobe';
public static NOTHING: string = 'nothing';
public static WARDROBE: string = 'wardrobe';
}

View File

@ -1,29 +1,29 @@
export class AvatarFigurePartType
{
public static BODY: string = 'bd';
public static SHOES: string = 'sh';
public static LEGS: string = 'lg';
public static CHEST: string = 'ch';
public static WAIST_ACCESSORY: string = 'wa';
public static CHEST_ACCESSORY: string = 'ca';
public static HEAD: string = 'hd';
public static HAIR: string = 'hr';
public static FACE_ACCESSORY: string = 'fa';
public static EYE_ACCESSORY: string = 'ea';
public static HEAD_ACCESSORY: string = 'ha';
public static BODY: string = 'bd';
public static SHOES: string = 'sh';
public static LEGS: string = 'lg';
public static CHEST: string = 'ch';
public static WAIST_ACCESSORY: string = 'wa';
public static CHEST_ACCESSORY: string = 'ca';
public static HEAD: string = 'hd';
public static HAIR: string = 'hr';
public static FACE_ACCESSORY: string = 'fa';
public static EYE_ACCESSORY: string = 'ea';
public static HEAD_ACCESSORY: string = 'ha';
public static HEAD_ACCESSORY_EXTRA: string = 'he';
public static COAT_CHEST: string = 'cc';
public static CHEST_PRINT: string = 'cp';
public static LEFT_HAND_ITEM: string = 'li';
public static LEFT_HAND: string = 'lh';
public static LEFT_SLEEVE: string = 'ls';
public static RIGHT_HAND: string = 'rh';
public static RIGHT_SLEEVE: string = 'rs';
public static FACE: string = 'fc';
public static EYES: string = 'ey';
public static HAIR_BIG: string = 'hrb';
public static RIGHT_HAND_ITEM: string = 'ri';
public static LEFT_COAT_SLEEVE: string = 'lc';
public static RIGHT_COAT_SLEEVE: string = 'rc';
public static FIGURE_SETS: string[] = [ AvatarFigurePartType.SHOES, AvatarFigurePartType.LEGS, AvatarFigurePartType.CHEST, AvatarFigurePartType.WAIST_ACCESSORY, AvatarFigurePartType.CHEST_ACCESSORY, AvatarFigurePartType.HEAD, AvatarFigurePartType.HAIR, AvatarFigurePartType.FACE_ACCESSORY, AvatarFigurePartType.EYE_ACCESSORY, AvatarFigurePartType.HEAD_ACCESSORY, AvatarFigurePartType.HEAD_ACCESSORY_EXTRA, AvatarFigurePartType.COAT_CHEST, AvatarFigurePartType.CHEST_PRINT ];
public static COAT_CHEST: string = 'cc';
public static CHEST_PRINT: string = 'cp';
public static LEFT_HAND_ITEM: string = 'li';
public static LEFT_HAND: string = 'lh';
public static LEFT_SLEEVE: string = 'ls';
public static RIGHT_HAND: string = 'rh';
public static RIGHT_SLEEVE: string = 'rs';
public static FACE: string = 'fc';
public static EYES: string = 'ey';
public static HAIR_BIG: string = 'hrb';
public static RIGHT_HAND_ITEM: string = 'ri';
public static LEFT_COAT_SLEEVE: string = 'lc';
public static RIGHT_COAT_SLEEVE: string = 'rc';
public static FIGURE_SETS: string[] = [ AvatarFigurePartType.SHOES, AvatarFigurePartType.LEGS, AvatarFigurePartType.CHEST, AvatarFigurePartType.WAIST_ACCESSORY, AvatarFigurePartType.CHEST_ACCESSORY, AvatarFigurePartType.HEAD, AvatarFigurePartType.HAIR, AvatarFigurePartType.FACE_ACCESSORY, AvatarFigurePartType.EYE_ACCESSORY, AvatarFigurePartType.HEAD_ACCESSORY, AvatarFigurePartType.HEAD_ACCESSORY_EXTRA, AvatarFigurePartType.COAT_CHEST, AvatarFigurePartType.CHEST_PRINT ];
}

View File

@ -1,6 +1,6 @@
export class AvatarGuideStatus
{
public static NONE: number = 0;
public static GUIDE: number = 1;
public static NONE: number = 0;
public static GUIDE: number = 1;
public static REQUESTER: number = 2;
}

View File

@ -1,8 +1,8 @@
export class GeometryType
{
public static VERTICAL: string = 'vertical';
public static SITTING: string = 'sitting';
public static HORIZONTAL: string = 'horizontal';
public static SWIM: string = 'swim';
public static VERTICAL: string = 'vertical';
public static SITTING: string = 'sitting';
public static HORIZONTAL: string = 'horizontal';
public static SWIM: string = 'swim';
public static SNOWWARS_HORIZONTAL: string = 'swhorizontal';
}

View File

@ -1,7 +1,7 @@
export class RenderMode
{
public static TOOL: string = 'tool';
public static COMPONENT: string = 'component';
public static ONLINE_TOOL: string = 'online_tool';
public static LOCAL_ONLY: string = 'local_only';
public static TOOL: string = 'tool';
public static COMPONENT: string = 'component';
public static ONLINE_TOOL: string = 'online_tool';
public static LOCAL_ONLY: string = 'local_only';
}

View File

@ -16,12 +16,12 @@ export class AvatarModelGeometry
constructor(k: any)
{
this._camera = new Vector3D(0, 0, 10);
this._avatarSet = new AvatarSet(k.avatarSets[0]);
this._geometryTypes = new Map();
this._itemIdToBodyPartMap = new Map();
this._transformation = new Matrix4x4();
this._canvases = new Map();
this._camera = new Vector3D(0, 0, 10);
this._avatarSet = new AvatarSet(k.avatarSets[0]);
this._geometryTypes = new Map();
this._itemIdToBodyPartMap = new Map();
this._transformation = new Matrix4x4();
this._canvases = new Map();
const camera = k.camera;
@ -38,8 +38,8 @@ export class AvatarModelGeometry
{
if(!canvas) continue;
const scale = canvas.scale;
const geometries = new Map();
const scale = canvas.scale;
const geometries = new Map();
if(canvas.geometries && (canvas.geometries.length > 0))
{
@ -63,8 +63,8 @@ export class AvatarModelGeometry
{
if(!type) continue;
const bodyParts: Map<string, GeometryBodyPart> = new Map();
const itemIds: Map<string, GeometryBodyPart> = new Map();
const bodyParts: Map<string, GeometryBodyPart> = new Map();
const itemIds: Map<string, GeometryBodyPart> = new Map();
if(type.bodyParts && (type.bodyParts.length > 0))
{
@ -211,7 +211,7 @@ export class AvatarModelGeometry
private getBodyPartsInAvatarSet(k: Map<string, GeometryBodyPart>, _arg_2: string): GeometryBodyPart[]
{
const parts = this.getBodyPartIdsInAvatarSet(_arg_2);
const parts = this.getBodyPartIdsInAvatarSet(_arg_2);
const geometryParts = [];
for(const part of parts)
@ -233,10 +233,10 @@ export class AvatarModelGeometry
{
if(!_arg_3) return [];
const geometryParts = this.getBodyPartsOfType(_arg_3);
const parts = this.getBodyPartsInAvatarSet(geometryParts, k);
const sets: [ number, GeometryBodyPart ][] = [];
const ids: string[] = [];
const geometryParts = this.getBodyPartsOfType(_arg_3);
const parts = this.getBodyPartsInAvatarSet(geometryParts, k);
const sets: [ number, GeometryBodyPart ][] = [];
const ids: string[] = [];
this._transformation = Matrix4x4.getYRotationMatrix(_arg_2);

View File

@ -8,11 +8,11 @@
constructor(k: any)
{
this._id = k.id;
this._isMain = k.main || false;
this._avatarSets = new Map();
this._bodyParts = [];
this._allBodyParts = [];
this._id = k.id;
this._isMain = k.main || false;
this._avatarSets = new Map();
this._bodyParts = [];
this._allBodyParts = [];
if(k.avatarSets && (k.avatarSets.length > 0))
{

View File

@ -15,10 +15,10 @@ export class GeometryBodyPart extends Node3D
{
super(parseFloat(k.x), parseFloat(k.y), parseFloat(k.z));
this._id = k.id;
this._radius = parseFloat(k.radius);
this._parts = new Map();
this._dynamicParts = new Map();
this._id = k.id;
this._radius = parseFloat(k.radius);
this._parts = new Map();
this._dynamicParts = new Map();
if(k.items && (k.items.length > 0))
{
@ -35,7 +35,7 @@ export class GeometryBodyPart extends Node3D
public getDynamicParts(k: IAvatarImage): GeometryItem[]
{
const existing = this._dynamicParts.get(k);
const existing = this._dynamicParts.get(k);
const parts: GeometryItem[] = [];
if(existing)

View File

@ -13,14 +13,14 @@ export class GeometryItem extends Node3D
{
super(parseFloat(k.x), parseFloat(k.y), parseFloat(k.z));
this._id = k.id;
this._radius = parseFloat(k.radius);
this._normal = new Vector3D(parseFloat(k.nx), parseFloat(k.ny), parseFloat(k.nz));
this._id = k.id;
this._radius = parseFloat(k.radius);
this._normal = new Vector3D(parseFloat(k.nx), parseFloat(k.ny), parseFloat(k.nz));
this._isDoubleSided = k.double || false;
this._isDynamic = _arg_2;
this._isDynamic = _arg_2;
}
public getDistance(k: Vector3D): number
public getDistance(k: Vector3D): number
{
const _local_2 = Math.abs(((k.z - this.transformedLocation.z) - this._radius));
const _local_3 = Math.abs(((k.z - this.transformedLocation.z) + this._radius));

View File

@ -2,8 +2,8 @@
export class Matrix4x4
{
public static IDENTITY:Matrix4x4 = new Matrix4x4(1, 0, 0, 0, 1, 0, 0, 0, 1);
private static TOLERANS: number = 1E-18;
public static IDENTITY:Matrix4x4 = new Matrix4x4(1, 0, 0, 0, 1, 0, 0, 0, 1);
private static TOLERANS: number = 1E-18;
private _data: number[];
@ -57,14 +57,14 @@ export class Matrix4x4
public multiply(k:Matrix4x4): Matrix4x4
{
const _local_2 = (((this._data[0] * k.data[0]) + (this._data[1] * k.data[3])) + (this._data[2] * k.data[6]));
const _local_3 = (((this._data[0] * k.data[1]) + (this._data[1] * k.data[4])) + (this._data[2] * k.data[7]));
const _local_4 = (((this._data[0] * k.data[2]) + (this._data[1] * k.data[5])) + (this._data[2] * k.data[8]));
const _local_5 = (((this._data[3] * k.data[0]) + (this._data[4] * k.data[3])) + (this._data[5] * k.data[6]));
const _local_6 = (((this._data[3] * k.data[1]) + (this._data[4] * k.data[4])) + (this._data[5] * k.data[7]));
const _local_7 = (((this._data[3] * k.data[2]) + (this._data[4] * k.data[5])) + (this._data[5] * k.data[8]));
const _local_8 = (((this._data[6] * k.data[0]) + (this._data[7] * k.data[3])) + (this._data[8] * k.data[6]));
const _local_9 = (((this._data[6] * k.data[1]) + (this._data[7] * k.data[4])) + (this._data[8] * k.data[7]));
const _local_2 = (((this._data[0] * k.data[0]) + (this._data[1] * k.data[3])) + (this._data[2] * k.data[6]));
const _local_3 = (((this._data[0] * k.data[1]) + (this._data[1] * k.data[4])) + (this._data[2] * k.data[7]));
const _local_4 = (((this._data[0] * k.data[2]) + (this._data[1] * k.data[5])) + (this._data[2] * k.data[8]));
const _local_5 = (((this._data[3] * k.data[0]) + (this._data[4] * k.data[3])) + (this._data[5] * k.data[6]));
const _local_6 = (((this._data[3] * k.data[1]) + (this._data[4] * k.data[4])) + (this._data[5] * k.data[7]));
const _local_7 = (((this._data[3] * k.data[2]) + (this._data[4] * k.data[5])) + (this._data[5] * k.data[8]));
const _local_8 = (((this._data[6] * k.data[0]) + (this._data[7] * k.data[3])) + (this._data[8] * k.data[6]));
const _local_9 = (((this._data[6] * k.data[1]) + (this._data[7] * k.data[4])) + (this._data[8] * k.data[7]));
const _local_10 = (((this._data[6] * k.data[2]) + (this._data[7] * k.data[5])) + (this._data[8] * k.data[8]));
return new Matrix4x4(_local_2, _local_3, _local_4, _local_5, _local_6, _local_7, _local_8, _local_9, _local_10);

View File

@ -9,9 +9,9 @@ export class Node3D
constructor(k: number, _arg_2: number, _arg_3: number)
{
this._location = new Vector3D(k, _arg_2, _arg_3);
this._transformedLocation = new Vector3D();
this._needsTransformation = false;
this._location = new Vector3D(k, _arg_2, _arg_3);
this._transformedLocation = new Vector3D();
this._needsTransformation = false;
if(((!(k == 0)) || (!(_arg_2 == 0))) || (!(_arg_3 == 0))) this._needsTransformation = true;
}

View File

@ -6,8 +6,8 @@ export class PetCustomPart
constructor(layerId: number, partId: number, paletteId: number)
{
this._layerId = layerId;
this._partId = partId;
this._layerId = layerId;
this._partId = partId;
this._paletteId = paletteId;
}

View File

@ -14,17 +14,17 @@ export class PetFigureData
constructor(k: string)
{
this._typeId = this.getTypeId(k);
this._typeId = this.getTypeId(k);
this._paletteId = this.getPaletteId(k);
this._color = this.getColor(k);
this._headOnly = this.getHeadOnly(k);
this._color = this.getColor(k);
this._headOnly = this.getHeadOnly(k);
const _local_2 = this.getCustomData(k);
this._customLayerIds = this.getCustomLayerIds(_local_2);
this._customPartIds = this.getCustomPartIds(_local_2);
this._customPaletteIds = this.getCustomPaletteIds(_local_2);
this._customParts = [];
this._customLayerIds = this.getCustomLayerIds(_local_2);
this._customPartIds = this.getCustomPartIds(_local_2);
this._customPaletteIds = this.getCustomPaletteIds(_local_2);
this._customParts = [];
let i = 0;
@ -114,16 +114,16 @@ export class PetFigureData
if(k)
{
const _local_3 = k.split(' ');
const _local_4 = ((this._headOnly) ? 1 : 0);
const _local_5 = (4 + _local_4);
const _local_3 = k.split(' ');
const _local_4 = ((this._headOnly) ? 1 : 0);
const _local_5 = (4 + _local_4);
if(_local_3.length > _local_5)
{
const _local_6 = (3 + _local_4);
const _local_7 = parseInt(_local_3[_local_6]);
const _local_6 = (3 + _local_4);
const _local_7 = parseInt(_local_3[_local_6]);
_local_2 = _local_3.slice(_local_5, (_local_5 + (_local_7 * 3)));
_local_2 = _local_3.slice(_local_5, (_local_5 + (_local_7 * 3)));
}
}
@ -225,4 +225,4 @@ export class PetFigureData
return false;
}
}
}

View File

@ -1,38 +1,38 @@
export class PetType
{
public static DOG: number = 0;
public static CAT: number = 1;
public static CROCODILE: number = 2;
public static TERRIER: number = 3;
public static BEAR: number = 4;
public static PIG: number = 5;
public static LION: number = 6;
public static RHINO: number = 7;
public static SPIDER: number = 8;
public static TURTLE: number = 9;
public static CHICKEN: number = 10;
public static FROG: number = 11;
public static DRAGON: number = 12;
public static MONSTER: number = 13;
public static MONKEY: number = 14;
public static HORSE: number = 15;
public static MONSTERPLANT: number = 16;
public static BUNNY: number = 17;
public static BUNNYEVIL: number = 18;
public static DOG: number = 0;
public static CAT: number = 1;
public static CROCODILE: number = 2;
public static TERRIER: number = 3;
public static BEAR: number = 4;
public static PIG: number = 5;
public static LION: number = 6;
public static RHINO: number = 7;
public static SPIDER: number = 8;
public static TURTLE: number = 9;
public static CHICKEN: number = 10;
public static FROG: number = 11;
public static DRAGON: number = 12;
public static MONSTER: number = 13;
public static MONKEY: number = 14;
public static HORSE: number = 15;
public static MONSTERPLANT: number = 16;
public static BUNNY: number = 17;
public static BUNNYEVIL: number = 18;
public static BUNNYDEPRESSED: number = 19;
public static BUNNYLOVE: number = 20;
public static PIGEONGOOD: number = 21;
public static PIGEONEVIL: number = 22;
public static DEMONMONKEY: number = 23;
public static BABYBEAR: number = 24;
public static BABYTERRIER: number = 25;
public static GNOME: number = 26;
public static LEPRECHAUN: number = 27;
public static KITTENBABY: number = 28;
public static PUPPYBABY: number = 29;
public static PIGLETNBABY: number = 30;
public static HALOOMPA: number = 31;
public static FOOLS: number = 32;
public static PTEROSAUR: number = 33;
public static VELOCIRAPTOR: number = 34;
public static BUNNYLOVE: number = 20;
public static PIGEONGOOD: number = 21;
public static PIGEONEVIL: number = 22;
public static DEMONMONKEY: number = 23;
public static BABYBEAR: number = 24;
public static BABYTERRIER: number = 25;
public static GNOME: number = 26;
public static LEPRECHAUN: number = 27;
public static KITTENBABY: number = 28;
public static PUPPYBABY: number = 29;
public static PIGLETNBABY: number = 30;
public static HALOOMPA: number = 31;
public static FOOLS: number = 32;
public static PTEROSAUR: number = 33;
public static VELOCIRAPTOR: number = 34;
}

View File

@ -11,10 +11,10 @@ export class AvatarCanvas
constructor(k: any, _arg_2: string)
{
this._id = k.id;
this._width = k.width;
this._height = k.height;
this._offset = new Point(k.dx, k.dy);
this._id = k.id;
this._width = k.width;
this._height = k.height;
this._offset = new Point(k.dx, k.dy);
if(_arg_2 == AvatarScaleType.LARGE) this._regPoint = new Point(((this._width - 64) / 2), 0);
else this._regPoint = new Point(((this._width - 32) / 2), 0);

View File

@ -14,8 +14,8 @@ export class FigureSetData implements IFigureSetData, IStructureData
constructor()
{
this._palettes = new Map();
this._setTypes = new Map();
this._palettes = new Map();
this._setTypes = new Map();
}
public dispose(): void

View File

@ -11,8 +11,8 @@ export class PartSetsData implements IFigureSetData
constructor()
{
this._parts = new Map();
this._activePartSets = new Map();
this._parts = new Map();
this._activePartSets = new Map();
}
public parse(data: any): boolean

View File

@ -13,11 +13,11 @@ export class AnimationAction
constructor(data: any)
{
this._id = data.id;
this._actionParts = new Map();
this._bodyPartOffsets = new Map();
this._frameCount = 0;
this._frameIndexes = [];
this._id = data.id;
this._actionParts = new Map();
this._bodyPartOffsets = new Map();
this._frameCount = 0;
this._frameIndexes = [];
if(data.parts && (data.parts.length > 0))
{
@ -104,9 +104,9 @@ export class AnimationAction
public getFrameBodyPartOffset(frameId: number, frameCount: number, partId: string): Point
{
const frameIndex = (frameCount % this._frameIndexes.length);
const frameNumber = this._frameIndexes[frameIndex];
const offsets = this._bodyPartOffsets.get(frameNumber);
const frameIndex = (frameCount % this._frameIndexes.length);
const frameNumber = this._frameIndexes[frameIndex];
const offsets = this._bodyPartOffsets.get(frameNumber);
if(!offsets) return AnimationAction.DEFAULT_OFFSET;

View File

@ -5,8 +5,8 @@ export class AvatarAnimationFrame
constructor(data: any)
{
this._number = data.number;
this._assetPartDefinition = data.assetPartDefinition || null;
this._number = data.number;
this._assetPartDefinition = data.assetPartDefinition || null;
}
public get number(): number

View File

@ -14,12 +14,12 @@ export class FigurePart implements IFigurePart
{
if(!data) throw new Error('invalid_data');
this._id = data.id;
this._type = data.type;
this._index = data.index;
this._colorLayerIndex = data.colorindex;
this._paletteMapId = -1;
this._breed = -1;
this._id = data.id;
this._type = data.type;
this._index = data.index;
this._colorLayerIndex = data.colorindex;
this._paletteMapId = -1;
this._breed = -1;
}
public dispose(): void

View File

@ -20,20 +20,20 @@ export class FigurePartSet implements IFigurePartSet
{
if(!type || !data) throw new Error('invalid_data');
this._id = data.id;
this._type = type;
this._gender = data.gender;
this._clubLevel = data.club;
this._isColorable = data.colorable;
this._isSelectable = data.selectable;
this._parts = [];
this._hiddenLayers = [];
this._isPreSelectable = data.preselectable;
this._isSellable = data.sellable;
this._id = data.id;
this._type = type;
this._gender = data.gender;
this._clubLevel = data.club;
this._isColorable = data.colorable;
this._isSelectable = data.selectable;
this._parts = [];
this._hiddenLayers = [];
this._isPreSelectable = data.preselectable;
this._isSellable = data.sellable;
for(const part of data.parts)
{
const newPart = new FigurePart(part);
const newPart = new FigurePart(part);
const partIndex = this.getPartIndex(newPart);
if(partIndex !== -1) this._parts.splice(partIndex, 0, newPart);
@ -55,8 +55,8 @@ export class FigurePartSet implements IFigurePartSet
figurePart.dispose();
}
this._parts = null;
this._hiddenLayers = null;
this._parts = null;
this._hiddenLayers = null;
}
private getPartIndex(part: FigurePart): number

View File

@ -13,8 +13,8 @@ export class Palette implements IPalette
{
if(!data) throw new Error('invalid_data');
this._id = data.id;
this._colors = new AdvancedMap();
this._id = data.id;
this._colors = new AdvancedMap();
this.append(data);
}

View File

@ -15,12 +15,12 @@ export class SetType implements ISetType
{
if(!data) throw new Error('invalid_data');
this._type = data.type;
this._paletteId = data.paletteId;
this._isMandatory = {};
this._isMandatory['F'] = [ data.mandatory_f_0, data.mandatory_f_1 ];
this._isMandatory['M'] = [ data.mandatory_m_0, data.mandatory_m_1 ];
this._partSets = new AdvancedMap();
this._type = data.type;
this._paletteId = data.paletteId;
this._isMandatory = {};
this._isMandatory['F'] = [ data.mandatory_f_0, data.mandatory_f_1 ];
this._isMandatory['M'] = [ data.mandatory_m_0, data.mandatory_m_1 ];
this._partSets = new AdvancedMap();
this.append(data);
}

View File

@ -5,7 +5,7 @@ export class ActivePartSet
constructor(data: any)
{
this._id = data.id;
this._id = data.id;
this._parts = [];
if(data.activeParts && (data.activeParts.length > 0))

View File

@ -10,11 +10,11 @@ export class PartDefinition
{
if(!data) throw new Error('invalid_data');
this._setType = data.setType;
this._flippedSetType = data.flippedSetType || null;
this._removeSetType = data.removeSetType || null;
this._appendToFigure = false;
this._staticId = -1;
this._setType = data.setType;
this._flippedSetType = data.flippedSetType || null;
this._removeSetType = data.removeSetType || null;
this._appendToFigure = false;
this._staticId = -1;
}
public hasStaticId(): boolean

View File

@ -12,11 +12,11 @@ export class RoomCameraWidgetEffect implements IRoomCameraWidgetEffect
constructor(name: string, minLevel: number = -1, texture: Texture<Resource> = null, colorMatrix: ColorMatrix = null, blendMode: number = null)
{
this._name = name;
this._minLevel = minLevel;
this._texture = texture;
this._colorMatrix = colorMatrix;
this._blendMode = blendMode;
this._name = name;
this._minLevel = minLevel;
this._texture = texture;
this._colorMatrix = colorMatrix;
this._blendMode = blendMode;
}
public get name(): string

View File

@ -17,9 +17,9 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
constructor()
{
this._effects = new Map();
this._events = new EventDispatcher();
this._isLoaded = false;
this._effects = new Map();
this._events = new EventDispatcher();
this._isLoaded = false;
}
public init(): void
@ -29,7 +29,7 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
this._isLoaded = true;
const imagesUrl = Nitro.instance.getConfiguration<string>('image.library.url') + 'Habbo-Stories/';
const effects = Nitro.instance.getConfiguration<{ name: string, colorMatrix?: ColorMatrix, minLevel: number, blendMode?: number, enabled: boolean }[]>('camera.available.effects');
const effects = Nitro.instance.getConfiguration<{ name: string, colorMatrix?: ColorMatrix, minLevel: number, blendMode?: number, enabled: boolean }[]>('camera.available.effects');
for(const effect of effects)
{
@ -43,8 +43,8 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
}
else
{
cameraEffect.texture = Texture.from(imagesUrl + effect.name + '.png');
cameraEffect.blendMode = effect.blendMode;
cameraEffect.texture = Texture.from(imagesUrl + effect.name + '.png');
cameraEffect.blendMode = effect.blendMode;
}
this._effects.set(cameraEffect.name, cameraEffect);
@ -56,7 +56,7 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
public applyEffects(texture: Texture, selectedEffects: IRoomCameraWidgetSelectedEffect[], isZoomed: boolean): HTMLImageElement
{
const container = new NitroContainer();
const sprite = new NitroSprite(texture);
const sprite = new NitroSprite(texture);
container.addChild(sprite);
@ -70,8 +70,8 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
{
const filter = new ColorMatrixFilter();
filter.matrix = effect.colorMatrix;
filter.alpha = selectedEffect.alpha;
filter.matrix = effect.colorMatrix;
filter.alpha = selectedEffect.alpha;
if(!sprite.filters) sprite.filters = [];
@ -79,9 +79,9 @@ export class RoomCameraWidgetManager implements IRoomCameraWidgetManager
}
else
{
const effectSprite = new NitroSprite(effect.texture);
effectSprite.alpha = selectedEffect.alpha;
effectSprite.blendMode = effect.blendMode;
const effectSprite = new NitroSprite(effect.texture);
effectSprite.alpha = selectedEffect.alpha;
effectSprite.blendMode = effect.blendMode;
container.addChild(effectSprite);
}

View File

@ -7,8 +7,8 @@ export class RoomCameraWidgetSelectedEffect
constructor(effect: IRoomCameraWidgetEffect, alpha: number)
{
this._effect = effect;
this._alpha = alpha;
this._effect = effect;
this._alpha = alpha;
}
public get effect(): IRoomCameraWidgetEffect

View File

@ -25,14 +25,14 @@ export class NitroCommunicationManager extends NitroManager implements INitroCom
super();
this._communication = communication;
this._connection = null;
this._messages = new NitroMessages();
this._connection = null;
this._messages = new NitroMessages();
this._demo = new NitroCommunicationDemo(this);
this._demo = new NitroCommunicationDemo(this);
this.onConnectionOpenedEvent = this.onConnectionOpenedEvent.bind(this);
this.onConnectionClosedEvent = this.onConnectionClosedEvent.bind(this);
this.onConnectionErrorEvent = this.onConnectionErrorEvent.bind(this);
this.onConnectionOpenedEvent = this.onConnectionOpenedEvent.bind(this);
this.onConnectionClosedEvent = this.onConnectionClosedEvent.bind(this);
this.onConnectionErrorEvent = this.onConnectionErrorEvent.bind(this);
this.onConnectionAuthenticatedEvent = this.onConnectionAuthenticatedEvent.bind(this);
}

File diff suppressed because one or more lines are too long

View File

@ -16,7 +16,6 @@ export class NitroCommunicationDemo extends NitroManager
{
private _communication: INitroCommunicationManager;
private _sso: string;
private _handShaking: boolean;
private _didConnect: boolean;
@ -28,16 +27,15 @@ export class NitroCommunicationDemo extends NitroManager
this._communication = communication;
this._sso = null;
this._handShaking = false;
this._didConnect = false;
this._handShaking = false;
this._didConnect = false;
this._pongInterval = null;
this._pongInterval = null;
this.onConnectionOpenedEvent = this.onConnectionOpenedEvent.bind(this);
this.onConnectionClosedEvent = this.onConnectionClosedEvent.bind(this);
this.onConnectionErrorEvent = this.onConnectionErrorEvent.bind(this);
this.sendPong = this.sendPong.bind(this);
this.onConnectionOpenedEvent = this.onConnectionOpenedEvent.bind(this);
this.onConnectionClosedEvent = this.onConnectionClosedEvent.bind(this);
this.onConnectionErrorEvent = this.onConnectionErrorEvent.bind(this);
this.sendPong = this.sendPong.bind(this);
}
protected onInit(): void
@ -66,8 +64,7 @@ export class NitroCommunicationDemo extends NitroManager
connection.removeEventListener(SocketConnectionEvent.CONNECTION_ERROR, this.onConnectionErrorEvent);
}
this._sso = null;
this._handShaking = false;
this._handShaking = false;
this.stopPonging();
@ -117,9 +114,9 @@ export class NitroCommunicationDemo extends NitroManager
private tryAuthentication(connection: IConnection): void
{
if(!connection || !this._sso)
if(!connection || !this.getSSO())
{
if(!this._sso)
if(!this.getSSO())
{
NitroLogger.log('Login without an SSO ticket is not supported');
}
@ -129,7 +126,7 @@ export class NitroCommunicationDemo extends NitroManager
return;
}
connection.send(new SSOTicketMessageComposer(this._sso, Nitro.instance.time));
connection.send(new SSOTicketMessageComposer(this.getSSO(), Nitro.instance.time));
}
private onClientPingEvent(event: ClientPingEvent): void
@ -147,18 +144,9 @@ export class NitroCommunicationDemo extends NitroManager
this.dispatchCommunicationDemoEvent(NitroCommunicationDemoEvent.CONNECTION_AUTHENTICATED, event.connection);
//event.connection.send(new UserHomeRoomComposer(555));
event.connection.send(new InfoRetrieveMessageComposer());
}
public setSSO(sso: string): void
{
if(!sso || (sso === '') || this._sso) return;
this._sso = sso;
}
private startHandshake(connection: IConnection): void
{
this.dispatchCommunicationDemoEvent(NitroCommunicationDemoEvent.CONNECTION_HANDSHAKING, connection);
@ -202,4 +190,9 @@ export class NitroCommunicationDemo extends NitroManager
{
Nitro.instance.events.dispatchEvent(new NitroCommunicationDemoEvent(type, connection));
}
private getSSO(): string
{
return Nitro.instance.getConfiguration('sso.ticket', null);
}
}

View File

@ -3,13 +3,13 @@ import { NitroEvent } from '../../../core/events/NitroEvent';
export class NitroCommunicationDemoEvent extends NitroEvent
{
public static CONNECTION_ESTABLISHED = 'NCE_ESTABLISHED';
public static CONNECTION_CLOSED = 'NCE_CLOSED';
public static CONNECTION_ERROR = 'NCE_ERROR';
public static CONNECTION_HANDSHAKING = 'NCE_HANDSHAKING';
public static CONNECTION_HANDSHAKED = 'NCE_HANDSHAKED';
public static CONNECTION_HANDSHAKE_FAILED = 'NCE_HANDSHAKE_FAILED';
public static CONNECTION_AUTHENTICATED = 'NCE_AUTHENTICATED';
public static CONNECTION_ESTABLISHED = 'NCE_ESTABLISHED';
public static CONNECTION_CLOSED = 'NCE_CLOSED';
public static CONNECTION_ERROR = 'NCE_ERROR';
public static CONNECTION_HANDSHAKING = 'NCE_HANDSHAKING';
public static CONNECTION_HANDSHAKED = 'NCE_HANDSHAKED';
public static CONNECTION_HANDSHAKE_FAILED = 'NCE_HANDSHAKE_FAILED';
public static CONNECTION_AUTHENTICATED = 'NCE_AUTHENTICATED';
private _connection: IConnection;

View File

@ -1,366 +1,368 @@
export class IncomingHeader
{
public static ACHIEVEMENT_LIST = 305;
public static AUTHENTICATED = 2491;
public static AUTHENTICATION = -1;
public static AVAILABILITY_STATUS = 2033;
public static BUILDERS_CLUB_EXPIRED = 1452;
public static CLUB_OFFERS = 2405;
public static CATALOG_PAGE = 804;
public static CATALOG_PAGE_LIST = 1032;
public static CATALOG_PURCHASE_OK = 869;
public static CATALOG_PURCHASE_ERROR = 1404;
public static CATALOG_PURCHASE_NOT_ALLOWED = 3770;
public static PRODUCT_OFFER = 3388;
public static LIMITED_SOLD_OUT = 377;
public static CATALOG_PUBLISHED = 1866;
public static CFH_RESULT_MESSAGE = 3635;
public static CLIENT_LATENCY = 10;
public static CLIENT_PING = 3928;
public static DESKTOP_CAMPAIGN = 1745;
public static DESKTOP_NEWS = 286;
public static DESKTOP_VIEW = 122;
public static BUNDLE_DISCOUNT_RULESET = 2347;
public static FIRST_LOGIN_OF_DAY = 793;
public static FURNITURE_ALIASES = 1723;
public static FURNITURE_DATA = 2547;
public static FURNITURE_FLOOR = 1778;
public static FURNITURE_FLOOR_ADD = 1534;
public static FURNITURE_FLOOR_REMOVE = 2703;
public static FURNITURE_FLOOR_UPDATE = 3776;
public static FURNITURE_ITEMDATA = 2202;
public static FURNITURE_STATE = 2376;
public static ACHIEVEMENT_LIST = 305;
public static AUTHENTICATED = 2491;
public static AUTHENTICATION = -1;
public static AVAILABILITY_STATUS = 2033;
public static BUILDERS_CLUB_EXPIRED = 1452;
public static CLUB_OFFERS = 2405;
public static CATALOG_PAGE = 804;
public static CATALOG_PAGE_LIST = 1032;
public static CATALOG_PURCHASE_OK = 869;
public static CATALOG_PURCHASE_ERROR = 1404;
public static CATALOG_PURCHASE_NOT_ALLOWED = 3770;
public static PRODUCT_OFFER = 3388;
public static LIMITED_SOLD_OUT = 377;
public static CATALOG_PUBLISHED = 1866;
public static CFH_RESULT_MESSAGE = 3635;
public static CLIENT_LATENCY = 10;
public static CLIENT_PING = 3928;
public static DESKTOP_CAMPAIGN = 1745;
public static DESKTOP_NEWS = 286;
public static DESKTOP_VIEW = 122;
public static BUNDLE_DISCOUNT_RULESET = 2347;
public static FIRST_LOGIN_OF_DAY = 793;
public static FURNITURE_ALIASES = 1723;
public static FURNITURE_DATA = 2547;
public static FURNITURE_FLOOR = 1778;
public static FURNITURE_FLOOR_ADD = 1534;
public static FURNITURE_FLOOR_REMOVE = 2703;
public static FURNITURE_FLOOR_UPDATE = 3776;
public static FURNITURE_ITEMDATA = 2202;
public static FURNITURE_STATE = 2376;
public static FURNITURE_GROUP_CONTEXT_MENU_INFO = 3293;
public static FURNITURE_POSTIT_STICKY_POLE_OPEN = 2366;
public static GAME_CENTER_ACHIEVEMENTS = 2265;
public static GAME_CENTER_GAME_LIST = 222;
public static GAME_CENTER_STATUS = 2893;
public static GENERIC_ALERT = 3801;
public static MODERATOR_MESSAGE = 2030;
public static GENERIC_ERROR = 1600;
public static GIFT_WRAPPER_CONFIG = 2234;
public static GROUP_BADGES = 2402;
public static GROUP_CREATE_OPTIONS = 2159;
public static GROUP_FORUM_INFO = 3011;
public static GROUP_FORUM_LIST = 3001;
public static GROUP_FORUM_THREADS = 1073;
public static GROUP_INFO = 1702;
public static GROUP_LIST = 420;
public static GROUP_MEMBER = 265;
public static GROUP_MEMBERS = 1200;
public static GROUP_MEMBERS_REFRESH = 2445;
public static GROUP_MEMBER_REMOVE_CONFIRM = 1876;
public static GROUP_PURCHASED = 2808;
public static GROUP_SETTINGS = 3965;
public static GROUP_BADGE_PARTS = 2238;
public static ITEM_DIMMER_SETTINGS = 2710;
public static ITEM_STACK_HELPER = 2816;
public static ITEM_WALL = 1369;
public static ITEM_WALL_ADD = 2187;
public static ITEM_WALL_REMOVE = 3208;
public static ITEM_WALL_UPDATE = 2009;
public static LOAD_GAME_URL = 2624;
public static MARKETPLACE_CONFIG = 1823;
public static MESSENGER_ACCEPT_FRIENDS = 896;
public static MESSENGER_CHAT = 1587;
public static MESSENGER_FIND_FRIENDS = 1210;
public static MESSENGER_FOLLOW_FAILED = 3048;
public static MESSENGER_FRIEND_NOTIFICATION = 3082;
public static MESSENGER_FRIENDS = 3130;
public static MESSENGER_INIT = 1605;
public static GAME_CENTER_ACHIEVEMENTS = 2265;
public static GAME_CENTER_GAME_LIST = 222;
public static GAME_CENTER_STATUS = 2893;
public static GENERIC_ALERT = 3801;
public static MODERATOR_MESSAGE = 2030;
public static GENERIC_ERROR = 1600;
public static GIFT_WRAPPER_CONFIG = 2234;
public static GROUP_BADGES = 2402;
public static GROUP_CREATE_OPTIONS = 2159;
public static GROUP_FORUM_INFO = 3011;
public static GROUP_FORUM_LIST = 3001;
public static GROUP_FORUM_THREADS = 1073;
public static GROUP_INFO = 1702;
public static GROUP_LIST = 420;
public static GROUP_MEMBER = 265;
public static GROUP_MEMBERS = 1200;
public static GROUP_MEMBERS_REFRESH = 2445;
public static GROUP_MEMBER_REMOVE_CONFIRM = 1876;
public static GROUP_PURCHASED = 2808;
public static GROUP_SETTINGS = 3965;
public static GROUP_BADGE_PARTS = 2238;
public static ITEM_DIMMER_SETTINGS = 2710;
public static ITEM_STACK_HELPER = 2816;
public static ITEM_WALL = 1369;
public static ITEM_WALL_ADD = 2187;
public static ITEM_WALL_REMOVE = 3208;
public static ITEM_WALL_UPDATE = 2009;
public static LOAD_GAME_URL = 2624;
public static MARKETPLACE_CONFIG = 1823;
public static MESSENGER_ACCEPT_FRIENDS = 896;
public static MESSENGER_CHAT = 1587;
public static MESSENGER_FIND_FRIENDS = 1210;
public static MESSENGER_FOLLOW_FAILED = 3048;
public static MESSENGER_FRIEND_NOTIFICATION = 3082;
public static MESSENGER_FRIENDS = 3130;
public static MESSENGER_INIT = 1605;
public static MESSENGER_INSTANCE_MESSAGE_ERROR = 3359;
public static MESSENGER_INVITE = 3870;
public static MESSENGER_INVITE_ERROR = 462;
public static MESSENGER_MESSAGE_ERROR = 892;
public static MESSENGER_MINIMAIL_COUNT = 2803;
public static MESSENGER_MINIMAIL_NEW = 1911;
public static MESSENGER_RELATIONSHIPS = 2016;
public static MESSENGER_REQUEST = 2219;
public static MESSENGER_REQUEST_ERROR = 892;
public static MESSENGER_REQUESTS = 280;
public static MESSENGER_ROOM_INVITE = 3870;
public static MESSENGER_SEARCH = 973;
public static MESSENGER_UPDATE = 2800;
public static MODERATION_REPORT_DISABLED = 1651;
public static MODERATION_TOOL = 2696;
public static MODERATION_USER_INFO = 2866;
public static MOTD_MESSAGES = 2035;
public static NAVIGATOR_CATEGORIES = 1562;
public static NAVIGATOR_COLLAPSED = 1543;
public static NAVIGATOR_EVENT_CATEGORIES = 3244;
public static NAVIGATOR_LIFTED = 3104;
public static NAVIGATOR_METADATA = 3052;
public static NAVIGATOR_OPEN_ROOM_CREATOR = 2064;
public static NAVIGATOR_SEARCH = 2690;
public static NAVIGATOR_SEARCHES = 3984;
public static NAVIGATOR_SETTINGS = 518;
public static NOTIFICATION_LIST = 1992;
public static PET_FIGURE_UPDATE = 1924;
public static PET_INFO = 2901;
public static RECYCLER_PRIZES = 3164;
public static ROOM_BAN_LIST = 1869;
public static ROOM_BAN_REMOVE = 3429;
public static ROOM_CREATED = 1304;
public static ROOM_DOORBELL = 2309;
public static ROOM_DOORBELL_ACCEPTED = 3783;
public static ROOM_DOORBELL_REJECTED = 878;
public static ROOM_ENTER = 758;
public static ROOM_ENTER_ERROR = 899;
public static ROOM_FORWARD = 160;
public static ROOM_HEIGHT_MAP = 2753;
public static ROOM_HEIGHT_MAP_UPDATE = 558;
public static ROOM_INFO = 687;
public static ROOM_INFO_OWNER = 749;
public static ROOM_MODEL = 1301;
public static ROOM_MODEL_BLOCKED_TILES = 3990;
public static ROOM_MODEL_DOOR = 1664;
public static ROOM_MODEL_NAME = 2031;
public static ROOM_MUTED = 2533;
public static ROOM_MUTE_USER = 826;
public static ROOM_PAINT = 2454;
public static ROOM_PROMOTION = 2274;
public static ROOM_QUEUE_STATUS = 2208;
public static ROOM_RIGHTS = 780;
public static ROOM_RIGHTS_CLEAR = 2392;
public static ROOM_RIGHTS_LIST = 1284;
public static ROOM_RIGHTS_LIST_ADD = 2088;
public static ROOM_RIGHTS_LIST_REMOVE = 1327;
public static ROOM_RIGHTS_OWNER = 339;
public static ROOM_ROLLING = 3207;
public static ROOM_SCORE = 482;
public static ROOM_SETTINGS = 1498;
public static ROOM_SETTINGS_CHAT = 1191;
public static ROOM_SETTINGS_SAVE = 948;
public static ROOM_SETTINGS_SAVE_ERROR = 1555;
public static ROOM_SETTINGS_UPDATED = 3297;
public static ROOM_SPECTATOR = 1033;
public static ROOM_THICKNESS = 3547;
public static INFO_FEED_ENABLE = 3284;
public static SECURITY_MACHINE = 1488;
public static MYSTERY_BOX_KEYS = 2833;
public static TRADE_ACCEPTED = 2568;
public static TRADE_CLOSED = 1373;
public static TRADE_COMPLETED = 1001;
public static TRADE_CONFIRMATION = 2720;
public static TRADE_LIST_ITEM = 2024;
public static TRADE_NOT_OPEN = 3128;
public static TRADE_OPEN = 2505;
public static TRADE_OPEN_FAILED = 217;
public static TRADE_OTHER_NOT_ALLOWED = 2154;
public static TRADE_YOU_NOT_ALLOWED = 3058;
public static UNIT = 374;
public static UNIT_CHANGE_NAME = 2182;
public static UNIT_CHAT = 1446;
public static UNIT_CHAT_SHOUT = 1036;
public static UNIT_CHAT_WHISPER = 2704;
public static UNIT_DANCE = 2233;
public static UNIT_EFFECT = 1167;
public static UNIT_EXPRESSION = 1631;
public static UNIT_HAND_ITEM = 1474;
public static UNIT_IDLE = 1797;
public static UNIT_INFO = 3920;
public static UNIT_NUMBER = 2324;
public static UNIT_REMOVE = 2661;
public static UNIT_STATUS = 1640;
public static UNIT_TYPING = 1717;
public static UNSEEN_ITEMS = 2103;
public static USER_ACHIEVEMENT_SCORE = 1968;
public static USER_BADGES = 717;
public static USER_BADGES_ADD = 2493;
public static USER_BADGES_CURRENT = 1087;
public static USER_BOT_REMOVE = 233;
public static USER_BOTS = 3086;
public static USER_CHANGE_NAME = 118;
public static USER_CLOTHING = 1450;
public static USER_CREDITS = 3475;
public static USER_CURRENCY = 2018;
public static ACTIVITY_POINT_NOTIFICATION = 2275;
public static USER_EFFECTS = 340;
public static USER_FAVORITE_ROOM = 2524;
public static USER_FAVORITE_ROOM_COUNT = 151;
public static USER_FIGURE = 2429;
public static USER_FURNITURE = 994;
public static USER_FURNITURE_ADD = 104;
public static USER_FURNITURE_POSTIT_PLACED = 1501;
public static USER_FURNITURE_REFRESH = 3151;
public static USER_FURNITURE_REMOVE = 159;
public static USER_HOME_ROOM = 2875;
public static USER_IGNORED = 126;
public static USER_IGNORED_RESULT = 207;
public static USER_INFO = 2725;
public static USER_OUTFITS = 3315;
public static USER_PERKS = 2586;
public static USER_PERMISSIONS = 411;
public static USER_PET_ADD = 2101;
public static USER_PET_REMOVE = 3253;
public static USER_PETS = 3522;
public static USER_PROFILE = 3898;
public static USER_RESPECT = 2815;
public static USER_SANCTION_STATUS = 3679;
public static USER_SETTINGS = 513;
public static USER_SUBSCRIPTION = 954;
public static USER_WARDROBE_PAGE = 3315;
public static WIRED_ACTION = 1434;
public static WIRED_CONDITION = 1108;
public static WIRED_ERROR = 156;
public static WIRED_OPEN = 1830;
public static WIRED_REWARD = 178;
public static WIRED_SAVE = 1155;
public static WIRED_TRIGGER = 383;
public static PLAYING_GAME = 448;
public static FURNITURE_STATE_2 = 3431;
public static REMOVE_BOT_FROM_INVENTORY = 233;
public static ADD_BOT_TO_INVENTORY = 1352;
public static ACHIEVEMENT_PROGRESSED = 2107;
public static MODTOOL_ROOM_INFO = 1333;
public static MODTOOL_USER_CHATLOG = 3377;
public static MODTOOL_ROOM_CHATLOG = 3434;
public static MODTOOL_VISITED_ROOMS_USER = 1752;
public static MODERATOR_ACTION_RESULT = 2335;
public static ISSUE_DELETED = 3192;
public static ISSUE_INFO = 3609;
public static ISSUE_PICK_FAILED = 3150;
public static CFH_CHATLOG = 607;
public static MODERATOR_TOOL_PREFERENCES = 1576;
public static LOVELOCK_FURNI_START = 3753;
public static LOVELOCK_FURNI_FRIEND_COMFIRMED = 382;
public static LOVELOCK_FURNI_FINISHED = 770;
public static GIFT_RECEIVER_NOT_FOUND = 1517;
public static GIFT_OPENED = 56;
public static FLOOD_CONTROL = 566;
public static REMAINING_MUTE = 826;
public static USER_EFFECT_LIST = 340;
public static USER_EFFECT_LIST_ADD = 2867;
public static USER_EFFECT_LIST_REMOVE = 2228;
public static USER_EFFECT_ACTIVATE = 1959;
public static CLUB_GIFT_INFO = 619;
public static REDEEM_VOUCHER_ERROR = 714;
public static REDEEM_VOUCHER_OK = 3336;
public static IN_CLIENT_LINK = 2023;
public static BOT_COMMAND_CONFIGURATION = 1618;
public static HAND_ITEM_RECEIVED = 354;
public static PET_PLACING_ERROR = 2913;
public static BOT_ERROR = 639;
public static MARKETPLACE_SELL_ITEM = 54;
public static MARKETPLACE_ITEM_STATS = 725;
public static MARKETPLACE_OWN_ITEMS = 3884;
public static MARKETPLACE_CANCEL_SALE = 3264;
public static MARKETPLACE_ITEM_POSTED = 1359;
public static MARKETPLACE_ITEMS_SEARCHED = 680;
public static MARKETPLACE_AFTER_ORDER_STATUS = 2032;
public static CATALOG_RECEIVE_PET_BREEDS = 3331;
public static CATALOG_APPROVE_NAME_RESULT = 1503;
public static OBJECTS_DATA_UPDATE = 1453;
public static PET_EXPERIENCE = 2156;
public static COMMUNITY_GOAL_VOTE_EVENT = 1435;
public static PROMO_ARTICLES = 286;
public static COMMUNITY_GOAL_EARNED_PRIZES = 3319;
public static COMMUNITY_GOAL_PROGRESS = 2525;
public static CONCURRENT_USERS_GOAL_PROGRESS = 2737;
public static QUEST_DAILY = 1878;
public static QUEST_CANCELLED = 3027;
public static QUEST_COMPLETED = 949;
public static COMMUNITY_GOAL_HALL_OF_FAME = 3005;
public static EPIC_POPUP = 3945;
public static SEASONAL_QUESTS = 1122;
public static QUESTS = 3625;
public static QUEST = 230;
public static BONUS_RARE_INFO = 1533;
public static CRAFTABLE_PRODUCTS = 1000;
public static CRAFTING_RECIPE = 2774;
public static CRAFTING_RECIPES_AVAILABLE = 2124;
public static CRAFTING_RESULT = 618;
public static CAMERA_PUBLISH_STATUS = 2057;
public static CAMERA_PURCHASE_OK = 2783;
public static CAMERA_STORAGE_URL = 3696;
public static COMPETITION_STATUS = 133;
public static INIT_CAMERA = 3878;
public static THUMBNAIL_STATUS = 3595;
public static ACHIEVEMENT_NOTIFICATION = 806;
public static CLUB_GIFT_NOTIFICATION = 2188;
public static INTERSTITIAL_MESSAGE = 1808;
public static ROOM_AD_ERROR = 1759;
public static AVAILABILITY_TIME = 600;
public static HOTEL_CLOSED_AND_OPENS = 3728;
public static HOTEL_CLOSES_AND_OPENS_AT = 2771;
public static HOTEL_WILL_CLOSE_MINUTES = 1050;
public static HOTEL_MAINTENANCE = 1350;
public static JUKEBOX_PLAYLIST_FULL = 105;
public static JUKEBOX_SONG_DISKS = 34;
public static NOW_PLAYING = 469;
public static OFFICIAL_SONG_ID = 1381;
public static PLAYLIST = 1748;
public static PLAYLIST_SONG_ADDED = 1140;
public static TRAX_SONG_INFO = 3365;
public static USER_SONG_DISKS_INVENTORY = 2602;
public static CHECK_USER_NAME = 563;
public static CFH_SANCTION = 2782;
public static CFH_TOPICS = 325;
public static CFH_SANCTION_STATUS = 2221;
public static CAMPAIGN_CALENDAR_DATA = 2531;
public static CAMPAIGN_CALENDAR_DOOR_OPENED = 2551;
public static BUILDERS_CLUB_FURNI_COUNT = 3828;
public static BUILDERS_CLUB_SUBSCRIPTION = 1452;
public static CATALOG_PAGE_EXPIRATION = 2668;
public static CATALOG_EARLIEST_EXPIRY = 2515;
public static CLUB_GIFT_SELECTED = 659;
public static TARGET_OFFER_NOT_FOUND = 1237;
public static TARGET_OFFER = 119;
public static DIRECT_SMS_CLUB_BUY = 195;
public static ROOM_AD_PURCHASE = 2468;
public static NOT_ENOUGH_BALANCE = 3914;
public static LIMITED_OFFER_APPEARING_NEXT = 44;
public static IS_OFFER_GIFTABLE = 761;
public static CLUB_EXTENDED_OFFER = 3964;
public static SEASONAL_CALENDAR_OFFER = 1889;
public static COMPETITION_ENTRY_SUBMIT = 1177;
public static COMPETITION_VOTING_INFO = 3506;
public static COMPETITION_TIMING_CODE = 1745;
public static COMPETITION_USER_PART_OF = 3841;
public static COMPETITION_NO_OWNED_ROOMS = 2064;
public static COMPETITION_SECONDS_UNTIL = 3926;
public static BADGE_POINT_LIMITS = 2501;
public static BADGE_REQUEST_FULFILLED = 2998;
public static HELPER_TALENT_TRACK = 3406;
public static USER_BANNED = 1683;
public static BOT_RECEIVED = 3684;
public static PET_LEVEL_NOTIFICATION = 859;
public static PET_RECEIVED = 1111;
public static MODERATION_CAUTION = 1890;
public static YOUTUBE_CONTROL_VIDEO = 1554;
public static YOUTUBE_DISPLAY_PLAYLISTS = 1112;
public static YOUTUBE_DISPLAY_VIDEO = 1411;
public static CFH_DISABLED_NOTIFY = 1651;
public static QUESTION = 2665;
public static POLL_CONTENTS = 2997;
public static POLL_ERROR = 662;
public static POLL_OFFER = 3785;
public static QUESTION_ANSWERED = 2589;
public static QUESTION_FINISHED = 1066;
public static CFH_PENDING_CALLS = 1121;
public static GUIDE_ON_DUTY_STATUS = 1548;
public static GUIDE_SESSION_ATTACHED = 1591;
public static GUIDE_SESSION_DETACHED = 138;
public static GUIDE_SESSION_ENDED = 1456;
public static GUIDE_SESSION_ERROR = 673;
public static MESSENGER_INVITE = 3870;
public static MESSENGER_INVITE_ERROR = 462;
public static MESSENGER_MESSAGE_ERROR = 892;
public static MESSENGER_MINIMAIL_COUNT = 2803;
public static MESSENGER_MINIMAIL_NEW = 1911;
public static MESSENGER_RELATIONSHIPS = 2016;
public static MESSENGER_REQUEST = 2219;
public static MESSENGER_REQUEST_ERROR = 892;
public static MESSENGER_REQUESTS = 280;
public static MESSENGER_ROOM_INVITE = 3870;
public static MESSENGER_SEARCH = 973;
public static MESSENGER_UPDATE = 2800;
public static MODERATION_REPORT_DISABLED = 1651;
public static MODERATION_TOOL = 2696;
public static MODERATION_USER_INFO = 2866;
public static MOTD_MESSAGES = 2035;
public static NAVIGATOR_CATEGORIES = 1562;
public static NAVIGATOR_COLLAPSED = 1543;
public static NAVIGATOR_EVENT_CATEGORIES = 3244;
public static NAVIGATOR_LIFTED = 3104;
public static NAVIGATOR_METADATA = 3052;
public static NAVIGATOR_OPEN_ROOM_CREATOR = 2064;
public static NAVIGATOR_SEARCH = 2690;
public static NAVIGATOR_SEARCHES = 3984;
public static NAVIGATOR_SETTINGS = 518;
public static NOTIFICATION_LIST = 1992;
public static PET_FIGURE_UPDATE = 1924;
public static PET_INFO = 2901;
public static RECYCLER_PRIZES = 3164;
public static ROOM_BAN_LIST = 1869;
public static ROOM_BAN_REMOVE = 3429;
public static ROOM_CREATED = 1304;
public static ROOM_DOORBELL = 2309;
public static ROOM_DOORBELL_ACCEPTED = 3783;
public static ROOM_DOORBELL_REJECTED = 878;
public static ROOM_ENTER = 758;
public static ROOM_ENTER_ERROR = 899;
public static ROOM_FORWARD = 160;
public static ROOM_HEIGHT_MAP = 2753;
public static ROOM_HEIGHT_MAP_UPDATE = 558;
public static ROOM_INFO = 687;
public static ROOM_INFO_OWNER = 749;
public static ROOM_MODEL = 1301;
public static ROOM_MODEL_BLOCKED_TILES = 3990;
public static ROOM_MODEL_DOOR = 1664;
public static ROOM_MODEL_NAME = 2031;
public static ROOM_MUTED = 2533;
public static ROOM_MUTE_USER = 826;
public static ROOM_PAINT = 2454;
public static ROOM_PROMOTION = 2274;
public static ROOM_QUEUE_STATUS = 2208;
public static ROOM_RIGHTS = 780;
public static ROOM_RIGHTS_CLEAR = 2392;
public static ROOM_RIGHTS_LIST = 1284;
public static ROOM_RIGHTS_LIST_ADD = 2088;
public static ROOM_RIGHTS_LIST_REMOVE = 1327;
public static ROOM_RIGHTS_OWNER = 339;
public static ROOM_ROLLING = 3207;
public static ROOM_SCORE = 482;
public static ROOM_SETTINGS = 1498;
public static ROOM_SETTINGS_CHAT = 1191;
public static ROOM_SETTINGS_SAVE = 948;
public static ROOM_SETTINGS_SAVE_ERROR = 1555;
public static ROOM_SETTINGS_UPDATED = 3297;
public static ROOM_SPECTATOR = 1033;
public static ROOM_THICKNESS = 3547;
public static INFO_FEED_ENABLE = 3284;
public static SECURITY_MACHINE = 1488;
public static MYSTERY_BOX_KEYS = 2833;
public static TRADE_ACCEPTED = 2568;
public static TRADE_CLOSED = 1373;
public static TRADE_COMPLETED = 1001;
public static TRADE_CONFIRMATION = 2720;
public static TRADE_LIST_ITEM = 2024;
public static TRADE_NOT_OPEN = 3128;
public static TRADE_OPEN = 2505;
public static TRADE_OPEN_FAILED = 217;
public static TRADE_OTHER_NOT_ALLOWED = 2154;
public static TRADE_YOU_NOT_ALLOWED = 3058;
public static UNIT = 374;
public static UNIT_CHANGE_NAME = 2182;
public static UNIT_CHAT = 1446;
public static UNIT_CHAT_SHOUT = 1036;
public static UNIT_CHAT_WHISPER = 2704;
public static UNIT_DANCE = 2233;
public static UNIT_EFFECT = 1167;
public static UNIT_EXPRESSION = 1631;
public static UNIT_HAND_ITEM = 1474;
public static UNIT_IDLE = 1797;
public static UNIT_INFO = 3920;
public static UNIT_NUMBER = 2324;
public static UNIT_REMOVE = 2661;
public static UNIT_STATUS = 1640;
public static UNIT_TYPING = 1717;
public static UNSEEN_ITEMS = 2103;
public static USER_ACHIEVEMENT_SCORE = 1968;
public static USER_BADGES = 717;
public static USER_BADGES_ADD = 2493;
public static USER_BADGES_CURRENT = 1087;
public static USER_BOT_REMOVE = 233;
public static USER_BOTS = 3086;
public static USER_CHANGE_NAME = 118;
public static USER_CLOTHING = 1450;
public static USER_CREDITS = 3475;
public static USER_CURRENCY = 2018;
public static ACTIVITY_POINT_NOTIFICATION = 2275;
public static USER_EFFECTS = 340;
public static USER_FAVORITE_ROOM = 2524;
public static USER_FAVORITE_ROOM_COUNT = 151;
public static USER_FIGURE = 2429;
public static USER_FURNITURE = 994;
public static USER_FURNITURE_ADD = 104;
public static USER_FURNITURE_POSTIT_PLACED = 1501;
public static USER_FURNITURE_REFRESH = 3151;
public static USER_FURNITURE_REMOVE = 159;
public static USER_HOME_ROOM = 2875;
public static USER_IGNORED = 126;
public static USER_IGNORED_RESULT = 207;
public static USER_INFO = 2725;
public static USER_OUTFITS = 3315;
public static USER_PERKS = 2586;
public static USER_PERMISSIONS = 411;
public static USER_PET_ADD = 2101;
public static USER_PET_REMOVE = 3253;
public static USER_PETS = 3522;
public static USER_PROFILE = 3898;
public static USER_RESPECT = 2815;
public static USER_SANCTION_STATUS = 3679;
public static USER_SETTINGS = 513;
public static USER_SUBSCRIPTION = 954;
public static USER_WARDROBE_PAGE = 3315;
public static WIRED_ACTION = 1434;
public static WIRED_CONDITION = 1108;
public static WIRED_ERROR = 156;
public static WIRED_OPEN = 1830;
public static WIRED_REWARD = 178;
public static WIRED_SAVE = 1155;
public static WIRED_TRIGGER = 383;
public static PLAYING_GAME = 448;
public static FURNITURE_STATE_2 = 3431;
public static REMOVE_BOT_FROM_INVENTORY = 233;
public static ADD_BOT_TO_INVENTORY = 1352;
public static ACHIEVEMENT_PROGRESSED = 2107;
public static MODTOOL_ROOM_INFO = 1333;
public static MODTOOL_USER_CHATLOG = 3377;
public static MODTOOL_ROOM_CHATLOG = 3434;
public static MODTOOL_VISITED_ROOMS_USER = 1752;
public static MODERATOR_ACTION_RESULT = 2335;
public static ISSUE_DELETED = 3192;
public static ISSUE_INFO = 3609;
public static ISSUE_PICK_FAILED = 3150;
public static CFH_CHATLOG = 607;
public static MODERATOR_TOOL_PREFERENCES = 1576;
public static LOVELOCK_FURNI_START = 3753;
public static LOVELOCK_FURNI_FRIEND_COMFIRMED = 382;
public static LOVELOCK_FURNI_FINISHED = 770;
public static GIFT_RECEIVER_NOT_FOUND = 1517;
public static GIFT_OPENED = 56;
public static FLOOD_CONTROL = 566;
public static REMAINING_MUTE = 826;
public static USER_EFFECT_LIST = 340;
public static USER_EFFECT_LIST_ADD = 2867;
public static USER_EFFECT_LIST_REMOVE = 2228;
public static USER_EFFECT_ACTIVATE = 1959;
public static CLUB_GIFT_INFO = 619;
public static REDEEM_VOUCHER_ERROR = 714;
public static REDEEM_VOUCHER_OK = 3336;
public static IN_CLIENT_LINK = 2023;
public static BOT_COMMAND_CONFIGURATION = 1618;
public static HAND_ITEM_RECEIVED = 354;
public static PET_PLACING_ERROR = 2913;
public static BOT_ERROR = 639;
public static MARKETPLACE_SELL_ITEM = 54;
public static MARKETPLACE_ITEM_STATS = 725;
public static MARKETPLACE_OWN_ITEMS = 3884;
public static MARKETPLACE_CANCEL_SALE = 3264;
public static MARKETPLACE_ITEM_POSTED = 1359;
public static MARKETPLACE_ITEMS_SEARCHED = 680;
public static MARKETPLACE_AFTER_ORDER_STATUS = 2032;
public static CATALOG_RECEIVE_PET_BREEDS = 3331;
public static CATALOG_APPROVE_NAME_RESULT = 1503;
public static OBJECTS_DATA_UPDATE = 1453;
public static PET_EXPERIENCE = 2156;
public static COMMUNITY_GOAL_VOTE_EVENT = 1435;
public static PROMO_ARTICLES = 286;
public static COMMUNITY_GOAL_EARNED_PRIZES = 3319;
public static COMMUNITY_GOAL_PROGRESS = 2525;
public static CONCURRENT_USERS_GOAL_PROGRESS = 2737;
public static QUEST_DAILY = 1878;
public static QUEST_CANCELLED = 3027;
public static QUEST_COMPLETED = 949;
public static COMMUNITY_GOAL_HALL_OF_FAME = 3005;
public static EPIC_POPUP = 3945;
public static SEASONAL_QUESTS = 1122;
public static QUESTS = 3625;
public static QUEST = 230;
public static BONUS_RARE_INFO = 1533;
public static CRAFTABLE_PRODUCTS = 1000;
public static CRAFTING_RECIPE = 2774;
public static CRAFTING_RECIPES_AVAILABLE = 2124;
public static CRAFTING_RESULT = 618;
public static CAMERA_PUBLISH_STATUS = 2057;
public static CAMERA_PURCHASE_OK = 2783;
public static CAMERA_STORAGE_URL = 3696;
public static COMPETITION_STATUS = 133;
public static INIT_CAMERA = 3878;
public static THUMBNAIL_STATUS = 3595;
public static ACHIEVEMENT_NOTIFICATION = 806;
public static CLUB_GIFT_NOTIFICATION = 2188;
public static INTERSTITIAL_MESSAGE = 1808;
public static ROOM_AD_ERROR = 1759;
public static AVAILABILITY_TIME = 600;
public static HOTEL_CLOSED_AND_OPENS = 3728;
public static HOTEL_CLOSES_AND_OPENS_AT = 2771;
public static HOTEL_WILL_CLOSE_MINUTES = 1050;
public static HOTEL_MAINTENANCE = 1350;
public static JUKEBOX_PLAYLIST_FULL = 105;
public static JUKEBOX_SONG_DISKS = 34;
public static NOW_PLAYING = 469;
public static OFFICIAL_SONG_ID = 1381;
public static PLAYLIST = 1748;
public static PLAYLIST_SONG_ADDED = 1140;
public static TRAX_SONG_INFO = 3365;
public static USER_SONG_DISKS_INVENTORY = 2602;
public static CHECK_USER_NAME = 563;
public static CFH_SANCTION = 2782;
public static CFH_TOPICS = 325;
public static CFH_SANCTION_STATUS = 2221;
public static CAMPAIGN_CALENDAR_DATA = 2531;
public static CAMPAIGN_CALENDAR_DOOR_OPENED = 2551;
public static BUILDERS_CLUB_FURNI_COUNT = 3828;
public static BUILDERS_CLUB_SUBSCRIPTION = 1452;
public static CATALOG_PAGE_EXPIRATION = 2668;
public static CATALOG_EARLIEST_EXPIRY = 2515;
public static CLUB_GIFT_SELECTED = 659;
public static TARGET_OFFER_NOT_FOUND = 1237;
public static TARGET_OFFER = 119;
public static DIRECT_SMS_CLUB_BUY = 195;
public static ROOM_AD_PURCHASE = 2468;
public static NOT_ENOUGH_BALANCE = 3914;
public static LIMITED_OFFER_APPEARING_NEXT = 44;
public static IS_OFFER_GIFTABLE = 761;
public static CLUB_EXTENDED_OFFER = 3964;
public static SEASONAL_CALENDAR_OFFER = 1889;
public static COMPETITION_ENTRY_SUBMIT = 1177;
public static COMPETITION_VOTING_INFO = 3506;
public static COMPETITION_TIMING_CODE = 1745;
public static COMPETITION_USER_PART_OF = 3841;
public static COMPETITION_NO_OWNED_ROOMS = 2064;
public static COMPETITION_SECONDS_UNTIL = 3926;
public static BADGE_POINT_LIMITS = 2501;
public static BADGE_REQUEST_FULFILLED = 2998;
public static HELPER_TALENT_TRACK = 3406;
public static USER_BANNED = 1683;
public static BOT_RECEIVED = 3684;
public static PET_LEVEL_NOTIFICATION = 859;
public static PET_RECEIVED = 1111;
public static MODERATION_CAUTION = 1890;
public static YOUTUBE_CONTROL_VIDEO = 1554;
public static YOUTUBE_DISPLAY_PLAYLISTS = 1112;
public static YOUTUBE_DISPLAY_VIDEO = 1411;
public static CFH_DISABLED_NOTIFY = 1651;
public static QUESTION = 2665;
public static POLL_CONTENTS = 2997;
public static POLL_ERROR = 662;
public static POLL_OFFER = 3785;
public static QUESTION_ANSWERED = 2589;
public static QUESTION_FINISHED = 1066;
public static CFH_PENDING_CALLS = 1121;
public static GUIDE_ON_DUTY_STATUS = 1548;
public static GUIDE_SESSION_ATTACHED = 1591;
public static GUIDE_SESSION_DETACHED = 138;
public static GUIDE_SESSION_ENDED = 1456;
public static GUIDE_SESSION_ERROR = 673;
public static GUIDE_SESSION_INVITED_TO_GUIDE_ROOM = 219;
public static GUIDE_SESSION_MESSAGE = 841;
public static GUIDE_SESSION_PARTNER_IS_TYPING = 1016;
public static GUIDE_SESSION_REQUESTER_ROOM = 1847;
public static GUIDE_SESSION_STARTED = 3209;
public static GUIDE_TICKET_CREATION_RESULT = 3285;
public static GUIDE_TICKET_RESOLUTION = 2674;
public static GUIDE_REPORTING_STATUS = 3463;
public static HOTEL_MERGE_NAME_CHANGE = 1663;
public static ISSUE_CLOSE_NOTIFICATION = 934;
public static QUIZ_DATA = 2927;
public static QUIZ_RESULTS = 2772;
public static CFH_PENDING_CALLS_DELETED = 77;
public static CFH_REPLY = 3796;
public static CHAT_REVIEW_SESSION_DETACHED = 30;
public static GUIDE_SESSION_MESSAGE = 841;
public static GUIDE_SESSION_PARTNER_IS_TYPING = 1016;
public static GUIDE_SESSION_REQUESTER_ROOM = 1847;
public static GUIDE_SESSION_STARTED = 3209;
public static GUIDE_TICKET_CREATION_RESULT = 3285;
public static GUIDE_TICKET_RESOLUTION = 2674;
public static GUIDE_REPORTING_STATUS = 3463;
public static HOTEL_MERGE_NAME_CHANGE = 1663;
public static ISSUE_CLOSE_NOTIFICATION = 934;
public static QUIZ_DATA = 2927;
public static QUIZ_RESULTS = 2772;
public static CFH_PENDING_CALLS_DELETED = 77;
public static CFH_REPLY = 3796;
public static CHAT_REVIEW_SESSION_DETACHED = 30;
public static CHAT_REVIEW_SESSION_OFFERED_TO_GUIDE = 735;
public static CHAT_REVIEW_SESSION_RESULTS = 3276;
public static CHAT_REVIEW_SESSION_STARTED = 143;
public static CHAT_REVIEW_SESSION_RESULTS = 3276;
public static CHAT_REVIEW_SESSION_STARTED = 143;
public static CHAT_REVIEW_SESSION_VOTING_STATUS = 1829;
public static SCR_SEND_KICKBACK_INFO = 3277;
public static SCR_SEND_KICKBACK_INFO = 3277;
public static PET_STATUS = 1907;
public static GROUP_DEACTIVATE = 3129;
}

View File

@ -18,13 +18,13 @@ export class CatalogPageMessageOfferData
constructor(wrapper: IMessageDataWrapper)
{
this._offerId = wrapper.readInt();
this._localizationId = wrapper.readString();
this._rent = wrapper.readBoolean();
this._priceCredits = wrapper.readInt();
this._priceActivityPoints = wrapper.readInt();
this._priceActivityPointsType = wrapper.readInt();
this._giftable = wrapper.readBoolean();
this._offerId = wrapper.readInt();
this._localizationId = wrapper.readString();
this._rent = wrapper.readBoolean();
this._priceCredits = wrapper.readInt();
this._priceActivityPoints = wrapper.readInt();
this._priceActivityPointsType = wrapper.readInt();
this._giftable = wrapper.readBoolean();
this._products = [];
@ -37,10 +37,10 @@ export class CatalogPageMessageOfferData
totalProducts--;
}
this._clubLevel = wrapper.readInt();
this._clubLevel = wrapper.readInt();
this._bundlePurchaseAllowed = wrapper.readBoolean();
this._isPet = wrapper.readBoolean();
this._previewImage = wrapper.readString();
this._isPet = wrapper.readBoolean();
this._previewImage = wrapper.readString();
}
public get offerId(): number

View File

@ -25,13 +25,13 @@ export class CatalogPageMessageProductData
public flush(): boolean
{
this._productType = null;
this._furniClassId = -1;
this._extraParam = null;
this._productCount = 0;
this._uniqueLimitedItem = false;
this._uniqueLimitedItemSeriesSize = 0;
this._uniqueLimitedItemsLeft = 0;
this._productType = null;
this._furniClassId = -1;
this._extraParam = null;
this._productCount = 0;
this._uniqueLimitedItem = false;
this._uniqueLimitedItemSeriesSize = 0;
this._uniqueLimitedItemsLeft = 0;
return true;
}
@ -43,19 +43,19 @@ export class CatalogPageMessageProductData
switch(this._productType)
{
case CatalogPageMessageProductData.B:
this._extraParam = wrapper.readString();
this._productCount = 1;
this._extraParam = wrapper.readString();
this._productCount = 1;
return true;
default:
this._furniClassId = wrapper.readInt();
this._extraParam = wrapper.readString();
this._productCount = wrapper.readInt();
this._furniClassId = wrapper.readInt();
this._extraParam = wrapper.readString();
this._productCount = wrapper.readInt();
this._uniqueLimitedItem = wrapper.readBoolean();
if(this._uniqueLimitedItem)
{
this._uniqueLimitedItemSeriesSize = wrapper.readInt();
this._uniqueLimitedItemsLeft = wrapper.readInt();
this._uniqueLimitedItemSeriesSize = wrapper.readInt();
this._uniqueLimitedItemsLeft = wrapper.readInt();
}
return true;
}

View File

@ -20,22 +20,22 @@ export class ClubOfferData
{
if(!wrapper) throw new Error('invalid_wrapper');
this._offerId = wrapper.readInt();
this._productCode = wrapper.readString();
this._offerId = wrapper.readInt();
this._productCode = wrapper.readString();
wrapper.readBoolean();
this._priceCredits = wrapper.readInt();
this._priceActivityPoints = wrapper.readInt();
this._priceActivityPointsType = wrapper.readInt();
this._vip = wrapper.readBoolean();
this._months = wrapper.readInt();
this._extraDays = wrapper.readInt();
this._giftable = wrapper.readBoolean();
this._daysLeftAfterPurchase = wrapper.readInt();
this._year = wrapper.readInt();
this._month = wrapper.readInt();
this._day = wrapper.readInt();
this._priceCredits = wrapper.readInt();
this._priceActivityPoints = wrapper.readInt();
this._priceActivityPointsType = wrapper.readInt();
this._vip = wrapper.readBoolean();
this._months = wrapper.readInt();
this._extraDays = wrapper.readInt();
this._giftable = wrapper.readBoolean();
this._daysLeftAfterPurchase = wrapper.readInt();
this._year = wrapper.readInt();
this._month = wrapper.readInt();
this._day = wrapper.readInt();
}
public get offerId(): number

View File

@ -3,9 +3,9 @@ import { Nitro } from '../../../../Nitro';
export class FrontPageItem
{
public static ITEM_CATALOGUE_PAGE: number = 0;
public static ITEM_PRODUCT_OFFER: number = 1;
public static ITEM_IAP: number = 2;
public static ITEM_CATALOGUE_PAGE: number = 0;
public static ITEM_PRODUCT_OFFER: number = 1;
public static ITEM_IAP: number = 2;
private _type: number;
private _position: number;
@ -26,14 +26,14 @@ export class FrontPageItem
public flush(): boolean
{
this._type = -1;
this._position = null;
this._itemName = null;
this._itemPromoImage = null;
this._catalogPageLocation = null;
this._productCode = null;
this._productOfferId = 0;
this._expirationTime = 0;
this._type = -1;
this._position = null;
this._itemName = null;
this._itemPromoImage = null;
this._catalogPageLocation = null;
this._productCode = null;
this._productOfferId = 0;
this._expirationTime = 0;
return true;
}
@ -42,10 +42,10 @@ export class FrontPageItem
{
if(!wrapper) return false;
this._position = wrapper.readInt();
this._itemName = wrapper.readString();
this._itemPromoImage = wrapper.readString();
this._type = wrapper.readInt();
this._position = wrapper.readInt();
this._itemName = wrapper.readString();
this._itemPromoImage = wrapper.readString();
this._type = wrapper.readInt();
switch(this._type)
{

View File

@ -20,13 +20,13 @@ export class NodeData
public flush(): boolean
{
this._visible = false;
this._icon = 0;
this._pageId = -1;
this._pageName = null;
this._localization = null;
this._children = [];
this._offerIds = [];
this._visible = false;
this._icon = 0;
this._pageId = -1;
this._pageName = null;
this._localization = null;
this._children = [];
this._offerIds = [];
return true;
}
@ -35,11 +35,11 @@ export class NodeData
{
if(!wrapper) return false;
this._visible = wrapper.readBoolean();
this._icon = wrapper.readInt();
this._pageId = wrapper.readInt();
this._pageName = wrapper.readString();
this._localization = wrapper.readString();
this._visible = wrapper.readBoolean();
this._icon = wrapper.readInt();
this._pageId = wrapper.readInt();
this._pageName = wrapper.readString();
this._localization = wrapper.readString();
let totalOffers = wrapper.readInt();

Some files were not shown because too many files have changed in this diff Show More