console
var canvas = document.getElementById('signature-pad');
function resizeCanvas() {
var ratio = Math.max(window.devicePixelRatio || 1, 1);
canvas.width = canvas.offsetWidth * ratio;
canvas.height = canvas.offsetHeight * ratio;
canvas.getContext("2d").scale(ratio, ratio);
}
window.onresize = resizeCanvas;
resizeCanvas();
var signaturePad = new SignaturePad(canvas, {
backgroundColor: 'rgb(255, 255, 255)'
});
document.getElementById('save-png').addEventListener('click', function() {
if (signaturePad.isEmpty()) {
return alert("Please provide a signature first.");
}
var data = signaturePad.toDataURL('image/png');
console.log(data);
document.getElementById("portImg").src=data;
});
document.getElementById('save-jpeg').addEventListener('click', function() {
if (signaturePad.isEmpty()) {
return alert("Please provide a signature first.");
}
var data = signaturePad.toDataURL('image/jpeg');
console.log(data);
document.getElementById("portImg").src=data;
});
document.getElementById('save-svg').addEventListener('click', function() {
if (signaturePad.isEmpty()) {
return alert("Please provide a signature first.");
}
var data = signaturePad.toDataURL('image/svg+xml');
console.log(data);
console.log(atob(data.split(',')[1]));
document.getElementById("portImg").src=data;
});
document.getElementById('clear').addEventListener('click', function() {
signaturePad.clear();
document.getElementById("portImg").src="";
});
document.getElementById('undo').addEventListener('click', function() {
var data = signaturePad.toData();
if (data) {
data.pop();
signaturePad.fromData(data);
}
});
<div class="wrapper">
<canvas id="signature-pad" class="signature-pad" >
</canvas>
</div>
<button id="save-png">存为PNG</button>
<button id="save-jpeg">存为JPEG</button>
<button id="save-svg">存为SVG</button>
<button id="undo">撤销</button>
<button id="clear">重写</button>
<img id= "portImg" width="800" heigth="500" src />
.wrapper {
position: relative;
width: 800px;
height: 500px;
-moz-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
}
.signature-pad {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-color: white;
border:1px dashed green;
}