-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
95 lines (84 loc) · 2.79 KB
/
index.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<html>
<head>
<meta charset="utf-8"/>
<script src="wasm_exec.js"></script>
</head>
<body style="background-color: #646464">
<div id="bcanv" style="background-color: #000000;">
<canvas id="fif">
</canvas>
</div>
<input type="file" id="file-selector" accept=".fif">
<span><button id="buttonX" onclick="renderNow()" disabled>Render</button> <span id="rtime">NOTHING RENDERED</span> Delay: <input type="range" min="0" max="100" value="0" id="myRange"> (<span id="myRangeDisplay">0</span>)</span>
<script>
var slider = document.getElementById("myRange");
var output = document.getElementById("myRangeDisplay");
slider.oninput = function() {
output.innerHTML = this.value;
}
function disableSlider(state) {
slider.disabled = state
}
disableSlider(false)
let dropArea = document.getElementById("bcanv");
dropArea.addEventListener('dragover', (event) => {
event.stopPropagation();
event.preventDefault();
// Style the drag-and-drop as a "copy file" operation.
event.dataTransfer.dropEffect = 'copy';
});
dropArea.addEventListener('drop', (event) => {
event.stopPropagation();
event.preventDefault();
const file = event.dataTransfer.files[0];
readFile(file)
});
dropArea = document.getElementById("fif");
dropArea.addEventListener('dragover', (event) => {
event.stopPropagation();
event.preventDefault();
// Style the drag-and-drop as a "copy file" operation.
event.dataTransfer.dropEffect = 'copy';
});
dropArea.addEventListener('drop', (event) => {
event.stopPropagation();
event.preventDefault();
const file = event.dataTransfer.files[0];
readFile(file)
});
const go = new Go();
WebAssembly.instantiateStreaming(fetch("main.wasm"), go.importObject).then((result) => {
go.run(result.instance);
});
let dataE;
function changeData(a) {
document.getElementById("buttonX").disabled = !a
}
document.addEventListener("load", () => {
changeData(false)
})
document.getElementById('file-selector').addEventListener('change', event => {
const file = event.target.files[0];
readFile(file)
})
function readFile(file) {
const reader = new FileReader();
reader.addEventListener('load', event => {
let a = new Uint8Array(reader.result)
dataE = a;
changeData(true)
});
reader.readAsArrayBuffer(file)
}
function renderNow() {
disableSlider(true)
renderFIF("fif", dataE, dataE.length, "rtime", parseInt(slider.value))
changeData(false)
}
function finished() {
disableSlider(false)
changeData(true)
}
</script>
</body>
</html>