123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- <!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 redo() {
- signature.redo()
- }
- function isEmpty() {
- const isEmpty = signature.isEmpty()
- emit({isEmpty});
- }
- function isTransparent(color) {
- // 判断颜色是否为 transparent
- if (color === 'transparent') {
- return true;
- }
-
- // 判断颜色是否为 rgba 的 a 为 0
- if (color.startsWith('rgba')) {
- const regex = /\d+(\.\d+)?/g;
- const matches = color.match(regex);
- if (matches !== null) {
- const alpha = parseFloat(matches[3]);
- if (alpha === 0) {
- return true;
- }
- }
- }
- return false;
- }
- function mask(param){
- clearTimeout(timer);
- let {destWidth=0, destHeight=0} = param
- let width = this.signature.canvas.get('width')
- let height = this.signature.canvas.get('height')
- let canvas = document.createElement('canvas')
- const ctx = canvas.getContext('2d');
- const pixelRatio = signature.canvas.get('pixelRatio')
- let width = signature.canvas.get('width')
- let height = signature.canvas.get('height')
- canvas.width = width * pixelRatio
- canvas.height = height * pixelRatio
-
- this.signature.pen.getMaskedImageData((imageData)=>{
- ctx.putImageData(imageData, 0, 0);
- if(destWidth&&destHeight){
- const _canvas = document.createElement('canvas')
- _canvas.width = destWidth
- _canvas.height = destHeight
- const _context = _canvas.getContext('2d')
- _context.drawImage(canvas, 0, 0, destWidth, destHeight)
- canvas.remove()
- canvas = _canvas
- }
- const path = canvas.toDataURL();
- canvas.remove()
- 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"});
- }
- })
- }
- function save(param) {
- // delete param.success;
- // delete param.fail;
- clearTimeout(timer);
- timer = setTimeout(() => {
- let {fileType = 'png', quality = 1, n, destWidth=0, destHeight=0} = param
- const type = `image/${fileType}`.replace(/jpg/, 'jpeg');
- const {backgroundColor, landscape, boundingBox} = options
- const flag = backgroundColor || landscape || boundingBox||destWidth&&destHeight
- let path = canvasEl.toDataURL(!flag && type, !flag && quality)
- if(flag) {
- let canvas = document.createElement('canvas')
- const pixelRatio = signature.canvas.get('pixelRatio')
- let width = signature.canvas.get('width')
- let height = 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 && !isTransparent(backgroundColor)) {
- context.fillStyle = backgroundColor
- context.fillRect(0, 0, width * pixelRatio, height * pixelRatio)
- }
- const drawImage = ()=>{
-
- }
- // param
- context.drawImage(signature.canvas.get('el'), ...param)
- if(destWidth&&destHeight){
- const _canvas = document.createElement('canvas')
- _canvas.width = destWidth
- _canvas.height = destHeight
- const _context = _canvas.getContext('2d')
- _context.drawImage(canvas, 0, 0, destWidth, destHeight)
- canvas.remove()
- canvas = _canvas
- }
- path = canvas.toDataURL(type, quality)
- canvas.remove()
- }
- if(boundingBox) {
- const res = 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>
|