欢迎光临,了解微信小程序开发,就上易用通!

当前位置 : 易用通 > 小程序模板
微信小程序-canvas组件涂鸦微信小程序-canvas组件涂鸦
立即下载

微信小程序-canvas组件涂鸦

模板分类 : 小程序模板 模板编号 : Y178 源码文件 : 完全开源 下载权限 : VIP会员
模板大小 :  模板指数 :  更新时间 : 2018-01-16 15:36 模板等级 : ☆☆☆☆☆

模板截图:

微信小程序-canvas组件涂鸦(图1) 

 

index.html
  1. <font color="#000000"><view class="container">
  2.     <!--画布区域-->
  3.     <view class="canvas_area">
  4.         <!--注意:同一页面中的 canvas-id 不可重复,如果使用一个已经出现过的 canvas-id,该 canvas 标签对应的画布将被隐藏并不再正常工作-->
  5.         <canvas canvas-id="myCanvas" class="myCanvas"
  6.             disable-scroll="false"
  7.             bindtouchstart="touchStart"
  8.             bindtouchmove="touchMove"
  9.             bindtouchend="touchEnd">
  10.         </canvas>
  11.     </view>
  12.     <!--画布工具区域-->
  13.     <view class="canvas_tools">
  14.         <view class="box box1" bindtap="penSelect" data-param="5"></view>
  15.         <view class="box box2" bindtap="penSelect" data-param="15"></view>
  16.         <view class="box box3" bindtap="colorSelect" data-param="#cc0033"></view>
  17.         <view class="box box4" bindtap="colorSelect" data-param="#ff9900"></view>
  18.         <view class="box box5" bindtap="clearCanvas"></view>
  19.     </view>
  20. </view></font>
复制代码
手指滑动代码
  1. <font color="#000000">//手指触摸动作开始
  2.   touchStart: function (e) {
  3.       //得到触摸点的坐标
  4.       this.startX = e.changedTouches[0].x
  5.       this.startY = e.changedTouches[0].y
  6.       this.context = wx.createContext()
  7.  
  8.       if(this.isClear){ //判断是否启用的橡皮擦功能  ture表示清除  false表示画画
  9.          this.context.setStrokeStyle('#F8F8F8') //设置线条样式 此处设置为画布的背景颜色  橡皮擦原理就是:利用擦过的地方被填充为画布的背景颜色一致 从而达到橡皮擦的效果
  10.          this.context.setLineCap('round') //设置线条端点的样式
  11.          this.context.setLineJoin('round') //设置两线相交处的样式
  12.          this.context.setLineWidth(20) //设置线条宽度
  13.          this.context.save();  //保存当前坐标轴的缩放、旋转、平移信息
  14.          this.context.beginPath() //开始一个路径
  15.          this.context.arc(this.startX,this.startY,5,0,2*Math.PI,true);  //添加一个弧形路径到当前路径,顺时针绘制  这里总共画了360度  也就是一个圆形
  16.          this.context.fill();  //对当前路径进行填充
  17.          this.context.restore();  //恢复之前保存过的坐标轴的缩放、旋转、平移信息
  18.       }else{
  19.          this.context.setStrokeStyle(this.data.color)
  20.          this.context.setLineWidth(this.data.pen)
  21.          this.context.setLineCap('round') // 让线条圆润
  22.          this.context.beginPath()
  23.  
  24.       }
  25.   },
  26.   //手指触摸后移动
  27.   touchMove: function (e) {
  28.  
  29.       var startX1 = e.changedTouches[0].x
  30.       var startY1 = e.changedTouches[0].y
  31.  
  32.       if(this.isClear){ //判断是否启用的橡皮擦功能  ture表示清除  false表示画画
  33.  
  34.         this.context.save();  //保存当前坐标轴的缩放、旋转、平移信息
  35.         this.context.moveTo(this.startX,this.startY);  //把路径移动到画布中的指定点,但不创建线条
  36.         this.context.lineTo(startX1,startY1);  //添加一个新点,然后在画布中创建从该点到最后指定点的线条
  37.         this.context.stroke();  //对当前路径进行描边
  38.         this.context.restore()  //恢复之前保存过的坐标轴的缩放、旋转、平移信息
  39.  
  40.         this.startX = startX1;
  41.         this.startY = startY1;
  42.  
  43.       }else{
  44.         this.context.moveTo(this.startX, this.startY)
  45.         this.context.lineTo(startX1, startY1)
  46.         this.context.stroke()
  47.  
  48.         this.startX = startX1;
  49.         this.startY = startY1;
  50.  
  51.       }
  52.       //只是一个记录方法调用的容器,用于生成记录绘制行为的actions数组。context跟<canvas/>不存在对应关系,一个context生成画布的绘制动作数组可以应用于多个<canvas/>
  53.       wx.drawCanvas({
  54.          canvasId: 'myCanvas',
  55.          reserve: true,
  56.          actions: this.context.getActions() // 获取绘图动作数组
  57.       })
  58.   }
  59. </font>
复制代码
以上是一部分代码展示,下面做核心原理说明: 1、能画出不同颜色的线条 主要是以下三个方法 setStrokeStyle(画笔的颜色) moveTo(把路径移动到画布中的指定点,但不创建线条) lineTo(添加一个新点,然后在画布中创建从该点到最后指定点的线条) 这样就可以从A点坐标到B点坐标  画出不同颜色的线条啦!!! 2、橡皮擦的原理:之所以能擦掉画布上的图像就是通过把要擦掉的区域绘制成与画布一样的颜色 这样就可以”欺骗”自己的眼睛  达到橡皮擦的效果啦!!!

加入收藏
立即下载
分享到微信朋友圈
X

免责声明:

1. 本站所有素材(未指定商用),仅限学习交流,请勿用于商业用途。
2. 本站所有小程序模板Demo和图片均来自用户分享上传和网络收集,模板和图片版权归原作者及原出处所有。
3. 未经合法授权,会员不得以任何形式发布、传播、复制、转售该素材。