手把手教你微信小程序的canvas组进行涂鸦

核心原理说明:

  1、能画出不同颜色的线条 主要是以下三个方法 setStrokeStyle(画笔的颜色) moveTo(把路径移动到画布中的指定点,但不创建线条) lineTo(添加一个新点,然后在画布中创建从该点到最后指定点的线条) 这样就可以从A点坐标到B点坐标 画出不同颜色的线条啦!!!

  2、橡皮擦的原理:之所以能擦掉画布上的图像就是通过把要擦掉的区域绘制成与画布一样的颜色 这样就可以”欺骗”自己的眼睛 达到橡皮擦的效果啦!!!

手把手教你微信小程序的canvas组进行涂鸦

  index.html

  disable-scroll="false"

  bindtouchstart="touchStart"

  bindtouchmove="touchMove"

  bindtouchend="touchEnd">

  复制代码

  手指滑动代码

  //手指触摸动作开始

  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跟不存在对应关系,一个context生成画布的绘制动作数组可以应用于多个

  wx.drawCanvas({

  canvasId: 'myCanvas',

  reserve: true,

  actions: this.context.getActions() // 获取绘图动作数组

  })

  }

  复制代码

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

  1、能画出不同颜色的线条 主要是以下三个方法 setStrokeStyle(画笔的颜色) moveTo(把路径移动到画布中的指定点,但不创建线条) lineTo(添加一个新点,然后在画布中创建从该点到最后指定点的线条) 这样就可以从A点坐标到B点坐标 画出不同颜色的线条啦!!!

  2、橡皮擦的原理:之所以能擦掉画布上的图像就是通过把要擦掉的区域绘制成与画布一样的颜色 这样就可以”欺骗”自己的眼睛 达到橡皮擦的效果啦!!!

  以上就是如何使用微信小程序的canvas组进行涂鸦的全部内容了,大家都学会了吗?更多小程序开发入门。


【本站声明】
  1、本站文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如果有侵权请立即联系。
  2、本网站不对文章中所涉及的内容真实性、准确性、可靠性负责,仅系客观性描述,如您需要了解该类商品/服务详细的资讯,请您直接与该类商品/服务的提供者联系。


KESION 科汛软件

KESION 科汛软件是国内领先的在线教育软件及私域社交电商软件服务提供商,长期专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。
公司核心产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化独立部署品牌网校和在线教育咨询等。

KESION 不断通过技术创新,提供产品和服务,助力企业向数字化转型,通过科技驱动商业革新,让商业变得更智慧!



▼点击进入科汛官网了解更多



热门标签
微信小程序 SaaS
上/下篇
  • 微信小程序获取绑定事件元素的ID

  • 小程序全屏展示图片的实现方式

换一换相关推荐
精选内容
热点精选