vue3实现电子签名的方法

vue3实现电子签名且对电子签名可进行修改画笔粗细、画笔颜色、撤销、清屏、保存等功能。

实现效果:查看源码
在这里插入图片描述

第一种:通过canvas

<div class="signaturePad-Box w100 h100 flex-center"><el-space class="mb10" size="large"><div><el-text>画笔粗细:</el-text><el-input-number v-model="state.signOptions.lineWidth" :min="2" :max="10" :step="1" @change="initCanvas" /></div><div><el-text>画笔颜色:</el-text><el-color-picker v-model="state.signOptions.penColor" color-format="hex" @blur="initCanvas"> </el-color-picker></div></el-space><canvas ref="canvas" @mousedown="startDrawing" @mousemove="draw" @mouseup="stopDrawing"></canvas><el-space class="mt10"><el-button  @click="clear">清除</el-button><el-button type="success" @click="view">查看</el-button><el-button type="primary" @click="save">保存</el-button></el-space><el-dialog v-model="state.dialogVisible" title="查看图片"  ><el-image :src="state.dataURL" /><template #footer><div class="dialog-footer"><el-button type="primary" @click="state.dialogVisible = false"> 确定 </el-button></div></template></el-dialog>
</div>
<script setup>import {ref,reactive,onMounted} from "vue";const canvas = ref(null);const state=reactive({dialogVisible:false,dataURL:"",signOptions: {penColor: '#000000',lineWidth: 2,},})let isDrawing = false;let lastX = 0;let lastY = 0;/* 初始化画布 */const initCanvas = () => {const ctx = canvas.value.getContext('2d');ctx.strokeStyle = state.signOptions.penColor;ctx.lineWidth = state.signOptions.lineWidth;}/* 开始绘制 */const startDrawing = (event) => {isDrawing = true;[lastX, lastY] = [event.offsetX, event.offsetY];}/* 绘制线条 */const draw = (event) => {if (!isDrawing) return;const ctx = canvas.value.getContext('2d');const currentX = event.offsetX;const currentY = event.offsetY;ctx.beginPath();ctx.moveTo(lastX, lastY);ctx.lineTo(currentX, currentY);ctx.stroke();[lastX, lastY] = [currentX, currentY];}/* 停止绘制 */const stopDrawing = () => {isDrawing = false;}/* 清除画布 */const clear = () => {const ctx = canvas.value.getContext('2d');ctx.clearRect(0, 0, canvas.value.width, canvas.value.height);}/* 保存签名 */const save = () => {state.dataURL = canvas.value.toDataURL('image/png');console.log('签名地址为:', state.dataURL);}/* 查看签名 */const view=()=>{state.dataURL = canvas.value.toDataURL('image/png');state.dialogVisible=true;}onMounted(() => initCanvas());
</script>

第二种:通过vue-signature-pad

安装依赖:

// npm
npm i vue-signature-pad// yarn
yarn add vue-signature-pad//pnpm 
pnpm i vue-signature-pad

在main.js里引用依赖:
注:在官网上写的是全局引入非单文件引入

import VueSignaturePad from 'vue-signature-pad';createApp(App).use(router).use(VueSignaturePad).mount('#app')

实现代码:

<template><div><el-space class="mb10" size="large"><div><el-text>画笔粗细:</el-text><el-input-number v-model="state.size" :min="2" :max="10" :step="1" @change="onChange" /></div><div><el-text>画笔颜色:</el-text><el-color-picker v-model="state.color" color-format="hex" @change="onChange"> </el-color-picker></div></el-space><VueSignaturePad class="line" ref="signaturePad" :options="signOptions" width="400px" height="200px" /><el-space class="mt10"><el-button @click="unDoSign">撤销</el-button><el-button @click="clearSign">清屏</el-button><el-button type="primary" @click="saveUploadSign">保存</el-button></el-space></div>
</template>
<script setup>import {ref,watch} from "vue";const signaturePad = ref();const signOptions=ref({penColor: '#000000',minWidth: 1,maxWidth:1})const state=ref({color:"#000",size:1})// 画笔颜色粗细改变时const onChange=()=>{signOptions.value={penColor:state.value.color,maxWidth:state.value.size}}// 撤销电子签名const unDoSign = () => {signaturePad.value.undoSignature();};// 清空电子签名const clearSign = () => {signaturePad.value.clearSignature();};// 保存并上传电子签名const saveUploadSign = async () => {const {isEmpty,data} = signaturePad.value.saveSignature();if (isEmpty) return;console.log("picture url:",data);};</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/679541.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pinia持久化出现store和storage的数据不一致的问题

问题描述 突然发现menu的store异常&#xff0c;pinia中查看到store数据正确&#xff0c;但是localstorage中的数据始终没有同步&#xff0c;但user的store没问题&#xff0c;具体如下&#xff1a; menu的store&#xff1a; user的store&#xff1a; 问题原因 进入系统…

【文章转载】ChatGPT 提示词十级技巧: 从新手到专家

学习了微博网友宝玉xp老师《ChatGPT 提示词十级技巧: 从新手到专家》 个人学习要点&#xff1a; 1、关于提示中避免使用否定句&#xff0c;播主说&#xff1a;“没有人能准确解释为什么&#xff0c;但大语言模型在你告诉它去做某事时&#xff0c;表现似乎比你让它不做某事时更…

分享《2024年中国企业级SaaS行业研究报告》

&#xff08;文章作者与来源&#xff1a;艾瑞咨询&#xff09; 大浪淘沙&#xff0c;SaaS行业进入关键转折点&#xff0c;企业级SaaS的总体市场规模达到888亿元&#xff0c;同比增长13.0%。内外部因素叠加之下&#xff0c;预计三年未来企业级SaaS市场规模的增速将稳定在15%-20…

Terrain —— Nodes

目录 Convert HeightField —— 转化高度场 HeightField —— 为地形创建初始高度场或遮罩场 HeightField Blur —— 模糊高度场或遮罩场 HeightField Clip —— 限制高度场的值 HeightField Combine Layers —— 将多个volume或VDB合并为一个新的volume或VDB HeightFiel…

PGP加密技术:保护信息安全的利器

随着数字化时代的到来&#xff0c;个人和企业对信息安全的需求日益增长。PGP&#xff08;Pretty Good Privacy&#xff09;加密技术作为一项强大的加密工具&#xff0c;为保护敏感数据提供了一种有效的方法。本文将探讨PGP加密技术的基本原理、应用场景以及其在现代信息安全中的…

idea 项目 修改项目文件名 教程

文章目录 目录 文章目录 修改流程 小结 概要流程技术细节小结 概要 原项目名 修改流程 关掉当前项目的idea页面 修改之后的文件名 重新打开idea。选择项目打开项目页面 技术细节 出现下面这个问题&#xff0c;可以参考作者新的一编文章idea开发工具 项目使用Spring框架开发解…

贪心算法-----柠檬水找零

今日题目&#xff1a;leetcode860 题目链接&#xff1a;点击跳转题目 分析&#xff1a; 顾客只会给三种面值&#xff1a;5、10、20&#xff0c;先分类讨论 当收到5美元时&#xff1a;不用找零&#xff0c;面值5张数1当收到10美元时&#xff1a;找零5美元&#xff0c;面值5张数…

cufftPlanMany参数说明

背景 最近在看cufft这个库&#xff0c;传统的cufftPlan3d()这种plan接口逐渐被nvidia舍弃了&#xff0c;说是要用最新的cufftPlanMany&#xff0c;这个函数呢又依赖一个什么Advanced Data Layout(地址)&#xff0c;最终把这个api搞得乌烟瘴气很难理解&#xff0c;为了理解自己…

Linux学习之禁用防火墙

查看防火墙状态 systemctl status firewalld.service 第一行前面的圆圈是有颜色的就是开启状态 黑色的就是关闭状态 关闭防火墙 systemctl stop firewalld.service 输入密码认证 再次查看防火墙状态 systemctl status firewalld.service 第一行前面的圆圈变成黑色说明关闭…

上网行为监控软件有哪些(上网审计软件)【收藏】

上网行为监控软件&#xff08;也被称为上网审计软件&#xff09;正逐渐成为企业信息安全管理的必备工具。 没错&#xff01; 这些软件通过对员工的上网行为进行全面、细致的监控和审计&#xff0c;帮助企业提升工作效率、保护数据安全&#xff0c;并规范员工的网络使用行为。 …

射频无源器件之耦合器

一. 耦合器的作用 在射频电路中,射频耦合器将一路微波功率按比例分成几路,用于检测或监测信号,如功率测量和波检测,还可改变信号的幅度、相位等特性,以满足不同的通信需求。根据输入与耦合端的功率差,常被分为5dB、6dB、10dB等耦合器。射频耦合器的类型主要包括定向耦合…

N皇后问题-第12届蓝桥杯省赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第59讲。 N皇后问题&#x…