You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
152 lines
4.0 KiB
152 lines
4.0 KiB
5 months ago
|
<!DOCTYPE html>
|
||
|
<html lang="zh">
|
||
|
<head>
|
||
|
<meta charset="UTF-8" />
|
||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||
|
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||
|
<title></title>
|
||
|
<style type="text/css">
|
||
|
html,
|
||
|
body,
|
||
|
canvas {
|
||
|
padding: 0;
|
||
|
margin: 0;
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
overflow-y: hidden;
|
||
|
background-color: transparent;
|
||
|
}
|
||
|
</style>
|
||
|
</head>
|
||
|
|
||
|
<body>
|
||
|
<canvas id="lime-signature"></canvas>
|
||
|
<script type="text/javascript" src="./uni.webview.1.5.3.js"></script>
|
||
|
<script type="text/javascript" src="./signature.js"></script>
|
||
|
<script>
|
||
|
var signature = null;
|
||
|
var timer = null;
|
||
|
var isStart = false;
|
||
|
var options = null
|
||
|
console.log = function(...args) {
|
||
|
postMessage(args);
|
||
|
};
|
||
|
// function stringify(key, value) {
|
||
|
// if (typeof value === 'object' && value !== null) {
|
||
|
// if (cache.indexOf(value) !== -1) {
|
||
|
// return;
|
||
|
// }
|
||
|
// cache.push(value);
|
||
|
// }
|
||
|
// return value;
|
||
|
// };
|
||
|
function emit(event, data) {
|
||
|
postMessage({
|
||
|
event,
|
||
|
data: typeof data !== "object" && data !== null ? data : JSON.stringify(data),
|
||
|
});
|
||
|
// cache = [];
|
||
|
}
|
||
|
|
||
|
function postMessage(data) {
|
||
|
uni.postMessage({
|
||
|
data
|
||
|
});
|
||
|
}
|
||
|
|
||
|
function update(v = {}) {
|
||
|
if (signature) {
|
||
|
options = v
|
||
|
signature.pen.setOption(v);
|
||
|
} else {
|
||
|
signature = new Signature.Signature({el: "lime-signature"});
|
||
|
canvasEl = signature.canvas.get("el");
|
||
|
options = v
|
||
|
signature.pen.setOption(v)
|
||
|
const width = signature.canvas.get("width");
|
||
|
const height = signature.canvas.get("height");
|
||
|
|
||
|
emit({changeSize: {width,height}})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function clear() {
|
||
|
signature.clear()
|
||
|
}
|
||
|
|
||
|
function undo() {
|
||
|
signature.undo()
|
||
|
}
|
||
|
function isEmpty() {
|
||
|
const isEmpty = signature.isEmpty()
|
||
|
emit({isEmpty});
|
||
|
}
|
||
|
function save(param) {
|
||
|
// delete args.success;
|
||
|
// delete args.fail;
|
||
|
clearTimeout(timer);
|
||
|
timer = setTimeout(() => {
|
||
|
const {fileType = 'png', quality = 1, n} = param
|
||
|
const type = `image/${fileType}`.replace(/jpg/, 'jpeg');
|
||
|
const {backgroundColor, landscape, boundingBox} = options
|
||
|
const flag = backgroundColor || landscape || boundingBox
|
||
|
let path = canvasEl.toDataURL(!flag && type, !flag && quality)
|
||
|
if(flag) {
|
||
|
const canvas = document.createElement('canvas')
|
||
|
const pixelRatio = this.signature.canvas.get('pixelRatio')
|
||
|
let width = this.signature.canvas.get('width')
|
||
|
let height = this.signature.canvas.get('height')
|
||
|
let x = 0
|
||
|
let y = 0
|
||
|
|
||
|
const next = () => {
|
||
|
const size = [width, height]
|
||
|
if(landscape) {size.reverse()}
|
||
|
canvas.width = size[0] * pixelRatio
|
||
|
canvas.height = size[1] * pixelRatio
|
||
|
const param = [x, y, width, height, 0 , 0, width, height].map(item => item * pixelRatio)
|
||
|
const context = canvas.getContext('2d')
|
||
|
// context.scale(pixelRatio, pixelRatio)
|
||
|
if (landscape) {
|
||
|
context.translate(0, width * pixelRatio)
|
||
|
context.rotate(-Math.PI / 2)
|
||
|
}
|
||
|
if (backgroundColor) {
|
||
|
context.fillStyle = backgroundColor
|
||
|
context.fillRect(0, 0, width * pixelRatio, height * pixelRatio)
|
||
|
}
|
||
|
// param
|
||
|
context.drawImage(this.signature.canvas.get('el'), ...param)
|
||
|
path = canvas.toDataURL(type, quality)
|
||
|
canvas.remove()
|
||
|
}
|
||
|
if(boundingBox) {
|
||
|
const res = this.signature.getContentBoundingBox()
|
||
|
width = res.width
|
||
|
height = res.height
|
||
|
x = res.startX
|
||
|
y = res.startY
|
||
|
next()
|
||
|
} else {
|
||
|
next()
|
||
|
}
|
||
|
}
|
||
|
if (typeof path == "string") {
|
||
|
const index = Math.ceil(path.length / 8);
|
||
|
for (var i = 0; i < 8; i++) {
|
||
|
if (i == 7) {
|
||
|
emit({"success": path.substr(i * index, index)});
|
||
|
} else {
|
||
|
emit({"file": path.substr(i * index, index)});
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
console.error("canvas no data");
|
||
|
emit({"fail": "canvas no data"});
|
||
|
}
|
||
|
}, 30);
|
||
|
}
|
||
|
</script>
|
||
|
</body>
|
||
|
</html>
|