| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | 
							- <!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-painter"></canvas>
 
- 	<script type="text/javascript" src="./uni.webview.1.5.3.js"></script>
 
- 	<script type="text/javascript" src="./painter.js"></script>
 
- 	<script> 
 
- 		var cache = [];
 
- 		var painter = null;
 
- 		var canvas = null;
 
- 		var context = null;
 
- 		var timer = null;
 
- 		var pixelRatio = 1;
 
- 		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 init(dpr) {
 
- 			canvas = document.querySelector('#lime-painter');
 
- 			context = canvas.getContext('2d');
 
- 			pixelRatio = dpr || window.devicePixelRatio;
 
- 			painter = new Painter({
 
- 				id: 'lime-painter',
 
- 				context,
 
- 				canvas,
 
- 				pixelRatio,
 
- 				width: canvas.offsetWidth,
 
- 				height: canvas.offsetHeight,
 
- 				listen: {
 
- 					onProgress(v) {
 
- 						emit('progressChange', v);
 
- 					},
 
- 					onEffectFail(err) {
 
- 						//console.error(err)
 
- 						emit('fail', err);
 
- 					}
 
- 				}
 
- 			});
 
- 			emit('inited', true);
 
- 		};
 
- 		function save(args) {
 
- 			delete args.success;
 
- 			delete args.fail;
 
- 			clearTimeout(timer);
 
- 			timer = setTimeout(() => {
 
- 				const path = painter.save(args);
 
- 				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.log('canvas no data')
 
- 					emit('fail', 'canvas no data');
 
- 				};
 
- 			}, 30);
 
- 		};
 
- 		async function source(args) {
 
- 			let size = await painter.source(args);
 
- 			emit('layoutChange', size);
 
- 			if(!canvas.height) {
 
- 				console.log('canvas no size')
 
- 				emit('fail', 'canvas no size');
 
- 			}
 
- 			painter.render().catch(err => {
 
- 				// console.error(err)
 
- 				emit('fail', err);
 
- 			});
 
- 		};
 
- 	</script>
 
- </body>
 
- </html>
 
 
  |