vue3+js使用canvas实现签字、重签
<el-dialog title="签字板" v-model="visible" width="1000px" append-to-body> <canvas @mousemove="canvasMove" @mouseup="canvasUp" ref="canvas" width="1000" height="500" @mousedown="mousedown" @mouseleave="canvasLeave"></canvas> <template #footer> <div class="dialog-footer"> <el-button type="primary" @click="handleSave">保 存</el-button> <el-button @click="handleClear">重 置</el-button> </div> </template> </el-dialog>
<script setup> const visible = ref(false) const isDown = ref(false) // 是否可以绘制 const canvas = ref(null) // canvas 元素 const ctx = ref(null) // ctx承接上下文 // 鼠标按下 function mousedown (e) { let { offsetX, offsetY } = e // 拿到x,y坐标 ctx.value = canvas.value.getContext('2d') // 上下文 // console.log(ctx.value) ctx.value.strokeStyle = '#000'; // 设置线条颜色 ctx.value.fillStyle = '#fff' ctx.value.lineWidth = 5; // 线条宽度 ctx.value.beginPath(); // 开始绘制路径 ctx.value.moveTo(offsetX, offsetY); // 将鼠标移动到某一个坐标,准备绘制 isDown.value = true // 打开绘制开关 } // 鼠标移动 function canvasMove (e) { let { offsetX, offsetY } = e // 拿到移动时的坐标信息 isDown.value && startDraw(offsetX, offsetY) // 绘制开关为true 开始绘制 } // 鼠标松开 function canvasUp() { console.log('松开'); isDown.value = false } // 鼠标超出canvas绘制区域 function canvasLeave() { console.log('超出canvas'); isDown.value = false } // 绘制方法 function startDraw(x, y) { ctx.value.lineTo(x, y); // 绘制线条 ctx.value.stroke(); // } function handleClear() { ctx.value.clearRect(0, 0, 1000, 500) } function handleSave() { const base64 = canvas.value.toDataURL() console.log(base64) // 输出base64的图片地址 } </script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理