1# OffscreenCanvasRenderingContext2D对象 2 3使用OffscreenCanvas在离屏Canvas画布组件上进行绘制,绘制对象可以是矩形、文本、图片等。 离屏,即GPU在当前缓冲区以外新开辟的一个缓冲区。 具体请参考[OffscreenCanvasRenderingContext2D对象](../reference/arkui-js/js-offscreencanvasrenderingcontext2d.md)。 4 5以下示例创建了一个OffscreenCanvas画布,再在画布上创建一个getContext2d对象,并设置filter属性改变图片样式。 6 7```html 8<!-- xxx.hml --> 9<div class="container"> 10 <canvas ref="canvas1"></canvas> 11 <select @change="change()"> 12 <option value="blur(5px)">blur</option> 13 <option value="grayscale(50%)">grayscale</option> 14 <option value="hue-rotate(45deg)">hue-rotate</option> 15 <option value="invert(100%)">invert</option> 16 <option value="drop-shadow(8px 8px 10px green)">drop-shadow</option> 17 <option value="brightness(0.4)">brightness</option> 18 <option value="opacity(0.25)">opacity</option> 19 <option value="saturate(30%)">saturate</option> 20 <option value="sepia(60%)">sepia</option> 21 <option value="contrast(200%)">contrast</option> 22 </select> 23</div> 24``` 25 26```css 27/* xxx.css */ 28.container{ 29 width: 100%; 30 height: 100%; 31 flex-direction: column; 32 justify-content: center; 33 align-items: center; 34 background-color: #F1F3F5; 35} 36canvas{ 37 width: 600px; 38 height: 500px; 39 background-color: #fdfdfd; 40 border: 5px solid red; 41} 42select{ 43 margin-top: 50px; 44 width: 250px; 45 height: 100px; 46 background-color: white; 47} 48``` 49 50```js 51// xxx.js 52import promptAction from '@ohos.promptAction'; 53export default { 54 data:{ 55 el: null, 56 ctx: null, 57 offscreen: null, 58 offCanvas: null, 59 img: null, 60 }, 61 onShow(){ 62 this.ctx = this.$refs.canvas1.getContext("2d"); 63 this.offscreen = new OffscreenCanvas(600, 500); 64 this.offCanvas = this.offscreen.getContext("2d"); 65 this.img = new Image(); 66 this.img.src = 'common/images/2.png'; 67 // 图片成功获取触发方法 68 let _this = this; 69 this.img.onload = function() { 70 _this.offCanvas.drawImage(_this.img, 100, 100, 400, 300); 71 }; 72 this.img.onerror = function() { 73 promptAction.showToast({message:"error",duration:2000}) 74 }; 75 var bitmap = this.offscreen.transferToImageBitmap(); this.ctx.transferFromImageBitmap(bitmap); 76 }, 77 change(e){ 78 this.offCanvas.filter = e.newValue;this.offCanvas.drawImage(this.img, 100, 100, 400, 300); 79 var bitmap = this.offscreen.transferToImageBitmap(); 80 this.ctx.transferFromImageBitmap(bitmap); 81 }, 82} 83``` 84 85 86![zh-cn_image_0000001218599708](figures/zh-cn_image_0000001218599708.gif) 87 88 89## 判断位置 90 91使用isPointInPath判断坐标点是否在路径的区域内,使用isPointInStroke判断坐标点是否在路径的边缘线上,并在页面上显示返回结果。 92 93 94```html 95<!-- xxx.hml --> 96<div class="container"> 97 <div class="content"> 98 <text>坐标:{{X}}, {{Y}}</text> 99 <text>In path:{{textValue}}</text> 100 <text>In stroke:{{textValue1}}</text> 101 </div> 102 <canvas ref="canvas"></canvas> 103 <button onclick="change">Add(50)</button> 104</div> 105``` 106 107 108```css 109/* xxx.css */ 110.container{ 111 width: 100%; 112 height: 100%; 113 flex-direction: column; 114 justify-content: center; 115 align-items: center; 116 background-color: #F1F3F5; 117} 118canvas{ 119 width: 600px; 120 height: 500px; 121 background-color: #fdfdfd; 122 border: 5px solid red; 123} 124.content{ 125 flex-direction: column; 126 justify-content: center; 127 align-items: center; 128} 129text{ 130 font-size: 30px; 131 width: 300px; 132 height: 80px; 133 text-align: center; 134} 135button{ 136 width: 180px; 137 height: 75px; 138 margin-top: 50px; 139} 140``` 141 142 143```js 144// xxx.js 145export default { 146 data: { 147 textValue: 0, 148 textValue1: 0, 149 X:0, 150 Y:250, 151 }, 152 onShow(){ 153 let canvas = this.$refs.canvas.getContext('2d'); 154 let offscreen = new OffscreenCanvas(500,500); 155 let offscreenCanvasCtx = offscreen.getContext("2d"); 156 let offscreenCanvasCtx1 = offscreen.getContext("2d"); 157 offscreenCanvasCtx1.arc(this.X, this.Y, 2, 0, 6.28); 158 offscreenCanvasCtx.lineWidth=20; 159 offscreenCanvasCtx.rect(200,150, 200, 200); 160 offscreenCanvasCtx.stroke(); 161 this.textValue1 = offscreenCanvasCtx.isPointInStroke(this.X, this.Y)?'true':'false'; 162 this.textValue = offscreenCanvasCtx.isPointInPath(this.X, this.Y)?'true':'false'; 163 let bitmap = offscreen.transferToImageBitmap(); 164 canvas.transferFromImageBitmap(bitmap); 165 }, 166 change(){ 167 if(this.X < 500){ 168 this.X = this.X+50; 169 }else{ 170 this.X = 0; 171 } 172 let canvas = this.$refs.canvas.getContext('2d'); 173 let offscreen = new OffscreenCanvas(500,500); 174 let offscreenCanvasCtx = offscreen.getContext("2d"); 175 let offscreenCanvasCtx1 = offscreen.getContext("2d"); 176 offscreenCanvasCtx1.arc(this.X, this.Y, 1, 0, 6.28) 177 offscreenCanvasCtx.lineWidth=20 178 offscreenCanvasCtx.rect(200,150, 200, 200); 179 offscreenCanvasCtx.stroke(); 180 this.textValue1 = offscreenCanvasCtx.isPointInStroke(this.X, this.Y)?'true':'false'; 181 this.textValue = offscreenCanvasCtx.isPointInPath(this.X, this.Y)?'true':'false'; 182 let bitmap = offscreen.transferToImageBitmap(); 183 canvas.transferFromImageBitmap(bitmap); 184 } 185} 186``` 187 188![zh-cn_image_0000001178084014](figures/zh-cn_image_0000001178084014.gif) 189