Vue 使用Canvas画布手写电子版签名 保存 上传服务端

电子版签名效果

在这里插入图片描述

定义画布

    <canvas width="500"height="250"ref="cn"@mousedown="cnMouseDown"@mousemove="cnMouseMove"@mouseup="cnMouseUp"style="width:500px;height: 250px;background-color:snow;padding: 10px"></canvas>

canvas 的width height两个属性表示画布的大小,style的width height为实际的内容大小

是否可绘制

data() {return {pen:false //是否可以绘画};},

获取鼠标按下事件

 cnMouseDown(e){this.pen=true //鼠标按下可绘画const canvas= this.$refs.cn //获取对象const p =canvas.getContext('2d') //绘画2D图 画笔//this.p.fillStyle = '#d3d3d3'; 画布的颜色 不设置保存时为透明//this.p.fillRect(0, 0, this.canvas.width, this.canvas.height) //填充整个画布let x =e.pageX-canvas.offsetLeft //鼠标在画布的Xlet y =e.pageY-canvas.offsetTop  //鼠标在画布的Yp.moveTo(x,y)//移动画笔到 鼠标位置 断开线段p.lineTo(x,y) //画线p.stroke() //绘制轮廓 (线)this.p=p //全局挂载 其他事件需要使用到 画笔this.canvas=canvas //全局挂载 其他事件需要使用到 画布},

鼠标移动事件

cnMouseMove(e){
if(this.pen)
{let x=e.pageX-this.canvas.offsetLeft //移动的距离Xlet y =e.pageY-this.canvas.offsetTop //移动的距离Ylet w =this.canvas.width //画布高度let h =this.canvas.height //画布宽度if(x+10>w||x<10||y+10>h||y<10){this.pen=falsereturn//鼠标移出画布 停止绘制}this.p.lineTo(x,y) //鼠标移动持续绘制this.p.stroke() //绘制轮廓 (线)
}

鼠标松开事件

 cnMouseUp(){this.pen=false//鼠标双开 停止绘画},

保存签名

 save(){const url =this.canvas.toDataURL() //转换成链接const a =document.createElement('a') //创建A标签a.download='手写签名' //文件名字a.href=url //赋值a.click() //点击事件 打开下载对话框}

在这里插入图片描述

清空画布

 clear(){this.p.clearRect(0,0,this.canvas.width,this.canvas.height)},

上传服务端

接口封装

import request from '@/utils/request'
export function  fileUp(data){return request({method:'POST',url:'/fileUpload',data})
}

上传

up(){this.canvas.toBlob(b=>{ //转成二进制 成功的回调const formData = new FormData();//表单formData.append('file', b, 'filename.png'); //file为上传时的参数名fileUp(formData).then(r=>{console.log(r) //上传成功})})
},

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

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

相关文章

算法学习003-银行存钱 中小学算法思维学习 信奥算法解析 c++实现

目录 C银行存钱 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、推荐资料 C银行存钱 一、题目要求 1、编程实现 小明的父亲准备为小明的4年大学生活一次性在银行储蓄一笔钱&#xff0c;使用整存零取…

某赛通电子文档安全管理系统 多处 SQL注入漏洞复现

0x01 产品简介 某赛通电子文档安全管理系统(简称:CDG)是一款电子文档安全加密软件,该系统利用驱动层透明加密技术,通过对电子文档的加密保护,防止内部员工泄密和外部人员非法窃取企业核心重要数据资产,对电子文档进行全生命周期防护,系统具有透明加密、主动加密、智能…

文章解读与仿真程序复现思路——电网技术EI\CSCD\北大核心《适用于含新能源交流电网继电保护整定计算的故障计算方法研究》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

数据结构:初识集合框架

目录 1. 什么是集合框架2. 集合框架的重要性3. 背后所涉及的数据结构以及算法3.1 什么是数据结构3.2 容器背后对应的数据结构3.3 相关java知识3.4 什么是算法 1. 什么是集合框架 官方教程 Java 集合框架Java Collection Framework &#xff0c;又被称为容器和其实现类classes …

神经网络的激活函数

目录 神经网络 激活函数 sigmoid 激活函数 tanh 激活函数 backward方法 relu 激活函数 softmax 激活函数 神经网络 人工神经网络&#xff08; Artificial Neural Network&#xff0c; 简写为ANN&#xff09;也简称为神经网络&#xff08;NN&#xff09;&#xff0c…

LeetCode - LCR 008.长度最小的子数组

一. 题目链接 LeetCode - 209. 长度最小的子数组 二. 思路分析 由于此问题分析的对象是「⼀段连续的区间」&#xff0c;因此可以考虑「滑动窗口」的思想来解决这道题。 让滑动窗口满足&#xff1a;从 i 位置开始&#xff0c;窗口内所有元素的和小于target &#xff08;那么当…

Linux基础——Linux开发工具(gcc/g++,gdb)

前言&#xff1a;在上一篇我们简单介绍了yum&#xff0c;vim的一些常用的指令和模式&#xff0c;现在让我们来进一步了解其他的Linux环境基础开发工具gcc/g&#xff0c;gdb。 如果对前面yum和vim有什么不懂的建议回顾去回顾上期知识&#xff01;&#xff01;&#xff01; Linu…

【问题实操】银河麒麟高级服务器操作系统实例,CPU软锁报错触发宕机

1.服务器环境以及配置 处理器&#xff1a; Kunpeng 920 内存&#xff1a; 256G DDR4 整机类型/架构&#xff1a; TaiShan 200 (Model 2280) 内核版本 4.19.90-23.8.v2101.ky10.aarch64 2.问题现象描述 两台搭载麒麟v10 sp1的机器均在系统CPU软锁报错时&#xff0c;触…

sCrypt全新上线RUNES功能

sCrypt智能合约平台全新上线一键etch/mint RUNES功能&#xff01; 请访问 https://runes.scrypt.io/ 或点击阅读原文体验&#xff01; 关于sCrypt sCrypt是BSV区块链上的一种智能合约高级语言。比特币使用基于堆栈的Script语言来支持智能合约&#xff0c;但是用原生Script编…

JavaScript创建和填充数组的更多方法

空数组fill()方法创建并填充数组 ● 我们之前创建数组的方式都是手动去创建去一个数据&#xff0c;例如 console.log([1, 2, 3, 4, 5, 6, 7]);● 当然我们也可以使用Array对象来构造数组 console.log([1, 2, 3, 4, 5, 6, 7]); console.log(new Array(1, 2, 3, 4, 5, 6, 7));…

​「Python大数据」词频数据渲染词云图导出HTML

前言 本文主要介绍通过python实现数据聚类、脚本开发、办公自动化。词频数据渲染词云图导出HTML。 一、业务逻辑 读取voc数据采集的数据批处理,使用jieba进行分词,去除停用词词频数据渲染词云图将可视化结果保存到HTML文件中二、具体产出 三、执行脚本 python wordCloud.p…

2024最新智慧医疗智慧医院大数据展示,医院数据采集概况、医院指标分析、医院就诊趋势分析等。源代码免费下载。

系列文章目录 【复制就能用1】2分钟玩转轮播图,unslider的详细用法 【复制就能用2】css实现转动的大风车&#xff0c;效果很不错。 【复制就能用3】2分钟自己写小游戏&#xff1a;剪刀石头布小游戏、扫雷游戏、五子棋小游戏 【复制就能用4】2024最新智慧医疗智慧医院大数据…