Skip to content

Commit

Permalink
🐛 Partially fix memory leaks in emitter editors
Browse files Browse the repository at this point in the history
  • Loading branch information
CosmoMyzrailGorynych committed Dec 24, 2020
1 parent 9ce261d commit 186ed18
Showing 1 changed file with 17 additions and 5 deletions.
22 changes: 17 additions & 5 deletions src/riotTags/particles/emitter-tandem-editor.tag
Original file line number Diff line number Diff line change
Expand Up @@ -262,7 +262,13 @@ emitter-tandem-editor.panel.view.flexrow

this.on('mount', () => {
window.addEventListener('resize', this.updatePreviewLayout);

window.signals.on('emitterResetRequest', this.resetEmitters);
});
this.on('unmount', () => {
window.removeEventListener('resize', this.updatePreviewLayout);
window.signals.off('emitterResetRequest', this.resetEmitters);
});
this.on('mount', () => {
const box = this.refs.preview.getBoundingClientRect();

this.gridGen = require('./data/node_requires/generators/gridTexture').generatePixiTextureGrid;
Expand All @@ -271,6 +277,7 @@ emitter-tandem-editor.panel.view.flexrow
this.renderer = new PIXI.Application({
width: Math.round(box.width),
height: Math.round(box.height),
sharedTicker: false,
view: this.refs.canvas,
antialias: !global.currentProject.settings.rendering.pixelatedrender
});
Expand Down Expand Up @@ -306,12 +313,17 @@ emitter-tandem-editor.panel.view.flexrow

this.resetEmitters();
this.updatePreviewLayout();

window.signals.on('emitterResetRequest', this.resetEmitters);
});
this.on('unmount', () => {
window.removeEventListener('resize', this.updatePreviewLayout);
window.signals.off('emitterResetRequest', this.resetEmitters);
this.emitterContainer = void 0;
if (this.renderer) {
this.renderer.ticker.stop();
this.renderer.destroy();
}
if (this.resetOnCompletionTimeout) {
clearTimeout(this.resetOnCompletionTimeout);
this.resetOnCompletionTimeout = null;
}
});

this.deleteEmitter = emitter => {
Expand Down

0 comments on commit 186ed18

Please sign in to comment.