效果如图
这是基础结构 没什么好说的
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> *{padding: 0;margin: 0} a{text-decoration: none} img{border: none} ul,ol{list-style: none} br{font-size: 0;line-height: 0;font-size: 0} canvas{border: 1px solid red;background: white} body{background: gray;text-align: center} </style> </head> <body> <div id='controls'> Stroke color: <select id='strokeStyleSelect'> <option value='red'>red</option> <option value='green'>green</option> <option value='blue'>blue</option> <option value='orange'>orange</option> <option value='cornflowerblue'>cornflowerblue</option> <option value='goldenrod'>goldenrod</option> <option value='navy' selected>navy</option> <option value='purple'>purple</option> <option value='purple'>purple</option> </select> Fill color: <select id='fillStyleSelect'> <option value='rgba(255,0,0,0.5)'>semi-transparent red</option> <option value='green'>green</option> <option value='rgba(0,0,255,0.5)'>semi-transparent blue</option> <option value='orange'>orange</option> <option value='rgba(100,140,230,0.5)'>semi-transparent cornflowerblue</option> <option value='goldenrod' selected>goldenrod</option> <option value='navy'>navy</option> <option value='purple'>purple</option> </select> Draw <input id='drawRadio' name='drawEraserRadios' type='radio' checked/> Erase <input id='eraserRadio' name='drawEraserRadios' type='radio'/> Eraser: <select id='eraserShapeSelect'> <option value='circle'>circle</option> <option value='square'>square</option> </select> Eraser width: <select id='eraserWidthSelect'> <option value=25>25</option> <option value=50>50</option> <option value=75>75</option> <option value=100>100</option> <option value=125>125</option> <option value=150>150</option> <option value=175>175</option> <option value=200>200</option> </select> </div> <canvas id="canvas" width="950" height="600"></canvas> </body> </html> <script src="/UploadFiles/2021-04-08/test9.js">下面是重点的js
这里有个坑要十分注意 调用clip()方法的时候,所定义的剪辑区域总是局限于期初的那个剪辑区域范围。
简单来说 clip()方法总是在上一次的剪辑区域基础上进行操作,所以说我们要把clip()方法放在save()和restore()方法中var canvas = document.getElementById('canvas'), context = canvas.getContext('2d'), strokeStyleSelect = document.getElementById('strokeStyleSelect'), //画图的描边颜色 fillStyleSelect = document.getElementById('fillStyleSelect'), //画图填充颜色 drawRadio = document.getElementById('drawRadio'), //画图按钮 eraserRadio = document.getElementById('eraserRadio'), //橡皮擦按钮 eraserShapeSelect = document.getElementById('eraserShapeSelect'), //橡皮擦形状 eraserWidthSelect = document.getElementById('eraserWidthSelect'), //橡皮擦宽度 ERASER_LINE_WIDTH = 1, drawingSurfaceImageData, lastX, lastY, mousedown = {}, rubberbandRect = {}, dragging = false function windowToCanvas(x,y){ //这个函数的作用是捕捉鼠标点在canvas上的坐标 var bbox=canvas.getBoundingClientRect() return { x:x-bbox.left, y:y-bbox.top } } function saveDrawingSurface(){ //这个函数的作用是初始化读取画布信息并储存起来 drawingSurfaceImageData=context.getImageData(0,0,canvas.width,canvas.height) } function restoreDrawingSurface(){ //这个函数的作用是读取画布信息 context.putImageData(drawingSurfaceImageData,0,0) } function drawGrid(){ //这个函数的作用是填充进橡皮擦的剪辑区域 context.save() context.fillStyle="#fff" context.fillRect(0,0,canvas.width,canvas.height) context.restore() } function drawrubber(x,y){ context.beginPath() context.arc(x,y,eraserWidthSelect.value,0,Math.PI*2,false) context.clip() } function drawCri(x,y){ var x_width=Math.abs(x-mousedown.x) var y_width=Math.abs(y-mousedown.y) var radius=Math.sqrt(x_width*x_width+y_width*y_width) context.save() context.beginPath() context.fillStyle=fillStyleSelect.value; context.arc(mousedown.x,mousedown.y,radius,0,Math.PI*2,false) context.fill() context.restore() } canvas.onmousedown=function(e){ var loc=windowToCanvas(e.clientX,e.clientY) mousedown.x=loc.x mousedown.y=loc.y lastX=loc.x lastY=loc.y saveDrawingSurface() dragging=true } canvas.onmousemove=function(e){ if(dragging){ var loc=windowToCanvas(e.clientX,e.clientY) if(drawRadio.checked){ //如果是画图状态 // restoreDrawingSurface() drawCri(loc.x,loc.y) }else{ //如果是橡皮擦状态 context.save() drawrubber(loc.x,loc.y) drawGrid() context.restore() } } } canvas.onmouseup=function(e){ dragging=false; var loc=windowToCanvas(e.clientX,e.clientY) if(drawRadio.checked){ lastX=loc.x; lastY=loc.y; restoreDrawingSurface() drawCri(lastX,lastY) }else{ context.save() drawrubber(loc.x,loc.y) drawGrid() context.restore() } }总结
以上所述是小编给大家介绍的基于canvas剪辑区域功能实现橡皮擦效果,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年12月26日
2024年12月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]