mirror of
https://github.com/libretro/RetroArch
synced 2025-03-28 19:20:35 +00:00
simplify template
This commit is contained in:
parent
cef5c828e8
commit
ce7ba91411
@ -1,50 +1,43 @@
|
|||||||
<!doctype html>
|
<!doctype html>
|
||||||
<html lang="en-us">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
|
||||||
<title>RetroArch - Template</title>
|
|
||||||
<style>
|
|
||||||
.emscripten { padding-right: 0; margin-left: auto; margin-right: auto; display: block; }
|
|
||||||
textarea.emscripten { font-family: monospace; width: 80%; }
|
|
||||||
div.emscripten, h1 { text-align: center; }
|
|
||||||
div.emscripten_border { border: 1px solid black; }
|
|
||||||
#fakerom { font-size: 20pt; margin: 5pt;}
|
|
||||||
/* the canvas *must not* have any border or padding, or mouse coords will be wrong */
|
|
||||||
canvas.emscripten { border: 0px none; }
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<h1>Template</h1>
|
|
||||||
<hr/>
|
|
||||||
<div class="emscripten" id="status">Downloading...</div>
|
|
||||||
<div class="emscripten">
|
|
||||||
<progress value="0" max="100" id="progress" hidden=1></progress>
|
|
||||||
</div>
|
|
||||||
<div class="emscripten_border" id="canvas_div" style="display: none">
|
|
||||||
<canvas class="emscripten" id="canvas" tabindex="1" oncontextmenu="event.preventDefault()"></canvas>
|
|
||||||
</div>
|
|
||||||
<div class="emscripten emscripten_border" id="openrom">
|
|
||||||
<button id="fakerom" onclick="document.getElementById('rom').click()">Select content</button>
|
|
||||||
<input style="display: none" type="file" id="rom" name="upload" onclick="document.getElementById('fakerom').click();" onchange="runEmulator(event.target.files);" multiple />
|
|
||||||
</div>
|
|
||||||
<hr/>
|
|
||||||
<div class="emscripten">
|
|
||||||
|
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>RetroArch Web Player</title>
|
||||||
|
<script type="text/javascript" src="browserfs.js"></script>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.emscripten { padding-right: 0; margin-left: auto; margin-right: auto; display: block; }
|
||||||
|
textarea.emscripten { border: 0px; font-family: 'Share Tech Mono'; font-size: 12px; width: 100%; overflow:hide; resize:none; color:black; }
|
||||||
|
div.emscripten, h1 { text-align: left; }
|
||||||
|
div.canvas_border { background-color:gray; width:800px; height:600px; margin-left: auto; margin-right: auto; }
|
||||||
|
canvas.emscripten { border: 0px none; }
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<hr/>
|
||||||
|
<div class="emscripten_border" id="canvas_div" style="display: none">
|
||||||
|
<canvas class="emscripten" id="canvas" tabindex="1" oncontextmenu="event.preventDefault()"></canvas>
|
||||||
|
</div>
|
||||||
|
<div class="emscripten emscripten_border" id="openrom">
|
||||||
|
<button id="btnLoad" onclick="document.getElementById('rom').click()">Select content</button>
|
||||||
|
<input style="display: none" type="file" id="rom" name="upload" onclick="document.getElementById('btnLoad').click();" onchange="runEmulator(event.target.files);" multiple />
|
||||||
|
<button id="btnStart" onclick="startRetroArch()">Select content</button>
|
||||||
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<div class="emscripten">
|
||||||
<input type="checkbox" id="resize"><label for="resize">Resize canvas</label>
|
<input type="checkbox" id="resize"><label for="resize">Resize canvas</label>
|
||||||
<input type="checkbox" id="pointerLock" checked><label for="pointerLock">Lock/hide mouse pointer</label>
|
<input type="checkbox" id="pointerLock" checked><label for="pointerLock">Lock/hide mouse pointer</label>
|
||||||
|
<input type="button" value="Fullscreen" onclick="Module.requestFullScreen(document.getElementById('pointerLock').checked, document.getElementById('resize').checked)"><br>
|
||||||
<input type="button" value="Fullscreen" onclick="Module.requestFullScreen(document.getElementById('pointerLock').checked,
|
|
||||||
document.getElementById('resize').checked)"><br>
|
|
||||||
<input type="checkbox" id="vsync"><label for="vsync" id="vsync-label">Enable V-sync (can only be done before loading game)</label><br>
|
<input type="checkbox" id="vsync"><label for="vsync" id="vsync-label">Enable V-sync (can only be done before loading game)</label><br>
|
||||||
<input type="checkbox" id="sdl2"><label for="sdl2" id="sdl2-label">Enable SDL2</label><br>
|
<input type="checkbox" id="sdl2"><label for="sdl2" id="sdl2-label">Enable SDL2</label><br>
|
||||||
<input type="textbox" id="latency" size="3" maxlength="3" value="96"> <label for="latency" id="latency-label">Audio latency (ms) (increase if you hear pops at fullspeed, can only be done before loading game)</label>
|
<input type="textbox" id="latency" size="3" maxlength="3" value="96"> <label for="latency" id="latency-label">Audio latency (ms) (increase if you hear pops at fullspeed, can only be done before loading game)</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<hr/>
|
<hr/>
|
||||||
<textarea class="emscripten" id="output" rows="8"></textarea>
|
<textarea class="emscripten" id="output" rows="8"></textarea>
|
||||||
<hr>
|
<hr>
|
||||||
<div class="emscripten" id="controls">
|
<div class="emscripten" id="controls">
|
||||||
Controls:<br>
|
Controls:<br>
|
||||||
<br>
|
<br>
|
||||||
A button (OK in menu): X<br>
|
A button (OK in menu): X<br>
|
||||||
@ -61,96 +54,89 @@
|
|||||||
Slow motion: E (hold)</br>
|
Slow motion: E (hold)</br>
|
||||||
Save state: F2<br>
|
Save state: F2<br>
|
||||||
Load state: F4
|
Load state: F4
|
||||||
</div>
|
</div>
|
||||||
<script type='text/javascript'>
|
|
||||||
var count = 0;
|
|
||||||
function runEmulator(files){
|
|
||||||
count = files.length;
|
|
||||||
document.getElementById("openrom").innerHTML = '';
|
|
||||||
document.getElementById("openrom").style.display = 'none';
|
|
||||||
for (var i = 0; i < files.length; i++) {
|
|
||||||
filereader = new FileReader();
|
|
||||||
filereader.file_name = files[i].name;
|
|
||||||
filereader.onload = function(){initFromData(this.result, this.file_name)};
|
|
||||||
filereader.readAsArrayBuffer(files[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function initFromData(data, name){
|
</body>
|
||||||
var dataView = new Uint8Array(data);
|
</html>
|
||||||
Module.FS_createDataFile('/', name, dataView, true, false);
|
<script type='text/javascript'>
|
||||||
count--;
|
var count = 0;
|
||||||
if (count === 0) {
|
function runEmulator(files)
|
||||||
Module.FS_createFolder('/', 'etc', true, true);
|
{
|
||||||
var config = 'input_player1_select = shift\n';
|
count = files.length;
|
||||||
var latency = parseInt(document.getElementById('latency').value, 10);
|
document.getElementById("openrom").innerHTML = '';
|
||||||
if (isNaN(latency)) latency = 96;
|
document.getElementById("openrom").style.display = 'none';
|
||||||
config += 'audio_latency = ' + latency + '\n'
|
for (var i = 0; i < files.length; i++)
|
||||||
if (document.getElementById('vsync').checked)
|
{
|
||||||
config += 'video_vsync = true\n';
|
filereader = new FileReader();
|
||||||
else
|
filereader.file_name = files[i].name;
|
||||||
config += 'video_vsync = false\n';
|
filereader.onload = function(){uploadData(this.result, this.file_name)};
|
||||||
Module.FS_createDataFile('/etc', 'retroarch.cfg', config, true, true);
|
filereader.readAsArrayBuffer(files[i]);
|
||||||
document.getElementById('canvas_div').style.display = 'block';
|
}
|
||||||
document.getElementById('vsync').disabled = true;
|
}
|
||||||
document.getElementById('vsync-label').style.color = 'gray';
|
function startRetroArch()
|
||||||
document.getElementById('latency').disabled = true;
|
{
|
||||||
document.getElementById('latency-label').style.color = 'gray';
|
Module.FS_createFolder('/', 'etc', true, true);
|
||||||
Module['callMain'](Module['arguments']);
|
Module.FS_createFolder('/', 'config', true, true);
|
||||||
}
|
Module.FS_createFolder('/', 'content', true, true);
|
||||||
}
|
Module.FS_createFolder('/', 'savefiles', true, true);
|
||||||
</script>
|
Module.FS_createFolder('/', 'savestates', true, true);
|
||||||
<script type='text/javascript'>
|
var config = 'input_player1_select = shift\n';
|
||||||
// connect to canvas
|
var latency = parseInt(document.getElementById('latency').value, 10);
|
||||||
var Module = {
|
if (isNaN(latency)) latency = 96;
|
||||||
noInitialRun: true,
|
config += 'audio_latency = ' + latency + '\n'
|
||||||
arguments: ["-v", "--menu"],
|
if (document.getElementById('vsync').checked)
|
||||||
preRun: [],
|
config += 'video_vsync = true\n';
|
||||||
postRun: [],
|
else
|
||||||
print: (function() {
|
config += 'video_vsync = false\n';
|
||||||
var element = document.getElementById('output');
|
Module.FS_createDataFile('/etc', 'retroarch.cfg', config, true, true);
|
||||||
element.value = ''; // clear browser cache
|
document.getElementById('canvas_div').style.display = 'block';
|
||||||
return function(text) {
|
document.getElementById('vsync').disabled = true;
|
||||||
|
document.getElementById('vsync-label').style.color = 'gray';
|
||||||
|
document.getElementById('latency').disabled = true;
|
||||||
|
document.getElementById('latency-label').style.color = 'gray';
|
||||||
|
Module['callMain'](Module['arguments']);
|
||||||
|
}
|
||||||
|
|
||||||
|
function uploadData(data, name)
|
||||||
|
{
|
||||||
|
var dataView = new Uint8Array(data);
|
||||||
|
Module.FS_createDataFile('/', name, dataView, true, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
var Module =
|
||||||
|
{
|
||||||
|
noInitialRun: true,
|
||||||
|
arguments: ["-v", "--menu"],
|
||||||
|
preRun: [],
|
||||||
|
postRun: [],
|
||||||
|
print: (function()
|
||||||
|
{
|
||||||
|
var element = document.getElementById('output');
|
||||||
|
element.value = ''; // clear browser cache
|
||||||
|
return function(text)
|
||||||
|
{
|
||||||
text = Array.prototype.slice.call(arguments).join(' ');
|
text = Array.prototype.slice.call(arguments).join(' ');
|
||||||
// These replacements are necessary if you render to raw HTML
|
|
||||||
//text = text.replace(/&/g, "&");
|
|
||||||
//text = text.replace(/</g, "<");
|
|
||||||
//text = text.replace(/>/g, ">");
|
|
||||||
//text = text.replace('\n', '<br>', 'g');
|
|
||||||
element.value += text + "\n";
|
element.value += text + "\n";
|
||||||
element.scrollTop = 99999; // focus on bottom
|
element.scrollTop = 99999; // focus on bottom
|
||||||
};
|
};
|
||||||
})(),
|
})(),
|
||||||
printErr: function(text) {
|
|
||||||
var text = Array.prototype.slice.call(arguments).join(' ');
|
printErr: function(text)
|
||||||
var element = document.getElementById('output');
|
{
|
||||||
element.value += text + "\n";
|
var text = Array.prototype.slice.call(arguments).join(' ');
|
||||||
element.scrollTop = 99999; // focus on bottom
|
var element = document.getElementById('output');
|
||||||
},
|
element.value += text + "\n";
|
||||||
canvas: document.getElementById('canvas'),
|
element.scrollTop = 99999; // focus on bottom
|
||||||
setStatus: function(text) {
|
},
|
||||||
if (Module.setStatus.interval) clearInterval(Module.setStatus.interval);
|
canvas: document.getElementById('canvas'),
|
||||||
var m = text.match(/([^(]+)\((\d+(\.\d+)?)\/(\d+)\)/);
|
|
||||||
var statusElement = document.getElementById('status');
|
totalDependencies: 0,
|
||||||
var progressElement = document.getElementById('progress');
|
monitorRunDependencies: function(left)
|
||||||
if (m) {
|
{
|
||||||
text = m[1];
|
this.totalDependencies = Math.max(this.totalDependencies, left);
|
||||||
progressElement.value = parseInt(m[2])*100;
|
}
|
||||||
progressElement.max = parseInt(m[4])*100;
|
};
|
||||||
progressElement.hidden = false;
|
|
||||||
} else {
|
</script>
|
||||||
progressElement.value = null;
|
<script type="text/javascript" src="browserfs.js"></script>
|
||||||
progressElement.max = null;
|
<script type="text/javascript" src="retroarch.js"></script>
|
||||||
progressElement.hidden = true;
|
|
||||||
}
|
|
||||||
statusElement.innerHTML = text;
|
|
||||||
},
|
|
||||||
totalDependencies: 0,
|
|
||||||
monitorRunDependencies: function(left) {
|
|
||||||
this.totalDependencies = Math.max(this.totalDependencies, left);
|
|
||||||
Module.setStatus(left ? 'Preparing... (' + (this.totalDependencies-left) + '/' + this.totalDependencies + ')' : 'All downloads complete.');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
Module.setStatus('Downloading...');
|
|
||||||
</script>
|
|
||||||
<script type="text/javascript" src="retroarch.js"></script>
|
|
Loading…
x
Reference in New Issue
Block a user