发布于 

Canvas实现数字签名

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>canvas - 数字签名</title>
<style>
/* 给画布增加一个阴影和圆角的样式 */
canvas {
box-shadow: 0px 0px 5px #ccc;
border-radius: 8px;
}
div {
width: 450px;
box-shadow: 0px 0px 5px #ccc;
border-radius: 8px;
text-align: center;
}
</style>
</head>
<body>
<canvas id="canvas" width="450" height="300">
当前浏览器不支持canvas元素,请升级或更换浏览器!
</canvas>
<div id="clear">清空画布</div>
<script>
// 获取 canvas 元素
var canvas = document.getElementById('canvas');
var clear = document.getElementById('clear');
const ctx = canvas.getContext("2d");
canvas.addEventListener('mouseenter', () => {
canvas.addEventListener('mousedown', (e) => {
ctx.beginPath()
ctx.moveTo(e.offsetX, e.offsetY)
canvas.addEventListener('mousemove', draw)
})
canvas.addEventListener('mouseup', () => {
canvas.removeEventListener('mousemove', draw)
})
})
function draw(e) {
ctx.lineTo(e.offsetX, e.offsetY)
ctx.stroke()
}
clear.addEventListener('click', () => {
ctx.clearRect(0, 0, canvas.width, canvas.height);
})

</script>
</body>
</html>