-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrenderer.html
57 lines (50 loc) · 1.75 KB
/
renderer.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="assets/skins/default.js" type="text/javascript"></script>
<script src="assets/wavedrom.min.js" type="text/javascript"></script>
<script>
async function render(code, config, width, height) {
var canvas = document.getElementsByClassName("wave")[0];
if (width) {
canvas.style.width = width;
}
if (height) {
canvas.style.height = height;
}
WaveDrom.RenderWaveForm(
0,
eval('(' + code + ')'),
'display'
);
WaveDrom.ProcessAll();
var count = 0;
while (canvas.childNodes.length == 0 || canvas.childNodes[0].childNodes.length == 0) {
count++;
if (count >= 2400) {
console.error("Failed to render chart");
return '<svg version="1.1" width="600" height="200" xmlns="http://www.w3.org/2000/svg"><text x="10" y="100" font-size="60" text-anchor="left">Rendering timed out, please check your input.</text></svg>';
}
}
var svg = document.getElementsByTagName("svg")[0];
var bbox = svg.getBBox();
// bbox.width = bbox.width * 1.5;
// bbox.height = bbox.height * 1.5;
if (width) {
bbox.width = width;
}
if (height) {
bbox.height = height;
}
svg.setAttribute("width", bbox.x + bbox.width + "px");
svg.setAttribute("height",bbox.y + bbox.height + "px");
// svg.setAttribute("viewBox","0 0 " + (bbox.x + bbox.width) + " " + (bbox.y + bbox.height) + "");
return new XMLSerializer().serializeToString(canvas);
}
</script>
</head>
<body>
<div class="wave" id="display0"></div>
</body>
</html>