~~Class: RenderableGCSystem~~
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:68
The RenderableGCSystem is responsible for cleaning up GPU resources that are no longer being used.
When rendering objects like sprites, text, etc - GPU resources are created and managed by the renderer. If these objects are no longer needed but not properly destroyed (via sprite.destroy()), their GPU resources would normally leak. This system prevents that by automatically cleaning up unused GPU resources.
Key features:
- Runs every 30 seconds by default to check for unused resources
- Cleans up resources not rendered for over 1 minute
- Works independently of rendering - will clean up even when not actively rendering
- When cleaned up resources are needed again, new GPU objects are quickly assigned from a pool
- Can be disabled with renderableGCActive:false for manual control
Best practices:
- Always call destroy() explicitly when done with renderables (e.g. sprite.destroy())
- This system is a safety net, not a replacement for proper cleanup
- Adjust frequency and timeouts via options if needed
Example
// Sprite created but reference lost without destroy
let sprite = new Sprite(texture);
// internally the renderer will assign a resource to the sprite
renderer.render(sprite);
sprite = null; // Reference lost but GPU resources still exist
// After 1 minute of not being rendered:
// - RenderableGC will clean up the sprite's GPU resources
// - JS garbage collector can then clean up the sprite itself
Advanced
Deprecated
since 8.15.0
Implements
Constructors
Constructor
> new RenderableGCSystem(renderer): RenderableGCSystem
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:92
Creates a new RenderableGCSystem instance.
Parameters
renderer
The renderer this garbage collection system works for
Returns
RenderableGCSystem
Properties
~~maxUnusedTime~~
> maxUnusedTime: number
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:85
Maximum time in ms a resource can be unused before being garbage collected
~~defaultOptions~~
> static defaultOptions: RenderableGCSystemOptions
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:83
Default configuration options for the garbage collection system. These can be overridden when initializing the renderer.
Deprecated
since 8.15.0
Accessors
~~enabled~~
Get Signature
> get enabled(): boolean
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:102
Gets whether the garbage collection system is currently enabled.
Returns
boolean
True if GC is enabled, false otherwise
Set Signature
> set enabled(value): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:108
Enables or disables the garbage collection system. When enabled, schedules periodic cleanup of resources. When disabled, cancels all scheduled cleanups.
Parameters
value
boolean
Returns
void
Methods
~~addManagedArray()~~
> addManagedArray<T>(context, hash): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:120
Adds an array to be managed by the garbage collector.
Type Parameters
T
T
Parameters
context
T
The object containing the array
hash
string
The property name of the array
Returns
void
~~addManagedHash()~~
> addManagedHash<T>(context, hash): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:114
Adds a hash table to be managed by the garbage collector.
Type Parameters
T
T
Parameters
context
T
The object containing the hash table
hash
string
The property name of the hash table
Returns
void
~~addRenderable()~~
> addRenderable(_renderable): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:126
Starts tracking a renderable for garbage collection.
Parameters
_renderable
The renderable to track
Returns
void
Deprecated
since 8.15.0
~~destroy()~~
> destroy(): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:133
Cleans up the garbage collection system. Disables GC and removes all tracked resources.
Returns
void
Implementation of
~~init()~~
> init(options): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:97
Initializes the garbage collection system with the provided options.
Parameters
options
Configuration options for the renderer
Returns
void
Implementation of
~~run()~~
> run(): void
Defined in: node_modules/pixi.js/lib/rendering/renderers/shared/texture/RenderableGCSystem.d.ts:131
Performs garbage collection by cleaning up unused renderables. Removes renderables that haven't been used for longer than maxUnusedTime.
Returns
void