-
Notifications
You must be signed in to change notification settings - Fork 50
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
6 changed files
with
223 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,162 @@ | ||
<!doctype html> | ||
<html lang="en-us"> | ||
<head> | ||
<meta charset="utf-8"> | ||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> | ||
<title>OpenJazz</title> | ||
<style> | ||
body { | ||
font-family: arial; | ||
margin: 0; | ||
padding: none; | ||
background-color: rgb(23, 23, 123); | ||
} | ||
|
||
.emscripten { padding-right: 0; margin-left: auto; margin-right: auto; display: block; } | ||
div.emscripten { text-align: center; } | ||
/* the canvas *must not* have any border or padding, or mouse coords will be wrong */ | ||
canvas.emscripten { border: 0px none; background-color: black; } | ||
|
||
.spinner { | ||
height: 30px; | ||
width: 30px; | ||
margin: 0; | ||
margin-top: 20px; | ||
margin-left: 20px; | ||
display: inline-block; | ||
vertical-align: top; | ||
|
||
-webkit-animation: rotation .8s linear infinite; | ||
-moz-animation: rotation .8s linear infinite; | ||
-o-animation: rotation .8s linear infinite; | ||
animation: rotation 0.8s linear infinite; | ||
|
||
border-left: 5px solid rgb(235, 235, 235); | ||
border-right: 5px solid rgb(235, 235, 235); | ||
border-bottom: 5px solid rgb(235, 235, 235); | ||
border-top: 5px solid rgb(120, 120, 120); | ||
|
||
border-radius: 100%; | ||
background-color: rgb(189, 215, 46); | ||
} | ||
|
||
@-webkit-keyframes rotation { | ||
from {-webkit-transform: rotate(0deg);} | ||
to {-webkit-transform: rotate(360deg);} | ||
} | ||
@-moz-keyframes rotation { | ||
from {-moz-transform: rotate(0deg);} | ||
to {-moz-transform: rotate(360deg);} | ||
} | ||
@-o-keyframes rotation { | ||
from {-o-transform: rotate(0deg);} | ||
to {-o-transform: rotate(360deg);} | ||
} | ||
@keyframes rotation { | ||
from {transform: rotate(0deg);} | ||
to {transform: rotate(360deg);} | ||
} | ||
|
||
#status { | ||
display: inline-block; | ||
vertical-align: top; | ||
margin-top: 30px; | ||
margin-left: 20px; | ||
font-weight: bold; | ||
color: rgb(120, 120, 120); | ||
} | ||
|
||
#progress { | ||
height: 20px; | ||
width: 300px; | ||
} | ||
|
||
#infobox { | ||
padding: 20px; | ||
background-color: rgb(222, 222, 222); | ||
} | ||
</style> | ||
</head> | ||
<body> | ||
<div class="spinner" id='spinner'></div> | ||
<div class="emscripten" id="status">Downloading...</div> | ||
|
||
<div class="emscripten"> | ||
<progress value="0" max="100" id="progress" hidden=1></progress> | ||
</div> | ||
|
||
<canvas class="emscripten" id="canvas" oncontextmenu="event.preventDefault()" tabindex=-1></canvas> | ||
|
||
<br> <br> | ||
|
||
<div id="infobox"> | ||
This is <a href="http://alister.eu/jazz/oj/">OpenJazz</a> powered by <a href="http://emscripten.org">emscripten</a>. | ||
</div> | ||
|
||
<script type='text/javascript'> | ||
var statusElement = document.getElementById('status'); | ||
var progressElement = document.getElementById('progress'); | ||
var spinnerElement = document.getElementById('spinner'); | ||
|
||
var Module = { | ||
print: (function() { | ||
return (...args) => { | ||
var text = args.join(' '); | ||
console.log(text); | ||
}; | ||
})(), | ||
canvas: (() => { | ||
var canvas = document.getElementById('canvas'); | ||
|
||
// As a default initial behavior, pop up an alert when webgl context is lost. To make your | ||
// application robust, you may want to override this behavior before shipping! | ||
// See http://www.khronos.org/registry/webgl/specs/latest/1.0/#5.15.2 | ||
canvas.addEventListener("webglcontextlost", (e) => { alert('WebGL context lost. You will need to reload the page.'); e.preventDefault(); }, false); | ||
|
||
return canvas; | ||
})(), | ||
setStatus: (text) => { | ||
if (!Module.setStatus.last) Module.setStatus.last = { time: Date.now(), text: '' }; | ||
if (text === Module.setStatus.last.text) return; | ||
var m = text.match(/([^(]+)\((\d+(\.\d+)?)\/(\d+)\)/); | ||
var now = Date.now(); | ||
if (m && now - Module.setStatus.last.time < 30) return; // if this is a progress update, skip it if too soon | ||
Module.setStatus.last.time = now; | ||
Module.setStatus.last.text = text; | ||
if (m) { | ||
text = m[1]; | ||
progressElement.value = parseInt(m[2])*100; | ||
progressElement.max = parseInt(m[4])*100; | ||
progressElement.hidden = false; | ||
spinnerElement.hidden = false; | ||
} else { | ||
progressElement.value = null; | ||
progressElement.max = null; | ||
progressElement.hidden = true; | ||
if (!text) spinnerElement.style.display = 'none'; | ||
} | ||
statusElement.innerHTML = text; | ||
}, | ||
totalDependencies: 0, | ||
monitorRunDependencies: (left) => { | ||
this.totalDependencies = Math.max(this.totalDependencies, left); | ||
Module.setStatus(left ? 'Preparing... (' + (this.totalDependencies-left) + '/' + this.totalDependencies + ')' : 'All downloads complete.'); | ||
}, | ||
onExit: (status) => { | ||
Module.setStatus('OpenJazz has closed. Refresh the browser window to play again.'); | ||
} | ||
}; | ||
Module.setStatus('Downloading...'); | ||
window.onerror = (event) => { | ||
// TODO: do not warn on ok events like simulating an infinite loop or exitStatus | ||
Module.setStatus('Exception thrown, see JavaScript console'); | ||
spinnerElement.style.display = 'none'; | ||
Module.setStatus = (text) => { | ||
if (text) console.error('[post-exception status] ' + text); | ||
}; | ||
}; | ||
</script> | ||
<script async type="text/javascript" src=data.js></script> | ||
{{{ SCRIPT }}} | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters