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);
signaturePad.clear(); // otherwise isEmpty() might return incorrect value
}
window.addEventListener("resize", resizeCanvas);
resizeCanvas();
# index.html
<script type="text/javascript" src="js/lib/signature_pad.js"></script>
# signature.html
<span id="selfSign"></span>
<button class="button button-fill sign" data-action="sign">签名</button>
# signatureCtr.js
let signButton = document.querySelector("[data-action=sign]");
let dataURL = "";
signButton.addEventListener("click", function (event) {
SdicInterview.popup(
‘<div class="popup sign-popup">‘ +
‘<a class="color-indigo close-popup" data-popup=".sign-popup" style="font-size:25px;position:absolute;top:4px;right:10px;cursor:pointer;z-index:1"> <i class="fa fa-times"></i></a>‘ +
‘<div id="signature-pad">‘ +
"<h1>专 家 签 名</h1>" +
‘<canvas class="form-footer-signature"></canvas>‘ +
‘<button class="button clear" data-action="clear">清除签名</button>‘ +
‘<button class="button save close-popup" data-popup=".sign-popup" data-action="save-jpg">确定</button>‘ +
"</div>"
);
var wrapper = document.getElementById("signature-pad");
var clearButton = wrapper.querySelector("[data-action=clear]");
var canvas = wrapper.querySelector("canvas");
var saveJPGButton = wrapper.querySelector("[data-action=save-jpg]");
var signaturePad = new SignaturePad(canvas, {
backgroundColor: "#fff",
});
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);
signaturePad.clear();
}
window.onresize = resizeCanvas;
resizeCanvas();
clearButton.addEventListener("click", function (event) {
signaturePad.clear();
});
saveJPGButton.addEventListener("click", function (event) {
if (!signaturePad.isEmpty()) {
dataURL = signaturePad.toDataURL("image/jpeg");
document.getElementById("selfSign").innerHTML = ‘<img class="sign-img-sum" id="selfSign" src="‘ + dataURL + ‘" />‘;
}
});
});
原文:https://www.cnblogs.com/shellon/p/14858464.html