mirror of
https://github.com/CTCaer/RetroArch.git
synced 2024-12-22 10:49:02 +00:00
Add focus to canvas (SDL2 input)
When the canvas in focus SDL2 input should be work
This commit is contained in:
parent
af09bd1751
commit
c6870cfb8e
@ -1,205 +1,229 @@
|
||||
var count = 0;
|
||||
var filename = "";
|
||||
var firstRun = true;
|
||||
|
||||
|
||||
function setupFolders()
|
||||
{
|
||||
console.log("setupFolders");
|
||||
|
||||
if(localStorage.getItem("folders_inited")!="true")
|
||||
{
|
||||
FS.createFolder('/home','web_user',true,true);
|
||||
FS.createFolder('/home/web_user','retroarch',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','saves',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','states',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','system',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','cheat',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','remap',true,true);
|
||||
FS.createFolder('/home/web_user','.config',true,true);
|
||||
FS.createFolder('/home/web_user/.config','retroarch',true,true);
|
||||
|
||||
localStorage.setItem("folders_inited","true");
|
||||
console.log('Folders initialized: ' + localStorage.getItem("folders_inited"));
|
||||
}
|
||||
}
|
||||
|
||||
function createConfig()
|
||||
{
|
||||
console.log("createConfig");
|
||||
|
||||
if(localStorage.getItem("cfg_inited")!="true")
|
||||
{
|
||||
var config = 'input_player1_select = shift\n';
|
||||
config += 'audio_latency = 96\n'
|
||||
config += 'video_font_size = 16\n'
|
||||
config += 'rgui_browser_directory = /content\n';
|
||||
config += 'savefile_directory = /home/web_user/retroarch/saves/\n';
|
||||
config += 'savestate_directory = /home/web_user/retroarch/states/\n';
|
||||
config += 'system_directory = /home/web_user/retroarch/system/\n';
|
||||
config += 'rgui_config_directory = /home/web_user/.config/retroarch/\n';
|
||||
config += 'input_remapping_directory = /home/web_user/retroarch/remap/\n';
|
||||
config += 'cheat_database_path = /home/web_user/retroarch/cheat/\n';
|
||||
FS.writeFile('/home/web_user/.config/retroarch/retroarch.cfg',config);
|
||||
|
||||
localStorage.setItem("cfg_inited","true");
|
||||
console.log('Config initialized: ' + localStorage.getItem("cfg_inited"));
|
||||
var count = 0;
|
||||
var filename = "";
|
||||
var firstRun = true;
|
||||
|
||||
|
||||
function setupFolders()
|
||||
{
|
||||
console.log("setupFolders");
|
||||
|
||||
if(localStorage.getItem("folders_inited")!="true")
|
||||
{
|
||||
FS.createFolder('/home','web_user',true,true);
|
||||
FS.createFolder('/home/web_user','retroarch',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','saves',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','states',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','system',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','cheat',true,true);
|
||||
FS.createFolder('/home/web_user/retroarch','remap',true,true);
|
||||
FS.createFolder('/home/web_user','.config',true,true);
|
||||
FS.createFolder('/home/web_user/.config','retroarch',true,true);
|
||||
|
||||
localStorage.setItem("folders_inited","true");
|
||||
console.log('Folders initialized: ' + localStorage.getItem("folders_inited"));
|
||||
}
|
||||
}
|
||||
|
||||
function setupFileSystem()
|
||||
{
|
||||
console.log("setupFileSystem");
|
||||
|
||||
if(localStorage.getItem("fs_inited")!="true")
|
||||
{
|
||||
var lsfs = new BrowserFS.FileSystem.LocalStorage();
|
||||
BrowserFS.initialize(lsfs);
|
||||
var BFS = new BrowserFS.EmscriptenFS();
|
||||
|
||||
FS.mount(BFS, {root: '/'}, '/home');
|
||||
|
||||
console.log('Filesystem initialized');
|
||||
}
|
||||
else
|
||||
{
|
||||
}
|
||||
|
||||
function createConfig()
|
||||
{
|
||||
console.log("createConfig");
|
||||
|
||||
if(localStorage.getItem("cfg_inited")!="true")
|
||||
{
|
||||
var config = 'input_player1_select = shift\n';
|
||||
|
||||
//SDL2 ADD focus to html element
|
||||
|
||||
if (document.getElementById('sdl2').checked) {
|
||||
config += 'video_driver = sdl2\n';
|
||||
config +="input_driver = sdl2\n";
|
||||
config +="input_joypad_driver = sdl2\n";
|
||||
config += "video_context_driver = sdl_gl\n";
|
||||
document.getElementById("canvas").focus();
|
||||
document.getElementById("canvas").addEventListener("keydown",function(e){
|
||||
e.preventDefault();
|
||||
return false;
|
||||
});
|
||||
|
||||
document.getElementById("canvas").onclick = function(){
|
||||
document.getElementById("canvas").focus();
|
||||
|
||||
};
|
||||
|
||||
}else{
|
||||
config += "video_context_driver = emscripten\n";
|
||||
|
||||
};
|
||||
|
||||
config += 'audio_latency = 96\n'
|
||||
config += 'video_font_size = 16\n'
|
||||
config += 'rgui_browser_directory = /content\n';
|
||||
config += 'savefile_directory = /home/web_user/retroarch/saves/\n';
|
||||
config += 'savestate_directory = /home/web_user/retroarch/states/\n';
|
||||
config += 'system_directory = /home/web_user/retroarch/system/\n';
|
||||
config += 'rgui_config_directory = /home/web_user/.config/retroarch/\n';
|
||||
config += 'input_remapping_directory = /home/web_user/retroarch/remap/\n';
|
||||
config += 'cheat_database_path = /home/web_user/retroarch/cheat/\n';
|
||||
FS.writeFile('/home/web_user/.config/retroarch/retroarch.cfg',config);
|
||||
|
||||
localStorage.setItem("cfg_inited","true");
|
||||
console.log('Config initialized: ' + localStorage.getItem("cfg_inited"));
|
||||
}
|
||||
}
|
||||
|
||||
function setupFileSystem()
|
||||
{
|
||||
console.log("setupFileSystem");
|
||||
|
||||
if(localStorage.getItem("fs_inited")!="true")
|
||||
{
|
||||
var lsfs = new BrowserFS.FileSystem.LocalStorage();
|
||||
BrowserFS.initialize(lsfs);
|
||||
var BFS = new BrowserFS.EmscriptenFS();
|
||||
|
||||
FS.mount(BFS, {root: '/'}, '/home');
|
||||
|
||||
console.log('Filesystem initialized');
|
||||
}
|
||||
else
|
||||
{
|
||||
console.log('Filesystem already initialized');
|
||||
}
|
||||
}
|
||||
|
||||
function runEmulator(files)
|
||||
{
|
||||
|
||||
if (Modernizr.localstorage)
|
||||
{
|
||||
if(firstRun)
|
||||
setupFileSystem();
|
||||
}
|
||||
|
||||
setupFolders();
|
||||
createConfig();
|
||||
|
||||
if(firstRun)
|
||||
FS.createFolder('/','content',true,true);
|
||||
|
||||
count = files.length;
|
||||
for (var i = 0; i < files.length; i++)
|
||||
{
|
||||
filereader = new FileReader();
|
||||
filereader.file_name = files[i].name;
|
||||
filereader.readAsArrayBuffer(files[i]);
|
||||
if(firstRun)
|
||||
{
|
||||
filereader.onload = function(){uploadContent(this.result, '/content/' + this.file_name)};
|
||||
firstRun = false;
|
||||
}
|
||||
}
|
||||
|
||||
function runEmulator(files)
|
||||
{
|
||||
|
||||
if (Modernizr.localstorage)
|
||||
{
|
||||
if(firstRun)
|
||||
setupFileSystem();
|
||||
}
|
||||
|
||||
setupFolders();
|
||||
createConfig();
|
||||
|
||||
if(firstRun)
|
||||
FS.createFolder('/','content',true,true);
|
||||
|
||||
count = files.length;
|
||||
for (var i = 0; i < files.length; i++)
|
||||
{
|
||||
filereader = new FileReader();
|
||||
filereader.file_name = files[i].name;
|
||||
filereader.readAsArrayBuffer(files[i]);
|
||||
if(firstRun)
|
||||
{
|
||||
filereader.onload = function(){uploadContent(this.result, '/content/' + this.file_name)};
|
||||
firstRun = false;
|
||||
initFromData();
|
||||
}
|
||||
else
|
||||
filereader.onload = function(){uploadContent(this.result, '/content/' + this.file_name)};
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
function uploadContent(data, name)
|
||||
{
|
||||
var dataView = new Uint8Array(data);
|
||||
FS.createDataFile('/', name, dataView, true, false);
|
||||
}
|
||||
|
||||
function copyFile(src,dest)
|
||||
{
|
||||
console.log('copying: ' + src + ' to: ' + dest);
|
||||
var contents = FS.readFile(src,{ encoding: 'binary' });
|
||||
console.log(contents);
|
||||
FS.writeFile(dest,contents,{ encoding: 'binary' });
|
||||
}
|
||||
|
||||
function uploadData(files, path)
|
||||
{
|
||||
count = files.length;
|
||||
for (var i = 0; i < files.length; i++)
|
||||
{
|
||||
filereader = new FileReader();
|
||||
filereader.file_name = files[i].name;
|
||||
filereader.readAsArrayBuffer(files[i]);
|
||||
filereader.onload = function(){uploadContent(this.result, '/tmp/' + this.file_name)};
|
||||
filereader.onloadend = function(){copyFile('/tmp/' + this.file_name,'/home/web_user/retroarch/' + path + '/' + this.file_name)};
|
||||
|
||||
}
|
||||
else
|
||||
filereader.onload = function(){uploadContent(this.result, '/content/' + this.file_name)};
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
function initFromData()
|
||||
{
|
||||
|
||||
count--;
|
||||
if (count === 0)
|
||||
{
|
||||
document.getElementById('canvas_div').style.display = 'block';
|
||||
Module['callMain'](Module['arguments']);
|
||||
}
|
||||
}
|
||||
|
||||
var Module =
|
||||
{
|
||||
noInitialRun: true,
|
||||
arguments: ["--verbose", "--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(' ');
|
||||
// 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.scrollTop = 99999; // focus on bottom
|
||||
};
|
||||
})(),
|
||||
|
||||
printErr: function(text)
|
||||
{
|
||||
var text = Array.prototype.slice.call(arguments).join(' ');
|
||||
var element = document.getElementById('output');
|
||||
element.value += text + "\n";
|
||||
element.scrollTop = 99999; // focus on bottom
|
||||
},
|
||||
|
||||
canvas: document.getElementById('canvas'),
|
||||
setStatus: function(text)
|
||||
{
|
||||
if (Module.setStatus.interval)
|
||||
clearInterval(Module.setStatus.interval);
|
||||
var m = text.match(/([^(]+)\((\d+(\.\d+)?)\/(\d+)\)/);
|
||||
var statusElement = document.getElementById('status');
|
||||
var progressElement = document.getElementById('progress');
|
||||
if (m)
|
||||
{
|
||||
text = m[1];
|
||||
progressElement.value = parseInt(m[2])*100;
|
||||
progressElement.max = parseInt(m[4])*100;
|
||||
progressElement.hidden = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
progressElement.value = null;
|
||||
progressElement.max = null;
|
||||
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...');
|
||||
}
|
||||
|
||||
function uploadContent(data, name)
|
||||
{
|
||||
var dataView = new Uint8Array(data);
|
||||
FS.createDataFile('/', name, dataView, true, false);
|
||||
}
|
||||
|
||||
function copyFile(src,dest)
|
||||
{
|
||||
console.log('copying: ' + src + ' to: ' + dest);
|
||||
var contents = FS.readFile(src,{ encoding: 'binary' });
|
||||
console.log(contents);
|
||||
FS.writeFile(dest,contents,{ encoding: 'binary' });
|
||||
}
|
||||
|
||||
function uploadData(files, path)
|
||||
{
|
||||
count = files.length;
|
||||
for (var i = 0; i < files.length; i++)
|
||||
{
|
||||
filereader = new FileReader();
|
||||
filereader.file_name = files[i].name;
|
||||
filereader.readAsArrayBuffer(files[i]);
|
||||
filereader.onload = function(){uploadContent(this.result, '/tmp/' + this.file_name)};
|
||||
filereader.onloadend = function(){copyFile('/tmp/' + this.file_name,'/home/web_user/retroarch/' + path + '/' + this.file_name)};
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
function initFromData()
|
||||
{
|
||||
|
||||
count--;
|
||||
if (count === 0)
|
||||
{
|
||||
document.getElementById('canvas_div').style.display = 'block';
|
||||
Module['callMain'](Module['arguments']);
|
||||
}
|
||||
}
|
||||
|
||||
var Module =
|
||||
{
|
||||
noInitialRun: true,
|
||||
arguments: ["--verbose", "--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(' ');
|
||||
// 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.scrollTop = 99999; // focus on bottom
|
||||
};
|
||||
})(),
|
||||
|
||||
printErr: function(text)
|
||||
{
|
||||
var text = Array.prototype.slice.call(arguments).join(' ');
|
||||
var element = document.getElementById('output');
|
||||
element.value += text + "\n";
|
||||
element.scrollTop = 99999; // focus on bottom
|
||||
},
|
||||
|
||||
canvas: document.getElementById('canvas'),
|
||||
setStatus: function(text)
|
||||
{
|
||||
if (Module.setStatus.interval)
|
||||
clearInterval(Module.setStatus.interval);
|
||||
var m = text.match(/([^(]+)\((\d+(\.\d+)?)\/(\d+)\)/);
|
||||
var statusElement = document.getElementById('status');
|
||||
var progressElement = document.getElementById('progress');
|
||||
if (m)
|
||||
{
|
||||
text = m[1];
|
||||
progressElement.value = parseInt(m[2])*100;
|
||||
progressElement.max = parseInt(m[4])*100;
|
||||
progressElement.hidden = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
progressElement.value = null;
|
||||
progressElement.max = null;
|
||||
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...');
|
||||
|
Loading…
Reference in New Issue
Block a user