Main Options
EJS_player
The selector of the element you want the emulator to be placed in.
- Type:
string
- Default:
- Example:
EJS_player = '#game'
EJS_gameUrl
URL to ROM file.
- Type:
string
- Default:
- Example:
EJS_gameUrl = 'someFile.nes'
EJS_pathtodata
The path to the data folder. Version 4.0 and up will set this to the same path to the folder your loader.js file is in if not specified.
- Type:
string
- Default:
data/
- Example:
EJS_pathtodata = '/data/'
EJS_language
Set the emulator UI to a certian language. More information available here.
- Type:
string
- Default:
en-US
EJS_paths
You can set the paths to the files used by the emulator. This is useful if you want to host the files in a different why than the default, like a blob or a cdn.
- Type:
object
- Default: The default paths are used.
- Example:
EJS_paths = {
"GameManager.js": "blob:https://emulatorjs.org/0a0a0a0a-0a0a-0a0a-0a0a-0a0a0a0a0a0a",
"emulator.min.css": "blob:https://emulatorjs.org/0a0a0a0a-0a0a-0a0a-0a0a-0a0a0a0a0a0a",
"emulator.min.js": "https://cdn.emulatorjs.org/emulator.min.js",
"gamepad.js": "https://cdn.emulatorjs.org/gamepad.js",
"loader.js": "https://cdn.emulatorjs.org/loader.js",
"nipplejs.js": "https://cdn.emulatorjs.org/nipplejs.js",
"shaders.js": "https://cdn.emulatorjs.org/shaders.js",
"socket.io.min.js": "https://cdn.emulatorjs.org/socket.io.min.js",
"storage.js": "https://cdn.emulatorjs.org/storage.js",
"version.json": "https://cdn.emulatorjs.org/version.json"
};
Note the example above will not work the paths are just for example purposes.
EJS_volume
Sets the defauly volume for the emulator. 0=muted, 1=max
- Type:
number
- Default:
0.5
- Example:
EJS_volume = 1
Game Options
EJS_gameName
Set this to the title of the game. This will be used when saving states and taking screenshots.
- Type:
string
- Default: The name of the ROM file
- Example:
EJS_gameName = 'pong'
EJS_cheats
Default cheats to be stored in the cheat manager screen.
- Type:
array
- Default:
[]
- Example:
EJS_cheats = [
["name", "value"],
["name2", "value2"]
]
EJS_fullscreenOnLoaded
Set to true to start the game in fullscreen mode.
- Type:
boolean
- Default:
false
- Example:
EJS_fullscreenOnLoaded = true
EJS_startOnLoaded
Set to true to start the game when the page is loaded. Note that if the user has not interacted with the page, the emulator will freeze until they have done so.
- Type:
boolean
- Default:
false
- Example:
EJS_startOnLoaded = true
Core Options
EJS_core
Desired target system.
- Type:
string
- Default:
- Example:
EJS_core = 'nes'
EJS_biosUrl
URL to bios file.
- Type:
string
- Default:
''
- Example:
EJS_biosUrl = 'someFile.bin'
EJS_gamePatchUrl
URL to game patch file.
- Type:
string
- Default:
''
- Example:
EJS_gamePatchUrl = 'someFile.patch'
EJS_videoRotation
Sets the rotation of the video from retroarch. It can be 0
- No rotation, 1
- 90 degrees, 2
- 180 degrees, 3
- 270 degrees.
- Type:
number
- Default:
0
- Example:
EJS_videoRotation = 1
EJS_threads
Runs the core using threads. This may improve performance. As of 4.2.0, if the SharedArrayBuffer
function is exposed (see below), and EJS_threads
is not true, the user will have the option to opt-in to threads.
- Type:
boolean
- Default:
false
- Example:
EJS_threads = true
- Note: Threads requires the
SharedArrayBuffer
feature that is provided by the COOP and COEP headers.
To enable this, two HTTP headers will need to be sent:Cross-Origin-Opener-Policy : same-origin
Cross-Origin-Embedder-Policy: require-corp
EJS_gameParentUrl
This is a url to the game parent data. For additional files needed for the game emulation.
- Type:
string
- Default:
EJS_loadStateURL
URL to save state. To be loaded on game start.
- Type:
string
- Default:
''
- Example:
EJS_loadStateURL = 'save.state'
UI Options
EJS_color
Emulator hex color theme.
- Type:
string
- Default:
#1AAFFF
- Example:
EJS_color = '#00FF80'
EJS_alignStartButton
This can be used to align the start button. It can be top
, center
, bottom
.
- Type:
string
- Default:
bottom
- Example:
EJS_alignStartButton = "center"
EJS_backgroundImage
Url to a file you want to have as the background at the "Play Now" screen. Must be a Absolute path or a Relative Path from the pathtodata
folder.
- Type:
string
- Default:
- Example:
EJS_backgroundImage = 'loadScreen.png'
EJS_backgroundBlur
This will blur the background image to fit the all aspect ratios. Also known as frame blur. This will override the EJS_backgroundColor
.
- Type:
boolean
- Default:
- Example:
EJS_backgroundBlur = true
EJS_backgroundColor
This will set the background color of the emulator. In the start and loadings screens. Can be a css color like #000
or rgba(150,150,150,0.6)
.
- Type:
string
- Default:
#333
- Example:
EJS_backgroundColor = '#000'
EJS_AdUrl
URL to ad page. Will show this page when the page is loaded.
- Type:
string
- Default:
''
- Example:
EJS_AdUrl = 'ad.html'
EJS_AdTimer
Duration (in milliseconds) the ad iframe will stay before it automatically closes. Setting to 0
will disable auto-close.
Setting to -1
will close the ad immediately.
- Type:
number
- Default:
10000
- Example:
EJS_AdTimer = 1000
EJS_AdMode
This will set the ad mode. There 3 values 0
1
2
0
will only show the ad on the start screen and not the loading screen.
1
will only show the ad on the loading screen.
2
will show on both.
- Type:
number
- Default:
2
- Example:
EJS_AdMode = 0
EJS_AdSize
This will set the size of the ad. An array with the first value is the width and the second is the height. It can be any css option %
, vh
, px
etc.
- Type:
array
- Default:
["300px", "250px"]
- Example:
EJS_AdSize = ["800px", "500px"];
Advanced Options
EJS_CacheLimit
The limit to game cache (per rom) in bytes
- Type:
number
- Default:
1073741824
(1 GB
) - Example:
EJS_CacheLimit = 1024
EJS_externalFiles
Allows external files to placed within the EJS file system.
Extraction rules:
- If the path does not end with a
/
, it assumes that eveything after the last/
is the filename. - If the path ends with
/
, it will check for file compression. If it is a compressed file it will decompress to that folder, if not it will just write the filename based off of the url
This option is a list of attributes, with the attribute name being a location within the EJS file system and the value being the URL of the file or archive to extract to that location.
- Type:
json
- Default:
{}
- Example:
{
"/opt/": "/sample.zip",
"/etc/configuration/": "/files.zip"
}
EJS_adBlocked
A function that can be run to change the adUrl on the fly or delete it. A use case would be if the user is using an ad blocker you can change the adUrl to a different url (like to show a message) or delete it.
The first parameter is the url to change it the second you can set it to true
to delete the ad.
- Type:
function
- Default:
- Example:
EJS_adBlocked("https://ads.emulatorjs.org/blocked");
EJS_ready
This is a function that will be called when the emulator is ready. This is useful if you want to do something when the emulator is ready.
- Type:
function
- Default:
- Example:
EJS_ready = function() {console.log("The emulator is ready!")}
EJS_onSaveState
Function to be called when save state button pressed.
- Type:
function
- Default:
- Call Arguments: An array containing a screenshot and a save state
- Example:
EJS_onSaveState = function(e) {console.log("save state button pressed!")}
EJS_onLoadState
Function to be called when load state button pressed.
- Type:
function
- Default:
- Example:
EJS_onLoadState = function(e) {console.log("load state button pressed!")}
EJS_onGameStart
Function to be called when game is started.
- Type:
function
- Default:
- Example:
EJS_onGameStart = function(e) {console.log("The game has started!")}
EJS_defaultControls
Sets the default controller mapping. More information about controller mapping is located here.
- Type:
object
- Default/Example:
EJS_defaultControls = {
0: {
0: {
'value': 'x',
'value2': 'BUTTON_2'
},
1: {
'value': 's',
'value2': 'BUTTON_4'
},
2: {
'value': 'v',
'value2': 'SELECT'
},
3: {
'value': 'enter',
'value2': 'START'
},
4: {
'value': 'up arrow',
'value2': 'DPAD_UP'
},
5: {
'value': 'down arrow',
'value2': 'DPAD_DOWN'
},
6: {
'value': 'left arrow',
'value2': 'DPAD_LEFT'
},
7: {
'value': 'right arrow',
'value2': 'DPAD_RIGHT'
},
8: {
'value': 'z',
'value2': 'BUTTON_1'
},
9: {
'value': 'a',
'value2': 'BUTTON_3'
},
10: {
'value': 'q',
'value2': 'LEFT_TOP_SHOULDER'
},
11: {
'value': 'e',
'value2': 'RIGHT_TOP_SHOULDER'
},
12: {
'value': 'tab',
'value2': 'LEFT_BOTTOM_SHOULDER'
},
13: {
'value': 'r',
'value2': 'RIGHT_BOTTOM_SHOULDER'
},
14: {
'value': '',
'value2': 'LEFT_STICK',
},
15: {
'value': '',
'value2': 'RIGHT_STICK',
},
16: {
'value': 'h',
'value2': 'LEFT_STICK_X:+1'
},
17: {
'value': 'f',
'value2': 'LEFT_STICK_X:-1'
},
18: {
'value': 'g',
'value2': 'LEFT_STICK_Y:+1'
},
19: {
'value': 't',
'value2': 'LEFT_STICK_Y:-1'
},
20: {
'value': 'l',
'value2': 'RIGHT_STICK_X:+1'
},
21: {
'value': 'j',
'value2': 'RIGHT_STICK_X:-1'
},
22: {
'value': 'k',
'value2': 'RIGHT_STICK_Y:+1'
},
23: {
'value': 'i',
'value2': 'RIGHT_STICK_Y:-1'
},
24: {
'value': '1'
},
25: {
'value': '2'
},
26: {
'value': '3'
},
27: {
'value': 'add'
},
28: {
'value': 'space'
},
29: {
'value': 'subtract'
},
},
1: {},
2: {},
3: {}
}
EJS_VirtualGamepadSettings
Sets the location of what buttons. More information about the virual gamepad button customization is located here.
- Type:
object
- Default:
{}
EJS_controlScheme
- Type:
string
- Default: ``
Default behaviour (when option is undefined) not changed (core name will be used).
Available control schemes: nes
gb
gba
snes
n64
gba
nds
vb
segaMD
segaCD
sega32x
segaMS
segaGG
segaSaturn
3do
atari2600
atari7800
lynx
jaguar
arcade
mame
EJS_Buttons
Shows/hides buttons.
- Type:
object
- Default:
{}
- Example: The following example will hide all the buttons except for the volume slider and fullscreen button.
EJS_Buttons = {
playPause: false,
restart: false,
mute: false,
settings: false,
fullscreen: true,
saveState: false,
loadState: false,
screenRecord: false,
gamepad: false,
cheat: false,
volume: true,
saveSavFiles: true,
loadSavFiles: true,
quickSave: false,
quickLoad: false,
screenshot: false,
cacheManager: false,
exitEmulation: false
}
EJS_defaultOptions
Sets the default settings menu options.
- Type:
object
- Default:
{}
- Note: Available options and values will be logged when the emulator is started. Load the emulator page with
EJS_DEBUG_XX
on, click the play button, then on load there should be a log in the consolesupported menu options
. If you use the one that logs on page load, not all options will be available and not all options will be supported. - Example:
EJS_defaultOptions = {
'shader':'crt-mattias.glslp',
'save-state-slot': 4,
'save-state-location': 'keep in browser'
}
Debug Options
EJS_DEBUG_XX
You can set this to true
to enable debug mode. This will log a lot of information to the console and use the unminified scripts. This is useful for debugging issues with the emulator. And it is recommended to use this when you are contibuting to the project.
- Type:
boolean
- Default:
false
- Example:
EJS_DEBUG_XX = true
EJS_settingsLanguage
For debugging and adding new languages. Set it to true
and it will enable the missing translations in the console logs.
- Type:
boolean
- Default:
false
- Example:
EJS_settingsLanguage = true
EJS_missingLang
This is an array of missing translations. This is used for debugging and adding new languages. You can get the array by using console.log(EJS_missingLang)
.
- Type:
array
- Default:
[]
- Example:
console.log(EJS_missingLang);
EJS_softLoad
Automatically reset the console after x seconds.
- Type:
boolean
- Default:
false
- Example:
EJS_softLoad = true;
EJS_startButtonName
Custom text for the start button.
- Type:
string
- Default:
Start Game
- Example:
EJS_startButtonName = "Start {game name}"