Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Why not make yau.html eaiser to use? #1

Open
TakunMaii opened this issue Jul 5, 2024 · 0 comments
Open

Why not make yau.html eaiser to use? #1

TakunMaii opened this issue Jul 5, 2024 · 0 comments

Comments

@TakunMaii
Copy link

yau生成器很草,但是生成之后需要手动截图不是很方便。
希望添加一个功能实现一键渲染到图片并下载。下面是我的实现思路:

<script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/1.4.1/html2canvas.min.js"></script>
<script>
	// capture, transform to image and download-btn
	document.getElementById('download-btn').addEventListener('click', function () {
		html2canvas(document.getElementById('capture-area')).then(function (canvas) {
			let link = document.createElement('a');
			link.href = canvas.toDataURL('image/png');
			link.download = 'yau-wechat.png';
			link.click();
		});
	});
</script>

然后将对应的<div>设置为#capture-area,添加一个#download-btn就行。
完整代码如下,可以直接替换(仓库有太多无关内容不想fork就不pl了)。

<html>
<head><meta charset="utf-8">
	<link rel="stylesheet" type="text/css" href="wxapp.css">
</head>
<body class="phone-bg" style="background-color:#F1F1F1;"><table><tr><td>
	用「国<sub>(而不是国)</sub><sub>(而不是内)</sub>」是故意的,是为了表明是假的。另诚招前端工程师。</td><tr><tr><td><input value="输入文本" id="inputtext"/><button onclick="document.getElementById('text').innerHTML=document.getElementById('inputtext').value;">生成</button>
	<button id="download-btn">下载</button></td></tr>
	<tr><td>
<div class="wechat-content" id="capture-area">
<div class="wechat-dialog">
	<div class="wechat-dialog-face"><img src=""></div>
	<table><tr><td><div class="wechat-username">丘成桐(国內)</div></td></tr><tr><td><div class="wechat-dialog-text" id="text">米家子弟,必須尋原神樂處,拓萬古星穹!</div></td></tr></table></div>
</div></td></tr></table>
	<script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/1.4.1/html2canvas.min.js"></script>
	<script>
		// capture, transform to image and download-btn
		document.getElementById('download-btn').addEventListener('click', function () {
			html2canvas(document.getElementById('capture-area')).then(function (canvas) {
				let link = document.createElement('a');
				link.href = canvas.toDataURL('image/png');
				link.download = 'yau-wechat.png';
				link.click();
			});
		});
	</script>
</body>
</html>

望采纳。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant