微信小程序canvas写字板效果及实例
作者:透笔度 时间:2024-04-19 09:44:03
微信小程序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