亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 編程設計 > 正文

基于canvas剪輯區域功能實現橡皮擦效果

2020-01-31 16:12:58
字體:
來源:轉載
供稿:網友

效果如圖

這是基礎結構 沒什么好說的

<!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="./js/test9.js"></script>

下面是重點的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 = falsefunction 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剪輯區域功能實現橡皮擦效果,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产伦精品一区二区三区精品视频| 欧美成人一区在线| 日韩av在线资源| 国产精品美女无圣光视频| 久久久久免费视频| 日韩欧美在线第一页| 国产亚洲成精品久久| 日韩在线免费观看视频| 日韩中文字幕在线免费观看| 亚洲一区亚洲二区亚洲三区| 国产精品日韩欧美| 亚洲精品影视在线观看| 国产亚洲在线播放| 国产精品吊钟奶在线| 久久午夜a级毛片| 国产日韩欧美在线看| 国产精品永久在线| 国内精品久久久久久久久| www.久久草.com| 欧美日韩亚洲视频一区| 亚洲精品国产拍免费91在线| 亚洲欧美日韩一区二区三区在线| 久久精品91久久香蕉加勒比| 日本国产一区二区三区| 性亚洲最疯狂xxxx高清| 精品欧美国产一区二区三区| 大荫蒂欧美视频另类xxxx| 91精品国产乱码久久久久久久久| 国内偷自视频区视频综合| 超碰日本道色综合久久综合| 亚洲r级在线观看| 中文字幕精品国产| 久久精品福利视频| 日韩在线免费视频观看| 精品福利在线看| 国产精品丝袜高跟| 亚洲精品国产福利| 欧美视频在线观看免费| 日韩精品视频观看| 精品人伦一区二区三区蜜桃免费| 欧美成人精品xxx| 精品久久久香蕉免费精品视频| 日韩欧美极品在线观看| 国产99视频在线观看| 亚洲精品国产电影| 91中文字幕在线观看| 国产一区二区香蕉| 97在线观看视频国产| 自拍视频国产精品| 亚洲欧美精品中文字幕在线| 国模极品一区二区三区| 国产精品高清在线观看| 欧美电影免费观看电视剧大全| 国产精品人人做人人爽| 欧美日产国产成人免费图片| 久久夜色精品国产欧美乱| 国产精品久久综合av爱欲tv| 久久人人爽国产| 热re91久久精品国99热蜜臀| 亚洲欧美日韩国产成人| 午夜精品蜜臀一区二区三区免费| 国产精品999| 亚洲一级片在线看| 日韩美女主播视频| 国产精品v片在线观看不卡| 久久久久久久一区二区三区| 久久久久久午夜| 中文字幕日韩在线播放| 在线精品视频视频中文字幕| 欧美激情久久久久| 久久综合久久88| 亚洲欧美一区二区三区在线| 国产成人综合av| 日韩高清人体午夜| 性欧美视频videos6一9| 国产成人精品免费久久久久| 亚洲伊人一本大道中文字幕| 欧美日韩免费一区| 亚洲摸下面视频| 黑人精品xxx一区一二区| 久久精品免费播放| 国产欧美日韩免费看aⅴ视频| 影音先锋欧美在线资源| 久久久久日韩精品久久久男男| 成人性生交大片免费观看嘿嘿视频| 欧美激情aaaa| 亚洲色在线视频| 日韩av中文字幕在线| 日韩精品欧美激情| 成人国产亚洲精品a区天堂华泰| 国产主播精品在线| 欧美午夜久久久| 亚洲热线99精品视频| 久久精品国产91精品亚洲| 国内精品久久久久久久| 成人午夜两性视频| 91精品国产成人www| 亚洲精品视频在线观看视频| 日韩中文字幕av| 亚洲一二在线观看| 久久久999精品免费| 78色国产精品| 青青久久aⅴ北条麻妃| 97精品视频在线播放| 日韩一区视频在线| 国产日韩在线看| 亚洲国产精品美女| 最近日韩中文字幕中文| 中文字幕九色91在线| 亚洲精品久久久久中文字幕欢迎你| 最近2019中文字幕在线高清| 欧美情侣性视频| 久久天堂电影网| 国产成人精品视频在线观看| 久久精品色欧美aⅴ一区二区| 色诱女教师一区二区三区| 成人免费观看49www在线观看| 日韩视频欧美视频| 国产精品视频白浆免费视频| 色天天综合狠狠色| 欧美xxxx18国产| 国产伊人精品在线| 欧美成人精品一区二区三区| 亚洲最大激情中文字幕| 亚洲欧洲午夜一线一品| 亚洲成av人片在线观看香蕉| 亚洲精品国产品国语在线| 国产一区二区丝袜高跟鞋图片| 欧美成人精品激情在线观看| 成人免费在线视频网站| 国产视频欧美视频| 深夜福利国产精品| 国产精品国产自产拍高清av水多| 久久精品中文字幕一区| 精品无人区乱码1区2区3区在线| 九九精品视频在线| 国产成人av在线| 国内精品一区二区三区四区| 日韩成人激情视频| 欧美日本精品在线| 97久久精品人人澡人人爽缅北| 久久久久久久久久久久av| 日韩欧美视频一区二区三区| 欧美激情欧美狂野欧美精品| 久久久久久久久综合| 欧美日韩亚洲精品一区二区三区| www.久久久久久.com| 久久人人爽亚洲精品天堂| 色噜噜久久综合伊人一本| 亚洲四色影视在线观看| 日韩电影在线观看免费| 亚洲精品在线视频| 久久精品国产电影| 欧美视频免费在线| 欧美日韩亚洲一区二区| 日韩视频免费大全中文字幕| 国产午夜精品美女视频明星a级| 久久人体大胆视频| 一区二区在线视频播放| 日韩av观看网址| 亚洲最大成人免费视频| 国产精品美女久久久久久免费| 日韩精品免费观看| 国产精品久久久久7777婷婷|