# OffscreenCanvasRenderingContext2D对象 使用OffscreenCanvas在离屏Canvas画布组件上进行绘制,绘制对象可以是矩形、文本、图片等。 离屏,即GPU在当前缓冲区以外新开辟的一个缓冲区。 具体请参考[OffscreenCanvasRenderingContext2D对象](../reference/arkui-js/js-offscreencanvasrenderingcontext2d.md)。 以下示例创建了一个OffscreenCanvas画布,再在画布上创建一个getContext2d对象,并设置filter属性改变图片样式。 ```html
``` ```css /* xxx.css */ .container{ width: 100%; height: 100%; flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } canvas{ width: 600px; height: 500px; background-color: #fdfdfd; border: 5px solid red; } select{ margin-top: 50px; width: 250px; height: 100px; background-color: white; } ``` ```js // xxx.js import promptAction from '@ohos.promptAction'; export default { data:{ el: null, ctx: null, offscreen: null, offCanvas: null, img: null, }, onShow(){ this.ctx = this.$refs.canvas1.getContext("2d"); this.offscreen = new OffscreenCanvas(600, 500); this.offCanvas = this.offscreen.getContext("2d"); this.img = new Image(); this.img.src = 'common/images/2.png'; // 图片成功获取触发方法 let _this = this; this.img.onload = function() { _this.offCanvas.drawImage(_this.img, 100, 100, 400, 300); }; this.img.onerror = function() { promptAction.showToast({message:"error",duration:2000}) }; var bitmap = this.offscreen.transferToImageBitmap(); this.ctx.transferFromImageBitmap(bitmap); }, change(e){ this.offCanvas.filter = e.newValue;this.offCanvas.drawImage(this.img, 100, 100, 400, 300); var bitmap = this.offscreen.transferToImageBitmap(); this.ctx.transferFromImageBitmap(bitmap); }, } ``` ![zh-cn_image_0000001218599708](figures/zh-cn_image_0000001218599708.gif) ## 判断位置 使用isPointInPath判断坐标点是否在路径的区域内,使用isPointInStroke判断坐标点是否在路径的边缘线上,并在页面上显示返回结果。 ```html
坐标:{{X}}, {{Y}} In path:{{textValue}} In stroke:{{textValue1}}
``` ```css /* xxx.css */ .container{ width: 100%; height: 100%; flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } canvas{ width: 600px; height: 500px; background-color: #fdfdfd; border: 5px solid red; } .content{ flex-direction: column; justify-content: center; align-items: center; } text{ font-size: 30px; width: 300px; height: 80px; text-align: center; } button{ width: 180px; height: 75px; margin-top: 50px; } ``` ```js // xxx.js export default { data: { textValue: 0, textValue1: 0, X:0, Y:250, }, onShow(){ let canvas = this.$refs.canvas.getContext('2d'); let offscreen = new OffscreenCanvas(500,500); let offscreenCanvasCtx = offscreen.getContext("2d"); let offscreenCanvasCtx1 = offscreen.getContext("2d"); offscreenCanvasCtx1.arc(this.X, this.Y, 2, 0, 6.28); offscreenCanvasCtx.lineWidth=20; offscreenCanvasCtx.rect(200,150, 200, 200); offscreenCanvasCtx.stroke(); this.textValue1 = offscreenCanvasCtx.isPointInStroke(this.X, this.Y)?'true':'false'; this.textValue = offscreenCanvasCtx.isPointInPath(this.X, this.Y)?'true':'false'; let bitmap = offscreen.transferToImageBitmap(); canvas.transferFromImageBitmap(bitmap); }, change(){ if(this.X < 500){ this.X = this.X+50; }else{ this.X = 0; } let canvas = this.$refs.canvas.getContext('2d'); let offscreen = new OffscreenCanvas(500,500); let offscreenCanvasCtx = offscreen.getContext("2d"); let offscreenCanvasCtx1 = offscreen.getContext("2d"); offscreenCanvasCtx1.arc(this.X, this.Y, 1, 0, 6.28) offscreenCanvasCtx.lineWidth=20 offscreenCanvasCtx.rect(200,150, 200, 200); offscreenCanvasCtx.stroke(); this.textValue1 = offscreenCanvasCtx.isPointInStroke(this.X, this.Y)?'true':'false'; this.textValue = offscreenCanvasCtx.isPointInPath(this.X, this.Y)?'true':'false'; let bitmap = offscreen.transferToImageBitmap(); canvas.transferFromImageBitmap(bitmap); } } ``` ![zh-cn_image_0000001178084014](figures/zh-cn_image_0000001178084014.gif)