微信小程序canvas写字板效果及实例

作者:透笔度 时间:2024-04-19 09:44:03 

微信小程序canvas写字板效果及实例

写字板效果:书写文字,画板重置,导出图片,导出图片前判断是否书写内容

微信小程序canvas写字板效果及实例微信小程序canvas写字板效果及实例

app.json:

添加一个路由:"pages/canvas/canvas"


{
"pages":[
 "pages/index/index",
 "pages/logs/logs",
 "pages/canvas/canvas"
],
"window":{
 "navigationBarBackgroundColor": "#ea6a46",
 "navigationBarTextStyle":"white",
 "navigationBarTitleText": "写字板",
 "backgroundTextStyle":"dark",
 "backgroundColor":"white",
 "enablePullDownRefresh":"true"
}
}

然后就是:

canvas.wxml:


<!--pages/canvas/canvas.wxml-->
<canvas class="canvas" id="canvas" canvas-id="canvas" disable-scroll="true" bindtouchstart="canvasStart" bindtouchmove="canvasMove" bindtouchend="canvasEnd" touchcancel="canvasEnd" binderror="canvasIdErrorCallback"></canvas>
<button type="default" bindtap="cleardraw">清除画布</button>
<button type="default" bindtap="getimg">导出图片</button>

canvas.js:


// canvas 全局配置
var context = null;// 使用 wx.createContext 获取绘图上下文 context
var isButtonDown = false;
var arrx = [];
var arry = [];
var arrz = [];
var canvasw = 0;
var canvash = 0;
//获取系统信息
wx.getSystemInfo({
success: function (res) {
 canvasw = res.windowWidth;//设备宽度
 canvash = res.windowWidth*7/15;
}
});
//注册页面
Page({
canvasIdErrorCallback: function (e) {
 console.error(e.detail.errMsg)
},
canvasStart: function (event){
 isButtonDown = true;
 arrz.push(0);
 arrx.push(event.changedTouches[0].x);
 arry.push(event.changedTouches[0].y);
 //context.moveTo(event.changedTouches[0].x, event.changedTouches[0].y);

},
canvasMove: function (event) {
 if (isButtonDown) {
  arrz.push(1);
  arrx.push(event.changedTouches[0].x);
  arry.push(event.changedTouches[0].y);
  // context.lineTo(event.changedTouches[0].x, event.changedTouches[0].y);
  // context.stroke();
  // context.draw()

};

for (var i = 0; i < arrx.length; i++) {
  if (arrz[i] == 0) {
   context.moveTo(arrx[i], arry[i])
  } else {
   context.lineTo(arrx[i], arry[i])
  };

};
 context.clearRect(0, 0, canvasw, canvash);
 context.stroke();

context.draw(true);
},
canvasEnd: function (event) {
 isButtonDown = false;
},
cleardraw: function () {
 //清除画布
 arrx = [];
 arry = [];
 arrz = [];
 context.clearRect(0, 0, canvasw, canvash);
 context.draw(true);
},
getimg: function(){
 if (arrx.length==0){
  wx.showModal({
   title: '提示',
   content: '签名内容不能为空!',
   showCancel: false
  });
  return false;
 };
 //生成图片
 wx.canvasToTempFilePath({
  canvasId: 'canvas',
  success: function (res) {
   console.log(res.tempFilePath);
   //存入服务器
   wx.uploadFile({
    url: 'a.php', //接口地址
    filePath: res.tempFilePath,
    name: 'file',
    formData: {                 //HTTP 请求中其他额外的 form data
     'user': 'test'
    },
    success: function (res) {
     console.log(res);
    },
    fail: function (res) {
     console.log(res);
    },
    complete: function (res) {

}
   });
  }
 })

},
/**
 * 页面的初始数据
 */
data: {
 src: ""
},
/**
 * 生命周期函数--监听页面加载
 */
onLoad: function (options) {
 // 使用 wx.createContext 获取绘图上下文 context
 context = wx.createCanvasContext('canvas');
 context.beginPath()
 context.setStrokeStyle('#000000');
 context.setLineWidth(4);
 context.setLineCap('round');
 context.setLineJoin('round');

}
})

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

来源:https://my.oschina.net/tbd/blog/956518

标签:微信小程序,canvas
0
投稿

猜你喜欢

  • 原生javascript运动函数的封装示例【匀速、抛物线、多属性的运动等】

    2024-04-25 13:15:33
  • JavaScript中尽量用局部变量的原因[译]

    2009-02-20 13:45:00
  • javascript replace()用法详解附实例代码

    2024-04-17 09:42:52
  • selenium在scrapy中的使用代码

    2021-11-24 09:34:16
  • sql server 2008 压缩备份数据库(20g)

    2024-01-15 09:23:41
  • python中验证码连通域分割的方法详解

    2022-09-30 11:04:00
  • MySql中如何使用 explain 查询 SQL 的执行计划

    2024-01-15 10:25:01
  • python3.x zip用法小结

    2023-08-13 05:25:05
  • 6个Python办公黑科技,助你提升工作效率

    2022-11-15 14:31:21
  • Centos7 安装mysql 8.0.13(rpm)的教程详解

    2024-01-19 04:52:14
  • Python利用Django如何写restful api接口详解

    2022-11-16 13:26:32
  • Python中JsonPath提取器和正则提取器

    2022-08-27 14:12:20
  • 详解Python判定IP地址合法性的三种方法

    2021-12-02 14:35:10
  • Python绘制地理图表可视化神器pyecharts

    2021-01-22 18:08:58
  • Mysql InnoDB多版本并发控制MVCC详解

    2024-01-23 16:46:25
  • mybatis如何实现的数据库排序

    2024-01-24 16:35:32
  • 在前女友婚礼上用python把婚礼现场的WIFI名称改成了

    2023-05-26 15:15:49
  • 在django模板中实现超链接配置

    2023-03-03 12:22:44
  • Python unittest生成测试报告过程解析

    2023-02-18 13:13:17
  • Python实现随机创建电话号码的方法示例

    2021-08-31 06:38:03
  • asp之家 网络编程 m.aspxhome.com