files/en-us/web/api/canvasrenderingcontext2d/getcontextattributes/index.md
{{APIRef("WebGL")}}
The CanvasRenderingContext2D.getContextAttributes() method returns an object that contains attributes used by the context.
Note that context attributes may be requested when creating the context with HTMLCanvasElement.getContext(), but the attributes that are actually supported and used may differ.
getContextAttributes()
None.
A CanvasRenderingContext2DSettings object that contains the actual context parameters.
It has the following members:
alpha {{optional_inline}}
false, the backdrop is always opaque, which can speed up drawing of transparent content and images.colorSpace {{optional_inline}}
srgb: denotes the sRGB color spacedisplay-p3: denotes the display-p3 color spacecolorType {{optional_inline}}
"unorm8" denotes the color channels to 8 bit unsigned values. This is the default value."float16" denotes the color channels to 16-bit floating-point values.desynchronized {{optional_inline}}
willReadFrequently {{optional_inline}}
This example shows how you can specify context attributes when creating a canvas context, and then call getContextAttributes() to read back the actual parameters that the browser used.
<pre id="log"></pre>
const logElement = document.getElementById("log");
function log(text) {
logElement.innerText += text;
}
First we create a context using HTMLCanvasElement.getContext(), specifying just one context attribute.
let canvas = document.createElement("canvas");
let ctx = canvas.getContext("2d", { alpha: false });
If the getContextAttributes() method is supported, we use it to read back the actual attributes used by the browser (including those we explicitly specified):
if (ctx.getContextAttributes) {
const attributes = ctx.getContextAttributes();
log(JSON.stringify(attributes));
} else {
log("CanvasRenderingContext2D.getContextAttributes() is not supported");
}
Depending on the attributes supported by the browser, the log below should display a string that looks something like: {alpha: false, colorSpace: 'srgb', desynchronized: false, willReadFrequently: false}
{{EmbedLiveSample('Examples','100%','50')}}
{{Specifications}}
{{Compat}}