You've already forked Nitro_Render_V3
mirror of
https://github.com/duckietm/Nitro_Render_V3.git
synced 2026-06-19 15:06:20 +00:00
🆙 Updates
- Added Test Coverage - Fix Potential Memory Leaks
This commit is contained in:
@@ -15,16 +15,44 @@ export class SoundManager implements ISoundManager
|
||||
private _furnitureBeingPlayed: IAdvancedMap<number, number> = new AdvancedMap();
|
||||
|
||||
private _musicController: IMusicController = new MusicController();
|
||||
private _eventCallback: (event: INitroEvent) => void = null;
|
||||
|
||||
public async init(): Promise<void>
|
||||
{
|
||||
this._musicController.init();
|
||||
|
||||
GetEventDispatcher().addEventListener<RoomEngineSamplePlaybackEvent>(RoomEngineSamplePlaybackEvent.PLAY_SAMPLE, event => this.onEvent(event));
|
||||
GetEventDispatcher().addEventListener<RoomEngineObjectEvent>(RoomEngineObjectEvent.REMOVED, event => this.onEvent(event));
|
||||
GetEventDispatcher().addEventListener<RoomEngineEvent>(RoomEngineEvent.DISPOSED, event => this.onEvent(event));
|
||||
GetEventDispatcher().addEventListener<NitroSettingsEvent>(NitroSettingsEvent.SETTINGS_UPDATED, event => this.onEvent(event));
|
||||
GetEventDispatcher().addEventListener<NitroSoundEvent>(NitroSoundEvent.PLAY_SOUND, event => this.onEvent(event));
|
||||
// Store callback for cleanup
|
||||
this._eventCallback = (event: INitroEvent) => this.onEvent(event);
|
||||
|
||||
GetEventDispatcher().addEventListener<RoomEngineSamplePlaybackEvent>(RoomEngineSamplePlaybackEvent.PLAY_SAMPLE, this._eventCallback);
|
||||
GetEventDispatcher().addEventListener<RoomEngineObjectEvent>(RoomEngineObjectEvent.REMOVED, this._eventCallback);
|
||||
GetEventDispatcher().addEventListener<RoomEngineEvent>(RoomEngineEvent.DISPOSED, this._eventCallback);
|
||||
GetEventDispatcher().addEventListener<NitroSettingsEvent>(NitroSettingsEvent.SETTINGS_UPDATED, this._eventCallback);
|
||||
GetEventDispatcher().addEventListener<NitroSoundEvent>(NitroSoundEvent.PLAY_SOUND, this._eventCallback);
|
||||
}
|
||||
|
||||
public dispose(): void
|
||||
{
|
||||
if(this._eventCallback)
|
||||
{
|
||||
GetEventDispatcher().removeEventListener(RoomEngineSamplePlaybackEvent.PLAY_SAMPLE, this._eventCallback);
|
||||
GetEventDispatcher().removeEventListener(RoomEngineObjectEvent.REMOVED, this._eventCallback);
|
||||
GetEventDispatcher().removeEventListener(RoomEngineEvent.DISPOSED, this._eventCallback);
|
||||
GetEventDispatcher().removeEventListener(NitroSettingsEvent.SETTINGS_UPDATED, this._eventCallback);
|
||||
GetEventDispatcher().removeEventListener(NitroSoundEvent.PLAY_SOUND, this._eventCallback);
|
||||
this._eventCallback = null;
|
||||
}
|
||||
|
||||
// Stop all playing samples
|
||||
this._furnitureBeingPlayed.getKeys().forEach((objectId: number) =>
|
||||
{
|
||||
this.stopFurniSample(objectId);
|
||||
});
|
||||
|
||||
// Clear all samples
|
||||
this._internalSamples.dispose();
|
||||
this._furniSamples.dispose();
|
||||
this._furnitureBeingPlayed.dispose();
|
||||
}
|
||||
|
||||
private onEvent(event: INitroEvent)
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { IAdvancedMap, IMusicController, IPlaylistController, ISongInfo } from '@nitrots/api';
|
||||
import { IAdvancedMap, IMessageEvent, IMusicController, IPlaylistController, ISongInfo } from '@nitrots/api';
|
||||
import { GetCommunication, GetNowPlayingMessageComposer, GetSongInfoMessageComposer, GetUserSongDisksMessageComposer, TraxSongInfoMessageEvent, UserSongDisksInventoryMessageEvent } from '@nitrots/communication';
|
||||
import { GetConfiguration } from '@nitrots/configuration';
|
||||
import { GetEventDispatcher, NotifyPlayedSongEvent, NowPlayingEvent, RoomObjectSoundMachineEvent, SongDiskInventoryReceivedEvent, SongInfoReceivedEvent, SoundManagerEvent } from '@nitrots/events';
|
||||
@@ -31,6 +31,7 @@ export class MusicController implements IMusicController
|
||||
private _songIdPlaying: number = 1;
|
||||
private _previousNotifiedSongId: number = -1;
|
||||
private _previousNotificationTime: number = -1;
|
||||
private _messageEvents: IMessageEvent[] = [];
|
||||
|
||||
constructor()
|
||||
{
|
||||
@@ -44,8 +45,11 @@ export class MusicController implements IMusicController
|
||||
|
||||
public init(): void
|
||||
{
|
||||
GetCommunication().registerMessageEvent(new TraxSongInfoMessageEvent(this.onTraxSongInfoMessageEvent.bind(this)));
|
||||
GetCommunication().registerMessageEvent(new UserSongDisksInventoryMessageEvent(this.onSongDiskInventoryMessage.bind(this)));
|
||||
// Store message events for cleanup
|
||||
this._messageEvents.push(
|
||||
GetCommunication().registerMessageEvent(new TraxSongInfoMessageEvent(this.onTraxSongInfoMessageEvent.bind(this))),
|
||||
GetCommunication().registerMessageEvent(new UserSongDisksInventoryMessageEvent(this.onSongDiskInventoryMessage.bind(this)))
|
||||
);
|
||||
|
||||
this._timerInstance = window.setInterval(this.onTick.bind(this), 1000);
|
||||
this._musicPlayer = new MusicPlayer(GetConfiguration().getValue<string>('external.samples.url'));
|
||||
@@ -156,6 +160,13 @@ export class MusicController implements IMusicController
|
||||
this._timerInstance = undefined;
|
||||
}
|
||||
|
||||
// Remove message events
|
||||
for(const event of this._messageEvents)
|
||||
{
|
||||
GetCommunication().removeMessageEvent(event);
|
||||
}
|
||||
this._messageEvents = [];
|
||||
|
||||
GetEventDispatcher().removeEventListener(RoomObjectSoundMachineEvent.JUKEBOX_INIT, this.onJukeboxInit);
|
||||
GetEventDispatcher().removeEventListener(RoomObjectSoundMachineEvent.JUKEBOX_DISPOSE, this.onJukeboxDispose);
|
||||
GetEventDispatcher().removeEventListener(RoomObjectSoundMachineEvent.SOUND_MACHINE_INIT, this.onSoundMachineInit);
|
||||
|
||||
Reference in New Issue
Block a user