This commit is contained in:
MyNameIsBatman 2021-09-05 22:30:30 -03:00
parent 9432c8b6d8
commit 475a83cb26
9 changed files with 37 additions and 136 deletions

View File

@ -1,5 +1,5 @@
import { IMessageDataWrapper, IMessageParser } from '../../../../../core'; import { IMessageDataWrapper, IMessageParser } from '../../../../../core';
import { GroupBadgePart } from './utils/GroupBadgePart'; import { GroupDataBadgePart } from './utils/GroupDataBadgePart';
export class GroupSettingsParser implements IMessageParser export class GroupSettingsParser implements IMessageParser
{ {
@ -12,7 +12,7 @@ export class GroupSettingsParser implements IMessageParser
private _colorB: number; private _colorB: number;
private _state: number; private _state: number;
private _canMembersDecorate: boolean; private _canMembersDecorate: boolean;
private _badgeParts: Map<number, GroupBadgePart>; private _badgeParts: Map<number, GroupDataBadgePart>;
private _badgeCode: string; private _badgeCode: string;
private _membersCount: number; private _membersCount: number;
@ -67,7 +67,7 @@ export class GroupSettingsParser implements IMessageParser
for(let i = 0; i < badgePartsCount; i++) for(let i = 0; i < badgePartsCount; i++)
{ {
const part = new GroupBadgePart(i === 0); const part = new GroupDataBadgePart(i === 0);
part.key = wrapper.readInt(); part.key = wrapper.readInt();
part.color = wrapper.readInt(); part.color = wrapper.readInt();
@ -132,7 +132,7 @@ export class GroupSettingsParser implements IMessageParser
return this._canMembersDecorate; return this._canMembersDecorate;
} }
public get badgeParts(): Map<number, GroupBadgePart> public get badgeParts(): Map<number, GroupDataBadgePart>
{ {
return this._badgeParts; return this._badgeParts;
} }

View File

@ -1,4 +1,4 @@
export class GroupBadgePart export class GroupDataBadgePart
{ {
public isBase: boolean; public isBase: boolean;
public key: number; public key: number;

View File

@ -1,3 +1,3 @@
export * from './GroupBadgePart'; export * from './GroupDataBadgePart';
export * from './GroupDataParser'; export * from './GroupDataParser';
export * from './GroupMemberParser'; export * from './GroupMemberParser';

View File

@ -1,108 +0,0 @@
import { Resource, Texture } from '@pixi/core';
import { IAssetManager } from '../../core/asset/IAssetManager';
import { IEventDispatcher } from '../../core/events/IEventDispatcher';
import { Nitro } from '../Nitro';
import { BadgeInfo } from './BadgeInfo';
import { BadgeImageReadyEvent } from './events/BadgeImageReadyEvent';
export class BadgeImageManager
{
public static GROUP_BADGE: string = 'group_badge';
public static NORMAL_BADGE: string = 'normal_badge';
private _assets: IAssetManager;
private _events: IEventDispatcher;
private _requestedBadges: Map<string, boolean>;
constructor(assetManager: IAssetManager, eventDispatcher: IEventDispatcher)
{
this._assets = assetManager;
this._events = eventDispatcher;
this._requestedBadges = new Map();
}
public dispose(): void
{
this._assets = null;
}
public getBadgeImage(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE, load: boolean = true): Texture<Resource>
{
let badge = this.getBadgeTexture(badgeName, type);
if(!badge && load) badge = this.getBadgePlaceholder();
return badge;
}
public getBadgeInfo(k: string): BadgeInfo
{
const badge = this.getBadgeTexture(k);
return (badge) ? new BadgeInfo(badge, false) : new BadgeInfo(this.getBadgePlaceholder(), true);
}
public loadBadgeImage(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE): string
{
if(this._assets.getTexture(this.getBadgeUrl(badgeName, type))) return badgeName;
this.getBadgeTexture(badgeName, type);
return null;
}
private getBadgeTexture(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE): Texture<Resource>
{
const url = this.getBadgeUrl(badgeName, type);
const existing = this._assets.getTexture(url);
if(existing) return existing.clone();
if(this._requestedBadges.get(badgeName)) return null;
if(url)
{
this._requestedBadges.set(badgeName, true);
this._assets.downloadAsset(url, (flag: boolean) =>
{
if(flag)
{
const texture = this._assets.getTexture(url);
if(texture && this._events) this._events.dispatchEvent(new BadgeImageReadyEvent(badgeName, texture.clone()));
}
});
}
return null;
}
private getBadgePlaceholder(): Texture<Resource>
{
const url = (Nitro.instance.getConfiguration<string>('images.url') + '/loading_icon.png');
const existing = this._assets.getTexture(url);
if(!existing) return null;
return existing.clone();
}
public getBadgeUrl(badge: string, type: string = BadgeImageManager.NORMAL_BADGE): string
{
let url = null;
switch(type)
{
case BadgeImageManager.NORMAL_BADGE:
url = (Nitro.instance.getConfiguration<string>('badge.asset.url')).replace('%badgename%', badge);
break;
case BadgeImageManager.GROUP_BADGE:
url = (Nitro.instance.getConfiguration<string>('badge.asset.group.url')).replace('%badgedata%', badge);
break;
}
return url;
}
}

View File

@ -18,7 +18,7 @@ import { UserRespectComposer } from '../communication/messages/outgoing/user/Use
import { NitroSettingsEvent } from '../events/NitroSettingsEvent'; import { NitroSettingsEvent } from '../events/NitroSettingsEvent';
import { Nitro } from '../Nitro'; import { Nitro } from '../Nitro';
import { HabboWebTools } from '../utils/HabboWebTools'; import { HabboWebTools } from '../utils/HabboWebTools';
import { BadgeImageManager } from './BadgeImageManager'; import { BadgeImageManager } from './badge/BadgeImageManager';
import { SecurityLevel } from './enum/SecurityLevel'; import { SecurityLevel } from './enum/SecurityLevel';
import { MysteryBoxKeysUpdateEvent } from './events'; import { MysteryBoxKeysUpdateEvent } from './events';
import { SessionDataPreferencesEvent } from './events/SessionDataPreferencesEvent'; import { SessionDataPreferencesEvent } from './events/SessionDataPreferencesEvent';
@ -197,7 +197,8 @@ export class SessionDataManager extends NitroManager implements ISessionDataMana
{ {
if(this._badgeImageManager) return; if(this._badgeImageManager) return;
this._badgeImageManager = new BadgeImageManager(Nitro.instance.core.asset, this.events); this._badgeImageManager = new BadgeImageManager(Nitro.instance.core.asset, this);
this._badgeImageManager.init();
} }
public hasProductData(listener: IProductDataListener): boolean public hasProductData(listener: IProductDataListener): boolean

View File

@ -1,21 +1,22 @@
import { Resource, Texture } from '@pixi/core'; import { Resource, Texture } from '@pixi/core';
import { BadgeTypeEnum, GroupBadge } from '.';
import { IAssetManager } from '../../../core/asset/IAssetManager'; import { IAssetManager } from '../../../core/asset/IAssetManager';
import { IMessageEvent } from '../../../core/communication/messages/IMessageEvent'; import { IMessageEvent } from '../../../core/communication/messages/IMessageEvent';
import { NitroSprite } from '../../../core/utils/proxy/NitroSprite'; import { NitroSprite } from '../../../core/utils/proxy/NitroSprite';
import { GroupBadgePartsEvent } from '../../communication/messages/incoming/group/GroupBadgePartsEvent'; import { GroupBadgePartsEvent } from '../../communication/messages/incoming/group/GroupBadgePartsEvent';
import { GroupBadgePartsComposer } from '../../communication/messages/outgoing/group/GroupBadgePartsComposer';
import { Nitro } from '../../Nitro'; import { Nitro } from '../../Nitro';
import { BadgeImageReadyEvent } from '../events/BadgeImageReadyEvent'; import { BadgeImageReadyEvent } from '../events/BadgeImageReadyEvent';
import { ISessionDataManager } from '../ISessionDataManager'; import { IDisposable } from './../../../core/common/disposable/IDisposable';
import { TextureUtils } from './../../../room/utils/TextureUtils'; import { TextureUtils } from './../../../room/utils/TextureUtils';
import { SessionDataManager } from './../SessionDataManager'; import { SessionDataManager } from './../SessionDataManager';
import { BadgeInfo } from './BadgeInfo'; import { BadgeInfo } from './BadgeInfo';
import { GroupBadge } from './GroupBadge';
import { GroupBadgePart } from './GroupBadgePart'; import { GroupBadgePart } from './GroupBadgePart';
import { IBadgeImageManager } from './IBadgeImageManager';
export class BadgeImageManager implements IBadgeImageManager export class BadgeImageManager implements IDisposable
{ {
public static GROUP_BADGE: string = 'group_badge';
public static NORMAL_BADGE: string = 'normal_badge';
private _assets: IAssetManager; private _assets: IAssetManager;
private _sessionDataManager: SessionDataManager; private _sessionDataManager: SessionDataManager;
private _messages: IMessageEvent[]; private _messages: IMessageEvent[];
@ -29,7 +30,7 @@ export class BadgeImageManager implements IBadgeImageManager
private _readyToGenerateGroupBadges: boolean; private _readyToGenerateGroupBadges: boolean;
constructor(assetManager: IAssetManager, sessionDataManager: ISessionDataManager) constructor(assetManager: IAssetManager, sessionDataManager: SessionDataManager)
{ {
this._assets = assetManager; this._assets = assetManager;
this._sessionDataManager = sessionDataManager; this._sessionDataManager = sessionDataManager;
@ -38,7 +39,8 @@ export class BadgeImageManager implements IBadgeImageManager
this._groupSymbols = new Map(); this._groupSymbols = new Map();
this._groupPartColors = new Map(); this._groupPartColors = new Map();
this._requestedBadges = new Map(); this._requestedBadges = new Map();
this._groupBadgesQueue = new Map();
this._readyToGenerateGroupBadges = false; this._readyToGenerateGroupBadges = false;
} }
@ -53,7 +55,7 @@ export class BadgeImageManager implements IBadgeImageManager
for(const message of this._messages) this._sessionDataManager.communication.registerMessageEvent(message); for(const message of this._messages) this._sessionDataManager.communication.registerMessageEvent(message);
this._sessionDataManager.send(new GroupBadgePartsComposer()); //this._sessionDataManager.send(new GroupBadgePartsComposer());
} }
} }
@ -69,7 +71,7 @@ export class BadgeImageManager implements IBadgeImageManager
this._sessionDataManager = null; this._sessionDataManager = null;
} }
public getBadgeImage(badgeName: string, type: string = BadgeTypeEnum.NORMAL_BADGE, load: boolean = true): Texture<Resource> public getBadgeImage(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE, load: boolean = true): Texture<Resource>
{ {
let badge = this.getBadgeTexture(badgeName, type); let badge = this.getBadgeTexture(badgeName, type);
@ -85,7 +87,7 @@ export class BadgeImageManager implements IBadgeImageManager
return (badge) ? new BadgeInfo(badge, false) : new BadgeInfo(this.getBadgePlaceholder(), true); return (badge) ? new BadgeInfo(badge, false) : new BadgeInfo(this.getBadgePlaceholder(), true);
} }
public loadBadgeImage(badgeName: string, type: string = BadgeTypeEnum.NORMAL_BADGE): string public loadBadgeImage(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE): string
{ {
if(this._assets.getTexture(this.getBadgeUrl(badgeName, type))) return badgeName; if(this._assets.getTexture(this.getBadgeUrl(badgeName, type))) return badgeName;
@ -94,7 +96,7 @@ export class BadgeImageManager implements IBadgeImageManager
return null; return null;
} }
private getBadgeTexture(badgeName: string, type: string = BadgeTypeEnum.NORMAL_BADGE): Texture<Resource> private getBadgeTexture(badgeName: string, type: string = BadgeImageManager.NORMAL_BADGE): Texture<Resource>
{ {
const url = this.getBadgeUrl(badgeName, type); const url = this.getBadgeUrl(badgeName, type);
@ -108,7 +110,7 @@ export class BadgeImageManager implements IBadgeImageManager
{ {
this._requestedBadges.set(badgeName, true); this._requestedBadges.set(badgeName, true);
if(type === BadgeTypeEnum.NORMAL_BADGE) if(type === BadgeImageManager.NORMAL_BADGE)
{ {
this._assets.downloadAsset(url, (flag: boolean) => this._assets.downloadAsset(url, (flag: boolean) =>
{ {
@ -126,7 +128,7 @@ export class BadgeImageManager implements IBadgeImageManager
{ {
if(!this._readyToGenerateGroupBadges) if(!this._readyToGenerateGroupBadges)
{ {
if(this._groupBadgesQueue.get(badgeName)) this._groupBadgesQueue.set(badgeName, true); if(!this._groupBadgesQueue.get(badgeName)) this._groupBadgesQueue.set(badgeName, true);
} }
else else
{ {
@ -148,16 +150,16 @@ export class BadgeImageManager implements IBadgeImageManager
return existing.clone(); return existing.clone();
} }
public getBadgeUrl(badge: string, type: string = BadgeTypeEnum.NORMAL_BADGE): string public getBadgeUrl(badge: string, type: string = BadgeImageManager.NORMAL_BADGE): string
{ {
let url = null; let url = null;
switch(type) switch(type)
{ {
case BadgeTypeEnum.NORMAL_BADGE: case BadgeImageManager.NORMAL_BADGE:
url = (Nitro.instance.getConfiguration<string>('badge.asset.url')).replace('%badgename%', badge); url = (Nitro.instance.getConfiguration<string>('badge.asset.url')).replace('%badgename%', badge);
break; break;
case BadgeTypeEnum.GROUP_BADGE: case BadgeImageManager.GROUP_BADGE:
//url = (Nitro.instance.getConfiguration<string>('badge.asset.group.url')).replace('%badgedata%', badge); //url = (Nitro.instance.getConfiguration<string>('badge.asset.group.url')).replace('%badgedata%', badge);
url = badge; url = badge;
break; break;
@ -190,6 +192,8 @@ export class BadgeImageManager implements IBadgeImageManager
const requiredAssets = isBase ? this._groupBases.get(partId) : this._groupSymbols.get(partId); const requiredAssets = isBase ? this._groupBases.get(partId) : this._groupSymbols.get(partId);
if(!requiredAssets) continue;
for(const requiredAsset of requiredAssets) for(const requiredAsset of requiredAssets)
{ {
if(requiredAsset.length > 0) if(requiredAsset.length > 0)
@ -214,6 +218,7 @@ export class BadgeImageManager implements IBadgeImageManager
{ {
for(const part of groupBadge.parts) for(const part of groupBadge.parts)
{ {
let isFirst = true;
for(const partUrl of part.urls) for(const partUrl of part.urls)
{ {
const texture = this._assets.getTexture(partUrl); const texture = this._assets.getTexture(partUrl);
@ -225,7 +230,10 @@ export class BadgeImageManager implements IBadgeImageManager
const sprite = new NitroSprite(texture); const sprite = new NitroSprite(texture);
sprite.x = pos.x; sprite.x = pos.x;
sprite.y = pos.y; sprite.y = pos.y;
sprite.tint = parseInt(this._groupPartColors.get(part.color), 16);
if(isFirst) sprite.tint = parseInt(this._groupPartColors.get(part.color), 16);
isFirst = false;
groupBadge.container.addChild(sprite); groupBadge.container.addChild(sprite);
} }
@ -235,7 +243,6 @@ export class BadgeImageManager implements IBadgeImageManager
this._groupBadgesQueue.delete(groupBadge.code); this._groupBadgesQueue.delete(groupBadge.code);
const texture = TextureUtils.generateTexture(groupBadge.container); const texture = TextureUtils.generateTexture(groupBadge.container);
this._assets.setTexture(groupBadge.code, texture); this._assets.setTexture(groupBadge.code, texture);
if(this._sessionDataManager) this._sessionDataManager.events.dispatchEvent(new BadgeImageReadyEvent(groupBadge.code, texture)); if(this._sessionDataManager) this._sessionDataManager.events.dispatchEvent(new BadgeImageReadyEvent(groupBadge.code, texture));

View File

@ -1,2 +1,4 @@
export * from './BadgeImageManager'; export * from './BadgeImageManager';
export * from './BadgeInfo';
export * from './GroupBadge';
export * from './GroupBadgePart'; export * from './GroupBadgePart';

View File

@ -1,5 +1,4 @@
export * from './BadgeImageManager'; export * from './badge';
export * from './BadgeInfo';
export * from './enum'; export * from './enum';
export * from './events'; export * from './events';
export * from './furniture'; export * from './furniture';