119 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
		
		
			
		
	
	
			119 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| 
								 | 
							
								<!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>
							 |