微信小程序手写签字版

在这里插入图片描述

wxml

请在下面的白框中签名 重置 提交 # js Page({ data: { signPath: [], cardNo: '', preX: '', preY: '', }, onLoad(options) { this.setData({ cardNo: options.cardNo }) wx.createSelectorQuery().select('#myCanvas').fields({ node: true, size: true }).exec(this.init.bind(this)) }, init(data) { console.log(data); const width = data[0].width; const height = data[0].height; const canvas = data[0].node; const ctx = canvas.getContext('2d'); const dpr = wx.getSystemInfoSync().pixelRatio

复制代码
canvas.width = width * dpr
canvas.height = height * dpr
ctx.scale(dpr, dpr)

this._dpr = dpr
this._ctx = ctx
this._canvas = canvas

},

touchStart(e) {

console.log(e)

const {

_ctx: ctx

} = this

const {

clientX: x,

clientY: y

} = e.touches[0]

ctx.beginPath()

// ctx.moveTo(x-e.target.offsetLeft, y-e.target.offsetTop)

ctx.moveTo(x - e.target.offsetLeft, y - e.target.offsetTop)

this.setData({

preX: x - e.target.offsetLeft,

preY: y - e.target.offsetTop,

})

},

touchMove(e) {

const {

_ctx: ctx

} = this

const {

clientX: x,

clientY: y

} = e.touches[0]

this.data.signPath.push([x, y])

this.setData({

signPath: this.data.signPath

})

let preX = this.data.preX

let preY = this.data.preY

let curX = x - e.target.offsetLeft

let curY = y - e.target.offsetTop

let deltaX = Math.abs(preX - curX)

let deltaY = Math.abs(preY - curY)

if (deltaX >= 3 || deltaY >= 3) {

// 前后两点中心点

let centerX = (preX + curX) / 2

let centerY = (preY + curY) / 2

复制代码
  //这里以前一点作为控制点,中心点作为终点,起始点为上一次的中点,很流畅啊!
  ctx.quadraticCurveTo(preX, preY, centerX, centerY);
  ctx.stroke();
  this.setData({
    preX: curX,
    preY: curY,
  })
}
// ctx.lineTo(x-e.target.offsetLeft, y-e.target.offsetTop)
// ctx.lineTo(x, y)
// ctx.stroke()

},

//重绘

reset() {

wx.showModal({

title: '提示',

content: '确定要重置吗?',

cancelText: '取消',

confirmText: '确定',

success: res => {

if (res.confirm) {

const {

_ctx: ctx,

_canvas: canvas

} = this

this.setData({

signPath: []

})

ctx.clearRect(0, 0, canvas.width, canvas.height)

}

}

})

},

//提交签名图片

sure() {

if (this.data.signPath.length <= 0) {

wx.showToast({

title: '签名不能为空',

icon: 'none'

})

return

}

wx.showModal({

title: '提示',

content: '确定提交吗?',

cancelText: '取消',

confirmText: '确定',

success: res => {

if (res.confirm) {

//导出图片

this.outImage()

}

}

})

},

sureSignature() {

if (this.data.signPath.length <= 0) {

wx.showToast({

title: '签名不能为空',

icon: 'none'

})

return

}

},

outImage() {

const {

_canvas: canvas,

_dpr: dpr

} = this

var image = canvas.toDataURL("image/png"); // 得到生成后的签名base64位 url 地址

console.log(image)

let pages = getCurrentPages(); //获取当前页面js里面的pages里的所有信息。

//prevPage 是获取上一个页面的js里面的pages的所有信息。 -2 是上一个页面,-3是上上个页面以此类推。

let prevPage = pages[pages.length - 2];

//给上个页面赋值

prevPage.setData({

qianimg: image

})

wx.navigateBack({

delta: 1,

})

}

})

wxss

.content {

width: 100vw;

height: 100vh;

}

.canvasBox {

margin-top: 10px;

background-color: #fff;

width: 100%;

border-radius: 10px;

display: flex;

flex-direction: column;

justify-content: space-around;

}

.title {

font-size: 28rpx;

padding: 0 24rpx;

}

.title::before {

content: '*';

color: red;

}

.tips {

width: 100%;

color: red;

padding: 20px;

box-sizing: border-box;

}

.sign-canvas-view {

box-sizing: border-box;

border: 2rpx dashed #ddd;

margin: 0 24rpx;

}

.submitBtn {

width: 100%;

display: flex;

justify-content: space-around;

align-items: center;

margin-top: 30px;

}

.clickbtn{

background-color: rgb(14, 103, 175);

}

.clickbtn_1{

background-color: rgb(5, 76, 134);

}

相关推荐
云起SAAS15 小时前
倒班日历助手抖音快手微信小程序看广告流量主开源
微信小程序·小程序·ai编程·看广告变现轻·倒班日历助手
sheji341617 小时前
【开题答辩全过程】以 基于微信小程序的失物认领系统为例,包含答辩的问题和答案
微信小程序·小程序
qq_256847888617 小时前
08cms房产多城市版最新v8.7含小程序及装修网的安装及配置方法整理出来希望能帮到大家
小程序·08cms房产系统源码·08cms装饰网门户系统·08cms 房产门户系统源码
风月歌18 小时前
python项目之摄影竞赛小程序
python·mysql·小程序·毕业设计·源码
云云只是个程序马喽18 小时前
2026年短剧系统开发搭建全流程教程(小程序+APP自营/红果模式/广告联盟/海外多语言)
小程序
计算机毕设指导618 小时前
基于微信小程序的网络安全知识科普平台系统【源码文末联系】
java·spring boot·安全·web安全·微信小程序·小程序·tomcat
天***88962 天前
小程序婚纱店摄影楼预约婚庆礼展示,小程序开发定制,会员下单档期系统
小程序
说私域2 天前
开源AI智能名片链动2+1模式商城小程序下短视频电商变现与广告变现的对比研究
人工智能·小程序
天***88962 天前
美业医疗美容院小程序,预约会员管理养生馆诊所肌护肤理疗系统,附源码交付
小程序
2501_915909062 天前
手机崩溃日志导出的工程化体系,从系统级诊断到应用行为分析的多工具协同方法
android·ios·智能手机·小程序·uni-app·iphone·webview