Managing the renderer state
Ogma provides three types of renderer: WebGL, Canvas and SVG. WebGL is the default one, and offers by far the best performance. But it can happen that the WebGL renderer is unavailable, usually because of one of the following reasons:
- The browser does not support WebGL (for example IE 10 and older)
- The hardware doesn't have a GPU (even integrated), or the GPU is blacklisted by the browser
- A specific hardware/software configuration is incorrectly handled by Ogma
If the WebGL render is unavailable, Ogma will automatically switch to the Canvas renderer with a message in the console.
But it can be useful to programmatically know when and why the renderer is not available. For that purpose, Ogma provides
the rendererStateChange
event:
ogma.events.on('rendererStateChange', function(evt) {
console.log('renderer "' + evt.type + '" entered state "' + evt.state + '"');
if (evt.state === 'error') {
console.log(' - code: ' + evt.code);
console.log(' - message: ' + evt.message);
}
});
When ogma is initialized, if WebGL is available you should get this in the console:
renderer "webgl" entered state "requested"
renderer "webgl" entered state "ok"
If WebGL is not available (e.g IE 10), you should get this in the console:
renderer "webgl" entered state "requested"
renderer "webgl" entered state "error"
- code: NO_WEBGL
- message: Unable to create a WebGL context: `canvas.getContext("webgl")` and `canvas.getContext("experimental-webgl")` returned `null`
renderer "canvas" entered state "requested"
renderer "canvas" entered state "ok"
Notice that the canvas renderer is requested as soon as the WebGL renderer is unavailable.
evt.type
indicates the type of renderer and can have 4 values: "webgl"
, "canvas"
, "svg"
or null
(headless
renderer, used by default in Node.js).
evt.state
can have three values:
"requested"
: the renderer is not initialized yet, Ogma will try to initialize it"ok"
: the renderer has been successfully initialized and is running normally"error"
: the renderer has encountered an error and will stop
The only renderer that can be in the error
state is the WebGL renderer. When that happens, evt.code
gives information
on why the renderer is unavailable:
"NO_WEBGL"
: the browser or hardware does not support WebGL"NO_ANGLE_INSTANCED_ARRAYS"
: the browser or hardware does not support theANGLE_instanced_arrays
WebGL extension that is used by Ogma"OTHER"
: unexpected error, if that happens contact support@linkurio.us
evt.message
is a string indicating the exact meaning of the error code (or the stacktrace
if the error is unexpected).
Side note: it's possible to change renderer at runtime with:
ogma.setOptions({renderer: "canvas"});
Where the value of renderer
can be "webgl"
, "canvas"
, "svg"
or null
.