1e41f4b71Sopenharmony_ci# OffscreenCanvas 2e41f4b71Sopenharmony_ci 3e41f4b71Sopenharmony_ci> **NOTE** 4e41f4b71Sopenharmony_ci> 5e41f4b71Sopenharmony_ci> The APIs of this component are supported since API version 7. Updates will be marked with a superscript to indicate their earliest API version. 6e41f4b71Sopenharmony_ci 7e41f4b71Sopenharmony_ci 8e41f4b71Sopenharmony_ci**OffscreenCanvas** defines a canvas object that can be rendered off the screen. 9e41f4b71Sopenharmony_ci 10e41f4b71Sopenharmony_ci 11e41f4b71Sopenharmony_ci## Attributes 12e41f4b71Sopenharmony_ci 13e41f4b71Sopenharmony_ci| Name | Type | Description | 14e41f4b71Sopenharmony_ci| ------ | ------ | --------------------------- | 15e41f4b71Sopenharmony_ci| width | number | Width of the **OffscreenCanvas** object.| 16e41f4b71Sopenharmony_ci| height | number | Height of the **OffscreenCanvas** object.| 17e41f4b71Sopenharmony_ci 18e41f4b71Sopenharmony_ci 19e41f4b71Sopenharmony_ci## Methods 20e41f4b71Sopenharmony_ci 21e41f4b71Sopenharmony_ci 22e41f4b71Sopenharmony_ci### getContext 23e41f4b71Sopenharmony_ci 24e41f4b71Sopenharmony_cigetContext(type: string, options?: CanvasRenderingContext2DSettings): OffscreenCanvasRenderingContext2D 25e41f4b71Sopenharmony_ci 26e41f4b71Sopenharmony_ciObtains the **OffscreenCanvas** context. This API returns a 2D drawing object. 27e41f4b71Sopenharmony_ci 28e41f4b71Sopenharmony_ci**Parameters** 29e41f4b71Sopenharmony_ci 30e41f4b71Sopenharmony_ci| Name | Type | Mandatory | Description | 31e41f4b71Sopenharmony_ci| --------- | ---------------------------------------- | ---- | ---------------------- | 32e41f4b71Sopenharmony_ci| contextId | string | Yes | Context ID. The value can only be **"2d"**. | 33e41f4b71Sopenharmony_ci| options | [CanvasRenderingContext2DSettings](#canvasrenderingcontext2dsettings) | No | Whether to enable anti-aliasing. By default, anti-aliasing is disabled.| 34e41f4b71Sopenharmony_ci 35e41f4b71Sopenharmony_ci**Return value** 36e41f4b71Sopenharmony_ci 37e41f4b71Sopenharmony_ci| Type | Description | 38e41f4b71Sopenharmony_ci| ---------------------------------------- | --------------------------- | 39e41f4b71Sopenharmony_ci| [OffscreenCanvasRenderingContext2D](js-offscreencanvasrenderingcontext2d.md) | 2D drawing object, which can be used to draw rectangles, images, and texts, on the **OffscreenCanvas**.| 40e41f4b71Sopenharmony_ci 41e41f4b71Sopenharmony_ci### CanvasRenderingContext2DSettings 42e41f4b71Sopenharmony_ci 43e41f4b71Sopenharmony_ciCanvasRenderingContext2DSettings(antialias?: boolean) 44e41f4b71Sopenharmony_ci 45e41f4b71Sopenharmony_ciConfigures the settings of an **OffscreenCanvasRenderingContext2D** object, including whether to enable antialiasing. 46e41f4b71Sopenharmony_ci 47e41f4b71Sopenharmony_ci| Name | Type | Description | 48e41f4b71Sopenharmony_ci| --------- | ------- | ------------------- | 49e41f4b71Sopenharmony_ci| antialias | boolean | Whether to enable anti-aliasing. The default value is **false**.| 50e41f4b71Sopenharmony_ci 51e41f4b71Sopenharmony_ci### toDataURL 52e41f4b71Sopenharmony_ci 53e41f4b71Sopenharmony_citoDataURL(type?: string, quality?:number): string 54e41f4b71Sopenharmony_ci 55e41f4b71Sopenharmony_ciGenerates a URL containing image display information. 56e41f4b71Sopenharmony_ci 57e41f4b71Sopenharmony_ci**Parameters** 58e41f4b71Sopenharmony_ci 59e41f4b71Sopenharmony_ci| Name | Type | Mandatory | Description | 60e41f4b71Sopenharmony_ci| ------- | ------ | ---- | ---------------------------------------- | 61e41f4b71Sopenharmony_ci| type | string | No | Image format. The default value is **image/png**. | 62e41f4b71Sopenharmony_ci| quality | number | No | Image quality, which ranges from 0 to 1, when the image format is **image/jpeg** or **image/webp**. If the set value is beyond the value range, the default value **0.92** is used.| 63e41f4b71Sopenharmony_ci 64e41f4b71Sopenharmony_ci**Return value** 65e41f4b71Sopenharmony_ci 66e41f4b71Sopenharmony_ci| Type | Description | 67e41f4b71Sopenharmony_ci| ------ | --------- | 68e41f4b71Sopenharmony_ci| string | Image URL.| 69e41f4b71Sopenharmony_ci 70e41f4b71Sopenharmony_ci 71e41f4b71Sopenharmony_ci### transferToImageBitmap 72e41f4b71Sopenharmony_ci 73e41f4b71Sopenharmony_citransferToImageBitmap(): ImageBitmap 74e41f4b71Sopenharmony_ci 75e41f4b71Sopenharmony_ciCreates an **ImageBitmap** object on the most recently rendered image of the **OffscreenCanvas**. 76e41f4b71Sopenharmony_ci 77e41f4b71Sopenharmony_ci**Return value** 78e41f4b71Sopenharmony_ci 79e41f4b71Sopenharmony_ci| Type | Description | 80e41f4b71Sopenharmony_ci| ---------------------------------------- | --------------- | 81e41f4b71Sopenharmony_ci| [ImageBitmap](js-components-canvas-imagebitmap.md) | Pixel data rendered on the **OffscreenCanvas**.| 82e41f4b71Sopenharmony_ci 83e41f4b71Sopenharmony_ci 84e41f4b71Sopenharmony_ci## Example 85e41f4b71Sopenharmony_ci 86e41f4b71Sopenharmony_ci```html 87e41f4b71Sopenharmony_ci<!-- xxx.hml --> 88e41f4b71Sopenharmony_ci<div> 89e41f4b71Sopenharmony_ci <canvas ref="canvasId" style="width: 200px; height: 150px; background-color: #ffff00;"></canvas> 90e41f4b71Sopenharmony_ci</div> 91e41f4b71Sopenharmony_ci``` 92e41f4b71Sopenharmony_ci 93e41f4b71Sopenharmony_ci```js 94e41f4b71Sopenharmony_ci//xxx.js 95e41f4b71Sopenharmony_ciexport default { 96e41f4b71Sopenharmony_ci onShow() { 97e41f4b71Sopenharmony_ci var canvas = this.$refs.canvasId.getContext('2d'); 98e41f4b71Sopenharmony_ci var offscreen = new OffscreenCanvas(500,500); 99e41f4b71Sopenharmony_ci var offscreenCanvasCtx = offscreen.getContext("2d"); 100e41f4b71Sopenharmony_ci 101e41f4b71Sopenharmony_ci // ... some drawing for the canvas using the offscreenCanvasCtx ... 102e41f4b71Sopenharmony_ci 103e41f4b71Sopenharmony_ci var dataURL = offscreen.toDataURL(); 104e41f4b71Sopenharmony_ci console.log(dataURL); // 105e41f4b71Sopenharmony_ci 106e41f4b71Sopenharmony_ci var bitmap = offscreen.transferToImageBitmap(); 107e41f4b71Sopenharmony_ci canvas.transferFromImageBitmap(bitmap); 108e41f4b71Sopenharmony_ci } 109e41f4b71Sopenharmony_ci} 110e41f4b71Sopenharmony_ci``` 111