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

首頁 > 課堂 > 小程序 > 正文

微信小程序canvas組件的簡單運用之涂鴉實例展示

2020-03-21 16:28:59
字體:
來源:轉載
供稿:網友

微信小程序canvas組件的簡單運用之涂鴉實例展示

微信小程序,canvas,組件,涂鴉

源碼

index.html

<view class="container">    <!--畫布區域-->    <view class="canvas_area">        <!--注意:同一頁面中的 canvas-id 不可重復,如果使用一個已經出現過的 canvas-id,該 canvas 標簽對應的畫布將被隱藏并不再正常工作-->        <canvas canvas-id="myCanvas" class="myCanvas"            disable-scroll="false"            bindtouchstart="touchStart"            bindtouchmove="touchMove"            bindtouchend="touchEnd">        </canvas>    </view>    <!--畫布工具區域-->    <view class="canvas_tools">        <view class="box box1" bindtap="penSelect" data-param="5"></view>        <view class="box box2" bindtap="penSelect" data-param="15"></view>        <view class="box box3" bindtap="colorSelect" data-param="#cc0033"></view>        <view class="box box4" bindtap="colorSelect" data-param="#ff9900"></view>        <view class="box box5" bindtap="clearCanvas"></view>    </view></view>

手指滑動代碼

//手指觸摸動作開始  touchStart: function (e) {      //得到觸摸點的坐標      this.startX = e.changedTouches[0].x      this.startY = e.changedTouches[0].y      this.context = wx.createContext()      if(this.isClear){ //判斷是否啟用的橡皮擦功能  ture表示清除  false表示畫畫         this.context.setStrokeStyle('#F8F8F8') //設置線條樣式 此處設置為畫布的背景顏色  橡皮擦原理就是:利用擦過的地方被填充為畫布的背景顏色一致 從而達到橡皮擦的效果         this.context.setLineCap('round') //設置線條端點的樣式         this.context.setLineJoin('round') //設置兩線相交處的樣式         this.context.setLineWidth(20) //設置線條寬度         this.context.save();  //保存當前坐標軸的縮放、旋轉、平移信息         this.context.beginPath() //開始一個路徑         this.context.arc(this.startX,this.startY,5,0,2*Math.PI,true);  //添加一個弧形路徑到當前路徑,順時針繪制  這里總共畫了360度  也就是一個圓形         this.context.fill();  //對當前路徑進行填充         this.context.restore();  //恢復之前保存過的坐標軸的縮放、旋轉、平移信息      }else{         this.context.setStrokeStyle(this.data.color)         this.context.setLineWidth(this.data.pen)         this.context.setLineCap('round') // 讓線條圓潤         this.context.beginPath()      }  },  //手指觸摸后移動  touchMove: function (e) {      var startX1 = e.changedTouches[0].x      var startY1 = e.changedTouches[0].y      if(this.isClear){ //判斷是否啟用的橡皮擦功能  ture表示清除  false表示畫畫        this.context.save();  //保存當前坐標軸的縮放、旋轉、平移信息        this.context.moveTo(this.startX,this.startY);  //把路徑移動到畫布中的指定點,但不創建線條        this.context.lineTo(startX1,startY1);  //添加一個新點,然后在畫布中創建從該點到最后指定點的線條        this.context.stroke();  //對當前路徑進行描邊        this.context.restore()  //恢復之前保存過的坐標軸的縮放、旋轉、平移信息        this.startX = startX1;        this.startY = startY1;      }else{        this.context.moveTo(this.startX, this.startY)        this.context.lineTo(startX1, startY1)        this.context.stroke()        this.startX = startX1;        this.startY = startY1;      }      //只是一個記錄方法調用的容器,用于生成記錄繪制行為的actions數組。context跟<canvas/>不存在對應關系,一個context生成畫布的繪制動作數組可以應用于多個<canvas/>      wx.drawCanvas({         canvasId: 'myCanvas',         reserve: true,         actions: this.context.getActions() // 獲取繪圖動作數組      })  }

以上是一部分代碼展示,下面做核心原理說明:

1、能畫出不同顏色的線條 主要是以下三個方法 setStrokeStyle(畫筆的顏色) moveTo(把路徑移動到畫布中的指定點,但不創建線條) lineTo(添加一個新點,然后在畫布中創建從該點到最后指定點的線條) 這樣就可以從A點坐標到B點坐標??畫出不同顏色的線條啦!!!

2、橡皮擦的原理:之所以能擦掉畫布上的圖像就是通過把要擦掉的區域繪制成與畫布一樣的顏色 這樣就可以”欺騙”自己的眼睛??達到橡皮擦的效果啦!!!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品啪aⅴ在线观看国产| 久久久久久com| 国产日本欧美一区二区三区| 久久久久久久爱| 亚洲风情亚aⅴ在线发布| 91久久国产综合久久91精品网站| 秋霞av国产精品一区| 欧美精品一二区| 欧美大肥婆大肥bbbbb| 亚洲精品午夜精品| 中文字幕亚洲综合| 国产精品亚洲精品| 亚洲天堂网在线观看| 国产精品视频免费在线观看| 国产午夜精品美女视频明星a级| 欧美在线激情视频| 日韩高清免费在线| 性日韩欧美在线视频| 一本大道久久加勒比香蕉| 91中文在线观看| 日韩精品中文字幕视频在线| www.欧美三级电影.com| 国产狼人综合免费视频| 最近免费中文字幕视频2019| 美女国内精品自产拍在线播放| 97在线视频观看| 亚洲国产精久久久久久久| 亚洲激情久久久| 北条麻妃久久精品| 日韩亚洲欧美中文高清在线| 国产免费一区二区三区在线能观看| 欧美一级淫片丝袜脚交| 国产欧美一区二区白浆黑人| 青青久久av北条麻妃黑人| 欧美最猛性xxxxx亚洲精品| 久久精品国产久精国产思思| 一区二区三欧美| 欧美在线观看网站| 亚洲一品av免费观看| 久久久久亚洲精品国产| 韩国日本不卡在线| 国产一区红桃视频| 日韩欧美在线视频日韩欧美在线视频| 久久精品国产91精品亚洲| 国产精品黄页免费高清在线观看| 成人有码在线播放| 91久久久精品| 国产成人在线一区二区| 久久久久成人网| 日韩小视频网址| 亚洲精品视频在线播放| 久久久久一本一区二区青青蜜月| 日韩一区二区av| 91精品国产色综合久久不卡98| 久久中文字幕视频| 91久久久久久久久久| 57pao国产精品一区| 国内精品久久久久久中文字幕| 亚洲成人免费在线视频| 亚洲女人被黑人巨大进入al| 17婷婷久久www| 日韩免费av在线| 成人伊人精品色xxxx视频| 成人免费午夜电影| 国产欧美在线播放| 亚洲无限av看| 国产精品久久久久久久久久| 欧美日韩成人精品| 91久久久久久久久| 国产精品精品久久久久久| 97视频免费在线看| 性色av一区二区咪爱| 日本欧美一级片| 黑人狂躁日本妞一区二区三区| 欧美性做爰毛片| 久久精品国产一区二区三区| 亚洲欧美国产另类| 日韩精品中文字幕久久臀| 久色乳综合思思在线视频| 欧美激情第1页| 久久色免费在线视频| 亚洲色图国产精品| 国产欧美日韩91| 日韩风俗一区 二区| 91福利视频在线观看| 国产+成+人+亚洲欧洲| 91精品啪在线观看麻豆免费| 欧美激情第三页| 欧美大全免费观看电视剧大泉洋| 亚洲欧美在线x视频| 国产精品自产拍在线观| 日韩av在线网址| 欧美性受xxxx白人性爽| 亚洲国产高清福利视频| 欧美在线欧美在线| 久久综合88中文色鬼| 91精品在线播放| 成人网在线免费看| 欧美在线视频观看| 91国内在线视频| 久久久噜噜噜久久中文字免| 亚洲一级片在线看| 96pao国产成视频永久免费| 久久噜噜噜精品国产亚洲综合| 亚洲乱码一区二区| 国产精品678| 久久国产精品首页| 中文字幕欧美专区| 久久亚洲国产成人| 亚洲图中文字幕| 国产成人精品最新| 亚洲影视中文字幕| 97人人爽人人喊人人模波多| 欧美亚洲国产日本| 欧美日韩亚洲一区二区| 久久久视频精品| 精品免费在线视频| 97成人精品区在线播放| 亚洲aaa激情| 亚洲乱码国产乱码精品精| 91精品国产精品| 亚洲丁香婷深爱综合| 日韩av在线直播| 国产精品久久不能| 全色精品综合影院| 大伊人狠狠躁夜夜躁av一区| 亚洲第一二三四五区| 欧美精品激情在线观看| 成人福利视频在线观看| 国产精品日韩一区| 在线播放国产一区二区三区| 91禁外国网站| 日韩av中文字幕在线播放| 国产精品自产拍在线观看中文| 日韩av综合网| 亚洲图片在区色| 日韩中文在线观看| 亚洲女人天堂视频| 日韩在线视频一区| 成人免费网站在线看| 美女国内精品自产拍在线播放| 久久久噜噜噜久久| 成人激情黄色网| 亚洲第一区在线| 久热精品视频在线| 8090成年在线看片午夜| 国产91九色视频| 国产精品久久久久免费a∨| 欧美日韩aaaa| 亚洲天堂免费观看| 91人人爽人人爽人人精88v| 成人免费视频网| 深夜福利91大全| 91精品久久久久久| 亚洲乱亚洲乱妇无码| 亚洲精品综合久久中文字幕| 国产精品一久久香蕉国产线看观看| 亚洲欧美综合图区| 精品亚洲一区二区| 国产精品一区二区三区成人| 激情成人中文字幕| 亚洲成人精品视频| 免费97视频在线精品国自产拍| 97在线免费观看视频|