EmulationStation allows each system to have its own "theme." A theme is a collection views that define some elements, each with their own properties.
The first place ES will check for a theme is in the system's <path>
folder, for a theme.xml file:
[SYSTEM_PATH]/theme.xml
If that file doesn't exist, ES will try to find the theme in the current theme set. Theme sets are just a collection of individual system themes arranged in the "themes" folder under some name. A theme set can provide a default theme that will be used if there is no matching system theme. Here's an example:
...
themes/
my_theme_set/
snes/
theme.xml
my_cool_background.jpg
nes/
theme.xml
my_other_super_cool_background.jpg
common_resources/
scroll_sound.wav
theme.xml (Default theme)
another_theme_set/
snes/
theme.xml
some_resource.svg
The theme set system makes it easy for users to try different themes and allows distributions to include multiple theme options. Users can change the currently active theme set in the "UI Settings" menu. The option is only visible if at least one theme set exists.
There are two places ES can load theme sets from:
[HOME]/.emulationstation/themes/[CURRENT_THEME_SET]/[SYSTEM_THEME]/theme.xml
/etc/emulationstation/themes/[CURRENT_THEME_SET]/[SYSTEM_THEME]/theme.xml
[SYSTEM_THEME]
is the <theme>
tag for the system, as defined in es_systems.cfg
. If the <theme>
tag is not set, ES will use the system's <name>
.
If both files happen to exist, ES will pick the first one (the one located in the home directory).
Again, the [CURRENT_THEME_SET]
value is set in the "UI Settings" menu. If it has not been set yet or the previously selected theme set is missing, the first available theme set will be used as the default.
Here is a very simple theme that changes the description text's color:
<theme>
<formatVersion>3</formatVersion>
<view name="detailed">
<text name="description">
<color>00FF00</color>
</text>
<image name="my_image" extra="true">
<pos>0.5 0.5</pos>
<origin>0.5 0.5</origin>
<size>0.8 0.8</size>
<path>./my_art/my_awesome_image.jpg</path>
</image>
</view>
</theme>
Everything must be inside a <theme>
tag.
The <formatVersion>
tag must be specified. This is the version of the theming system the theme was designed for. The current version is 3.
A view can be thought of as a particular "screen" within EmulationStation. Views are defined like this:
<view name="ViewNameHere">
... define elements here ...
</view>
An element is a particular visual element, such as an image or a piece of text. You can either modify an element that already exists for a particular view (as is done in the "description" example), like this:
<elementTypeHere name="ExistingElementNameHere">
... define properties here ...
</elementTypeHere>
Or, you can create your own elements by adding extra="true"
(as is done in the "my_image" example) like this:
<elementTypeHere name="YourUniqueElementNameHere" extra="true">
... define properties here ...
</elementTypeHere>
"Extra" elements will be drawn in the order they are defined (so define backgrounds first!). When they get drawn relative to the pre-existing elements depends on the view. Make sure "extra" element names do not clash with existing element names! An easy way to protect against this is to just start all your extra element names with some prefix like "e_".
Properties control how a particular element looks - for example, its position, size, image path, etc. The type of the property determines what kinds of values you can use. You can read about the types below in the "Reference" section. Properties are defined like this:
<propertyNameHere>ValueHere</propertyNameHere>
It is recommended that if you are writing a theme you launch EmulationStation with the --debug
and --windowed
switches. This way you can read error messages without having to check the log file. You can also reload the current gamelist view and system view with Ctrl-R
if --debug
is specified.
You can specifiy the resolution the theme was made for using this. This defaults to 1 1. When parsing any elements of type RESOLUTION_RECT, RESOLUTION_PAIR or RESOLUTION_FLOAT, they will have their values divided by the resolution specified so they become percentages. The following 2 examples produce the same result
<theme>
<formatVersion>6</formatVersion>
<view name="detailed">
<text name="description">
<color>00FF00</color>
</text>
<image name="my_image" extra="true">
<pos>0.5 0.5</pos>
<origin>0.5 0.5</origin>
<size>0.8 0.8</size>
<path>./my_art/my_awesome_image.jpg</path>
</image>
</view>
</theme>
<theme>
<formatVersion>6</formatVersion>
<resolution>1920 1080</resolution>
<view name="detailed">
<text name="description">
<color>00FF00</color>
</text>
<image name="my_image" extra="true">
<pos>960 540</pos>
<origin>0.5 0.5</origin>
<size>1536 864</size>
<path>./my_art/my_awesome_image.jpg</path>
</image>
</view>
</theme>
The difference is how we specify the position and size of the image element. This does not limit a theme to be used at a certain resolution, but merely helps the theme makers build their themes using pixel values rather than percentages. Parenting of elements can not be used when using a resolution other than 1 1.
You can include theme files within theme files, similar to #include
in C (though the internal mechanism is different, the effect is the same). Example:
~/.emulationstation/all_themes.xml
:
<theme>
<formatVersion>3</formatVersion>
<view name="detailed">
<text name="description">
<fontPath>./all_themes/myfont.ttf</fontPath>
<color>00FF00</color>
</text>
</view>
</theme>
~/.emulationstation/snes/theme.xml
:
<theme>
<formatVersion>3</formatVersion>
<include>./../all_themes.xml</include>
<view name="detailed">
<text name="description">
<color>FF0000</color>
</text>
</view>
</theme>
Is equivalent to this snes/theme.xml
:
<theme>
<formatVersion>3</formatVersion>
<view name="detailed">
<text name="description">
<fontPath>./all_themes/myfont.ttf</fontPath>
<color>FF0000</color>
</text>
</view>
</theme>
Notice that properties that were not specified got merged (<fontPath>
) and the snes/theme.xml
could overwrite the included files' values (<color>
). Also notice the included file still needed the <formatVersion>
tag.
Sometimes you want to apply the same properties to the same elements across multiple views. The name
attribute actually works as a list (delimited by any characters of \t\r\n ,
- that is, whitespace and commas). So, for example, to easily apply the same header to the basic, grid, and system views:
<theme>
<formatVersion>3</formatVersion>
<view name="basic, grid, system">
<image name="logo">
<path>./snes_art/snes_header.png</path>
</image>
</view>
<view name="detailed">
<image name="logo">
<path>./snes_art/snes_header_detailed.png</path>
</image>
</view>
</theme>
This is equivalent to:
<theme>
<formatVersion>3</formatVersion>
<view name="basic">
<image name="logo">
<path>./snes_art/snes_header.png</path>
</image>
</view>
<view name="detailed">
<image name="logo">
<path>./snes_art/snes_header_detailed.png</path>
</image>
</view>
<view name="grid">
<image name="logo">
<path>./snes_art/snes_header.png</path>
</image>
</view>
<view name="system">
<image name="logo">
<path>./snes_art/snes_header.png</path>
</image>
</view>
... and any other view that might try to look up "logo" ...
</theme>
You can theme multiple elements of the same type simultaneously. The name
attribute actually works as a list (delimited by any characters of \t\r\n ,
- that is, whitespace and commas), just like it does for views, as long as the elements have the same type. This is useful if you want to, say, apply the same color to all the metadata labels:
<theme>
<formatVersion>3</formatVersion>
<view name="detailed">
<!-- Weird spaces/newline on purpose! -->
<text name="md_lbl_rating, md_lbl_releasedate, md_lbl_developer, md_lbl_publisher,
md_lbl_genre, md_lbl_players, md_lbl_lastplayed, md_lbl_playcount">
<color>48474D</color>
</text>
</view>
</theme>
Which is equivalent to:
<theme>
<formatVersion>3</formatVersion>
<view name="detailed">
<text name="md_lbl_rating">
<color>48474D</color>
</text>
<text name="md_lbl_releasedate">
<color>48474D</color>
</text>
<text name="md_lbl_developer">
<color>48474D</color>
</text>
<text name="md_lbl_publisher">
<color>48474D</color>
</text>
<text name="md_lbl_genre">
<color>48474D</color>
</text>
<text name="md_lbl_players">
<color>48474D</color>
</text>
<text name="md_lbl_lastplayed">
<color>48474D</color>
</text>
<text name="md_lbl_playcount">
<color>48474D</color>
</text>
</view>
</theme>
Just remember, this only works if the elements have the same type!
You can now change the order in which elements are rendered by setting zIndex
values. Default values correspond to the default rendering order while allowing elements to easily be shifted without having to set zIndex
values for every element. Elements will be rendered in order from smallest z-index to largest.
- Extra Elements
extra="true"
- 10 carousel name="systemcarousel"
- 40text name="systemInfo"
- 50
image name="background"
- 0- Extra Elements
extra="true"
- 10 textlist name="gamelist"
- 20imagegrid name="gamegrid"
- 20- Media
image name="md_image"
- 30video name="md_video"
- 30image name="md_thumbnail"
- 35image name="md_marquee"
- 35
- Metadata - 40
- Labels
text name="md_lbl_rating"
text name="md_lbl_releasedate"
text name="md_lbl_developer"
text name="md_lbl_publisher"
text name="md_lbl_genre"
text name="md_lbl_players"
text name="md_lbl_lastplayed"
text name="md_lbl_playcount"
- Values
rating name="md_rating"
datetime name="md_releasedate"
text name="md_developer"
text name="md_publisher"
text name="md_genre"
text name="md_players"
datetime name="md_lastplayed"
text name="md_playcount"
text name="md_description"
text name="md_name"
- Labels
- System Logo/Text - 50
text name="logoText"
image name="logo"
Theme variables can be used to simplify theme construction. There are 2 types of variables available.
- System Variables
- Theme Defined Variables
System variables are system specific and are derived from the values in es_systems.cfg.
system.name
system.fullName
system.theme
Variables can also be defined in the theme.
<variables>
<themeColor>8b0000</themeColor>
</variables>
Variables can be used to specify the value of a theme property:
<color>${themeColor}</color>
or to specify only a portion of the value of a theme property:
<color>${themeColor}c0</color>
<path>./art/logo/${system.theme}.svg</path>
helpsystem name="help"
- ALL- The help system style for this view.
image name="background"
- ALL- This is a background image that exists for convenience. It goes from (0, 0) to (1, 1).
text name="logoText"
- ALL- Displays the name of the system. Only present if no "logo" image is specified. Displayed at the top of the screen, centered by default.
image name="logo"
- ALL- A header image. If a non-empty
path
is specified,text name="logoText"
will be hidden and this image will be, by default, displayed roughly in its place.
- A header image. If a non-empty
textlist name="gamelist"
- ALL- The gamelist.
primaryColor
is for games,secondaryColor
is for folders. Centered by default.
- The gamelist.
-
helpsystem name="help"
- ALL- The help system style for this view.
-
image name="background"
- ALL- This is a background image that exists for convenience. It goes from (0, 0) to (1, 1).
-
text name="logoText"
- ALL- Displays the name of the system. Only present if no "logo" image is specified. Displayed at the top of the screen, centered by default.
-
image name="logo"
- ALL- A header image. If a non-empty
path
is specified,text name="logoText"
will be hidden and this image will be, by default, displayed roughly in its place.
- A header image. If a non-empty
-
textlist name="gamelist"
- ALL- The gamelist.
primaryColor
is for games,secondaryColor
is for folders. Left aligned by default.
- The gamelist.
-
Metadata
-
Labels
text name="md_lbl_rating"
- ALLtext name="md_lbl_releasedate"
- ALLtext name="md_lbl_developer"
- ALLtext name="md_lbl_publisher"
- ALLtext name="md_lbl_genre"
- ALLtext name="md_lbl_players"
- ALLtext name="md_lbl_lastplayed"
- ALLtext name="md_lbl_playcount"
- ALL
-
Values
-
All values will follow to the right of their labels if a position isn't specified.
-
image name="md_image"
- POSITION | SIZE | Z_INDEX- Path is the "image" metadata for the currently selected game.
-
rating name="md_rating"
- ALL- The "rating" metadata.
-
datetime name="md_releasedate"
- ALL- The "releasedate" metadata.
-
text name="md_developer"
- ALL- The "developer" metadata.
-
text name="md_publisher"
- ALL- The "publisher" metadata.
-
text name="md_genre"
- ALL- The "genre" metadata.
-
text name="md_players"
- ALL- The "players" metadata (number of players the game supports).
-
datetime name="md_lastplayed"
- ALL- The "lastplayed" metadata. Displayed as a string representing the time relative to "now" (e.g. "3 hours ago").
-
text name="md_playcount"
- ALL- The "playcount" metadata (number of times the game has been played).
-
text name="md_description"
- POSITION | SIZE | FONT_PATH | FONT_SIZE | COLOR | Z_INDEX- Text is the "desc" metadata. If no
pos
/size
is specified, will move and resize to fit under the lowest label and reach to the bottom of the screen.
- Text is the "desc" metadata. If no
-
text name="md_name"
- ALL- The "name" metadata (the game name). Unlike the others metadata fields, the name is positioned offscreen by default
-
-
-
helpsystem name="help"
- ALL- The help system style for this view.
-
image name="background"
- ALL- This is a background image that exists for convenience. It goes from (0, 0) to (1, 1).
-
text name="logoText"
- ALL- Displays the name of the system. Only present if no "logo" image is specified. Displayed at the top of the screen, centered by default.
-
image name="logo"
- ALL- A header image. If a non-empty
path
is specified,text name="logoText"
will be hidden and this image will be, by default, displayed roughly in its place.
- A header image. If a non-empty
-
textlist name="gamelist"
- ALL- The gamelist.
primaryColor
is for games,secondaryColor
is for folders. Left aligned by default.
- The gamelist.
-
Metadata
-
Labels
text name="md_lbl_rating"
- ALLtext name="md_lbl_releasedate"
- ALLtext name="md_lbl_developer"
- ALLtext name="md_lbl_publisher"
- ALLtext name="md_lbl_genre"
- ALLtext name="md_lbl_players"
- ALLtext name="md_lbl_lastplayed"
- ALLtext name="md_lbl_playcount"
- ALL
-
Values
-
All values will follow to the right of their labels if a position isn't specified.
-
image name="md_image"
- POSITION | SIZE | Z_INDEX- Path is the "image" metadata for the currently selected game.
-
image name="md_marquee"
- POSITION | SIZE | Z_INDEX- Path is the "marquee" metadata for the currently selected game.
-
video name="md_video"
- POSITION | SIZE | Z_INDEX- Path is the "video" metadata for the currently selected game.
-
rating name="md_rating"
- ALL- The "rating" metadata.
-
datetime name="md_releasedate"
- ALL- The "releasedate" metadata.
-
text name="md_developer"
- ALL- The "developer" metadata.
-
text name="md_publisher"
- ALL- The "publisher" metadata.
-
text name="md_genre"
- ALL- The "genre" metadata.
-
text name="md_players"
- ALL- The "players" metadata (number of players the game supports).
-
datetime name="md_lastplayed"
- ALL- The "lastplayed" metadata. Displayed as a string representing the time relative to "now" (e.g. "3 hours ago").
-
text name="md_playcount"
- ALL- The "playcount" metadata (number of times the game has been played).
-
text name="md_description"
- POSITION | SIZE | FONT_PATH | FONT_SIZE | COLOR | Z_INDEX- Text is the "desc" metadata. If no
pos
/size
is specified, will move and resize to fit under the lowest label and reach to the bottom of the screen.
- Text is the "desc" metadata. If no
-
text name="md_name"
- ALL- The "name" metadata (the game name). Unlike the others metadata fields, the name is positioned offscreen by default
-
-
-
helpsystem name="help"
- ALL- The help system style for this view.
-
image name="background"
- ALL- This is a background image that exists for convenience. It goes from (0, 0) to (1, 1).
-
text name="logoText"
- ALL- Displays the name of the system. Only present if no "logo" image is specified. Displayed at the top of the screen, centered by default.
-
image name="logo"
- ALL- A header image. If a non-empty
path
is specified,text name="logoText"
will be hidden and this image will be, by default, displayed roughly in its place.
- A header image. If a non-empty
-
imagegrid name="gamegrid"
- ALL- The gamegrid. The number of tile displayed is controlled by its size, margin and the default tile max size.
-
gridtile name="default"
- ALL- Note that many of the default gridtile parameters change the selected gridtile parameters if they are not explicitly set by the theme. For example, changing the background image of the default gridtile also change the background image of the selected gridtile. Refer to the gridtile documentation for more informations.
-
gridtile name="selected"
- ALL- See default gridtile description right above.
-
Metadata
-
Labels
text name="md_lbl_rating"
- ALLtext name="md_lbl_releasedate"
- ALLtext name="md_lbl_developer"
- ALLtext name="md_lbl_publisher"
- ALLtext name="md_lbl_genre"
- ALLtext name="md_lbl_players"
- ALLtext name="md_lbl_lastplayed"
- ALLtext name="md_lbl_playcount"
- ALL
-
Values
-
All values will follow to the right of their labels if a position isn't specified.
-
rating name="md_rating"
- ALL- The "rating" metadata.
-
datetime name="md_releasedate"
- ALL- The "releasedate" metadata.
-
text name="md_developer"
- ALL- The "developer" metadata.
-
text name="md_publisher"
- ALL- The "publisher" metadata.
-
text name="md_genre"
- ALL- The "genre" metadata.
-
text name="md_players"
- ALL- The "players" metadata (number of players the game supports).
-
datetime name="md_lastplayed"
- ALL- The "lastplayed" metadata. Displayed as a string representing the time relative to "now" (e.g. "3 hours ago").
-
text name="md_playcount"
- ALL- The "playcount" metadata (number of times the game has been played).
-
text name="md_description"
- POSITION | SIZE | FONT_PATH | FONT_SIZE | COLOR | Z_INDEX- Text is the "desc" metadata. If no
pos
/size
is specified, will move and resize to fit under the lowest label and reach to the bottom of the screen.
- Text is the "desc" metadata. If no
-
text name="md_name"
- ALL- The "name" metadata (the game name). Unlike the others metadata fields, the name is positioned offscreen by default
-
-
helpsystem name="help"
- ALL- The help system style for this view.
carousel name="systemcarousel"
-ALL- The system logo carousel
image name="logo"
- PATH | COLOR- A logo image, to be displayed in the system logo carousel.
text name="logoText"
- FONT_PATH | COLOR | FORCE_UPPERCASE | LINE_SPACING | TEXT- A logo text, to be displayed system name in the system logo carousel when no logo is available.
text name="systemInfo"
- ALL- Displays details of the system currently selected in the carousel.
- You can use extra elements (elements with
extra="true"
) to add your own backgrounds, etc. They will be displayed behind the carousel, and scroll relative to the carousel.
- RESOLUTION_RECT - four decimals, using pixels in the range [0..resolution], delimited by a space. For example,
320 640 80 160
. Most commonly used for padding to store top, left, bottom and right coordinates. - RESOLUTION_PAIR - two decimals, using pixels in the range [0..resolution], delimited by a space. For example,
320 640
. Most commonly used for position (x and y coordinates) and size (width and height). - RESOLUTION_FLOAT - a decimal, using pixels in the range [0..resolution]. Most commonly used for font size.
- NORMALIZED_PAIR - two decimals, using percentage in the range [0..1], delimited by a space. For example,
0.25 0.5
. Most commonly used for origin (x and y coordinates). - PATH - a path. If the first character is a
~
, it will be expanded into the environment variable for the home path ($HOME
for Linux or%HOMEPATH%
for Windows). If the first character is a.
, it will be expanded to the theme file's directory, allowing you to specify resources relative to the theme file, like so:./../general_art/myfont.ttf
. - STRING - a string of text.
- COLOR - a hexidecimal RGB or RGBA color (6 or 8 digits). If 6 digits, will assume the alpha channel is
FF
(not transparent). - FLOAT - a decimal.
- BOOLEAN -
true
/1
orfalse
/0
.
Common to almost all elements is a pos
and size
property of the NORMALIZED_PAIR type. They are normalized in terms of their "parent" object's size; 99% of the time, this is just the size of the screen. In this case, <pos>0 0</pos>
would correspond to the top left corner, and <pos>1 1</pos>
the bottom right corner (a positive Y value points further down). pos
almost always refers to the top left corner of your element. You can use numbers outside of the [0..1] range if you want to place an element partially or completely off-screen.
The order you define properties in does not matter. Remember, you do not need to specify every property! Note that a view may choose to only make only certain properties on a particular element themable!
Can be created as an extra.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- If only one axis is specified (and the other is zero), the other will be automatically calculated in accordance with the image's aspect ratio.
maxSize
- type: RESOLUTION_PAIR.- The image will be resized as large as possible so that it fits within this size and maintains its aspect ratio. Use this instead of
size
when you don't know what kind of image you're using so it doesn't get grossly oversized on one axis (e.g. with a game's image metadata).
- The image will be resized as large as possible so that it fits within this size and maintains its aspect ratio. Use this instead of
origin
- type: NORMALIZED_PAIR.- Where on the image
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the image exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the image
rotation
- type: FLOAT.- angle in degrees that the image should be rotated. Positive values will rotate clockwise, negative values will rotate counterclockwise.
rotationOrigin
- type: NORMALIZED_PAIR.- Point around which the image will be rotated. Defaults to
0.5 0.5
.
- Point around which the image will be rotated. Defaults to
path
- type: PATH.- Path to the image file. Most common extensions are supported (including .jpg, .png, and unanimated .gif).
default
- type: PATH.- Path to default image file. Default image will be displayed when selected game does not have an image.
tile
- type: BOOLEAN.- If true, the image will be tiled instead of stretched to fit its size. Useful for backgrounds.
color
- type: COLOR.- Multiply each pixel's color by this color. For example, an all-white image with
<color>FF0000</color>
would become completely red. You can also control the transparency of an image with<color>FFFFFFAA</color>
- keeping all the pixels their normal color and only affecting the alpha channel.
- Multiply each pixel's color by this color. For example, an all-white image with
visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- The size of the grid. Take care the selected tile can go out of the grid size, so don't position the grid too close to another element or the screen border.
margin
- type: RESOLUTION_PAIR. Margin between tiles.padding
- type: RESOLUTION_RECT.- NEW : Padding for displaying tiles.
autoLayout
- type: NORMALIZED_PAIR.- NEW : Number of column and rows in the grid (integer values).
autoLayoutSelectedZoom
- type: FLOAT.- NEW : Zoom factor to apply when a tile is selected.
gameImage
- type: PATH.- The default image used for games which doesn't have an image.
folderImage
- type: PATH.- The default image used for folders which doesn't have an image.
imageSource
- type: STRING.- Selects the image to display.
thumbnail
by default, can also be set toimage
ormarquee
.
- Selects the image to display.
scrollDirection
- type: STRING.vertical
by default, can also be set tohorizontal
. Not that inhorizontal
mod, the tiles are ordered from top to bottom, then from left to right.
centerSelection
- type: BOOLEAN.false
by default, whentrue
the selected tile will be locked to the center of the grid.
scrollLoop
- type: BOOLEAN.false
by default, whentrue
the grid will seamlessly loop around when scrolling reaches the end of the list. Only works whencenterSelection
istrue
.
animate
- type : BOOLEAN.true
by default, whenfalse
the grid scrolling will not be animated.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
size
- type: RESOLUTION_PAIR.- The size of the default gridtile is used to calculate how many tiles can fit in the imagegrid. If not explicitly set, the size of the selected gridtile is equal the size of the default gridtile * 1.2
padding
- type: RESOLUTION_PAIR.- The padding around the gridtile content. Default
16 16
. If not explicitly set, the selected tile padding will be equal to the default tile padding.
- The padding around the gridtile content. Default
imageColor
- type: COLOR.- The default tile image color and selected tile image color have no influence on each others.
backgroundImage
- type: PATH.- If not explicitly set, the selected tile background image will be the same as the default tile background image.
backgroundCornerSize
- type: RESOLUTION_PAIR.- The corner size of the ninepatch used for the tile background. Default is
16 16
.
- The corner size of the ninepatch used for the tile background. Default is
backgroundColor
- type: COLOR.- A shortcut to define both the center color and edge color at the same time. The default tile background color and selected tile background color have no influence on each others.
backgroundCenterColor
- type: COLOR.- Set the color of the center part of the ninepatch. The default tile background center color and selected tile background center color have no influence on each others.
backgroundEdgeColor
- type: COLOR.- Set the color of the edge parts of the ninepatch. The default tile background edge color and selected tile background edge color have no influence on each others.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- If only one axis is specified (and the other is zero), the other will be automatically calculated in accordance with the video's aspect ratio.
maxSize
- type: RESOLUTION_PAIR.- The video will be resized as large as possible so that it fits within this size and maintains its aspect ratio. Use this instead of
size
when you don't know what kind of video you're using so it doesn't get grossly oversized on one axis (e.g. with a game's video metadata).
- The video will be resized as large as possible so that it fits within this size and maintains its aspect ratio. Use this instead of
origin
- type: NORMALIZED_PAIR.- Where on the image
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the image exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the image
rotation
- type: FLOAT.- angle in degrees that the text should be rotated. Positive values will rotate clockwise, negative values will rotate counterclockwise.
rotationOrigin
- type: NORMALIZED_PAIR.- Point around which the text will be rotated. Defaults to
0.5 0.5
.
- Point around which the text will be rotated. Defaults to
delay
- type: FLOAT. Default is false.- Delay in seconds before video will start playing.
default
- type: PATH.- Path to default video file. Default video will be played when selected game does not have a video.
showSnapshotNoVideo
- type: BOOLEAN- If true, image will be shown when selected game does not have a video and no
default
video is configured.
- If true, image will be shown when selected game does not have a video and no
showSnapshotDelay
- type: BOOLEAN- If true, playing of video will be delayed for
delayed
seconds, when game is selected.
- If true, playing of video will be delayed for
visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
Can be created as an extra.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- Possible combinations:
0 0
- automatically size so text fits on one line (expanding horizontally).w 0
- automatically wrap text so it doesn't go beyondw
(expanding vertically).w h
- works like a "text box." Ifh
is non-zero andh
<=fontSize
(implying it should be a single line of text), text that goes beyondw
will be truncated with an elipses (...).
origin
- type: NORMALIZED_PAIR.- Where on the component
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the component exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the component
rotation
- type: FLOAT.- angle in degrees that the text should be rotated. Positive values will rotate clockwise, negative values will rotate counterclockwise.
rotationOrigin
- type: NORMALIZED_PAIR.- Point around which the text will be rotated. Defaults to
0.5 0.5
.
- Point around which the text will be rotated. Defaults to
text
- type: STRING.color
- type: COLOR.backgroundColor
- type: COLOR;fontPath
- type: PATH.- Path to a truetype font (.ttf).
fontSize
- type: RESOLUTION_FLOAT.- Size of the font as a percentage of screen height (e.g. for a value of
0.1
, the text's height would be 10% of the screen height).
- Size of the font as a percentage of screen height (e.g. for a value of
alignment
- type: STRING.- Valid values are "left", "center", or "right". Controls alignment on the X axis. "center" will also align vertically.
forceUppercase
- type: BOOLEAN. Draw text in uppercase.lineSpacing
- type: FLOAT. Controls the space between lines (as a multiple of font height). Default is 1.5.visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.origin
- type: NORMALIZED_PAIR.- Where on the component
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the component exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the component
selectorColor
- type: COLOR.- Color of the "selector bar."
selectorImagePath
- type: PATH.- Path to image to render in place of "selector bar."
selectorImageTile
- type: BOOLEAN.- If true, the selector image will be tiled instead of stretched to fit its size.
selectorHeight
- type: RESOLUTION_FLOAT.- Height of the "selector bar".
selectorOffsetY
- type: RESOLUTION_FLOAT.- Allows moving of the "selector bar" up or down from its computed position. Useful for fine tuning the position of the "selector bar" relative to the text.
selectedColor
- type: COLOR.- Color of the highlighted entry text.
primaryColor
- type: COLOR.- Primary color; what this means depends on the text list. For example, for game lists, it is the color of a game.
secondaryColor
- type: COLOR.- Secondary color; what this means depends on the text list. For example, for game lists, it is the color of a folder.
fontPath
- type: PATH.fontSize
- type: RESOLUTION_FLOAT.scrollSound
- type: PATH.- Sound that is played when the list is scrolled.
alignment
- type: STRING.- Valid values are "left", "center", or "right". Controls alignment on the X axis.
horizontalMargin
- type: RESOLUTION_FLOAT.- Horizontal offset for text from the alignment point. If
alignment
is "left", offsets the text to the right. Ifalignment
is "right", offsets text to the left. No effect ifalignment
is "center". Given as a percentage of the element's parent's width (same unit assize
's X value).
- Horizontal offset for text from the alignment point. If
forceUppercase
- type: BOOLEAN. Draw text in uppercase.lineSpacing
- type: FLOAT. Controls the space between lines (as a multiple of font height). Default is 1.5.zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.path
- type: PATH.visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
EmulationStation borrows the concept of "nine patches" from Android (or "9-Slices"). Currently the implementation is very simple and hard-coded to only use 48x48px images (16x16px for each "patch"). Check the data/resources
directory for some examples (button.png, frame.png).
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- Only one value is actually used. The other value should be zero. (e.g. specify width OR height, but not both. This is done to maintain the aspect ratio.)
origin
- type: NORMALIZED_PAIR.- Where on the component
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the component exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the component
rotation
- type: FLOAT.- angle in degrees that the rating should be rotated. Positive values will rotate clockwise, negative values will rotate counterclockwise.
rotationOrigin
- type: NORMALIZED_PAIR.- Point around which the rating will be rotated. Defaults to
0.5 0.5
.
- Point around which the rating will be rotated. Defaults to
filledPath
- type: PATH.- Path to the "filled star" image. Image must be square (width equals height).
unfilledPath
- type: PATH.- Path to the "unfilled star" image. Image must be square (width equals height).
color
- type: COLOR.- Multiply each pixel's color by this color. For example, an all-white image with
<color>FF0000</color>
would become completely red. You can also control the transparency of an image with<color>FFFFFFAA</color>
- keeping all the pixels their normal color and only affecting the alpha channel.
- Multiply each pixel's color by this color. For example, an all-white image with
visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
pos
- type: RESOLUTION_PAIR.size
- type: RESOLUTION_PAIR.- Possible combinations:
0 0
- automatically size so text fits on one line (expanding horizontally).w 0
- automatically wrap text so it doesn't go beyondw
(expanding vertically).w h
- works like a "text box." Ifh
is non-zero andh
<=fontSize
(implying it should be a single line of text), text that goes beyondw
will be truncated with an elipses (...).
origin
- type: NORMALIZED_PAIR.- Where on the component
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the component exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the component
rotation
- type: FLOAT.- angle in degrees that the text should be rotated. Positive values will rotate clockwise, negative values will rotate counterclockwise.
rotationOrigin
- type: NORMALIZED_PAIR.- Point around which the text will be rotated. Defaults to
0.5 0.5
.
- Point around which the text will be rotated. Defaults to
color
- type: COLOR.backgroundColor
- type: COLOR;fontPath
- type: PATH.- Path to a truetype font (.ttf).
fontSize
- type: RESOLUTION_FLOAT.- Size of the font as a percentage of screen height (e.g. for a value of
0.1
, the text's height would be 10% of the screen height).
- Size of the font as a percentage of screen height (e.g. for a value of
alignment
- type: STRING.- Valid values are "left", "center", or "right". Controls alignment on the X axis. "center" will also align vertically.
forceUppercase
- type: BOOLEAN. Draw text in uppercase.lineSpacing
- type: FLOAT. Controls the space between lines (as a multiple of font height). Default is 1.5.visible
- type: BOOLEAN.- If true, component will be rendered, otherwise rendering will be skipped. Can be used to hide elements from a particular view.
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
displayRelative
- type: BOOLEAN. Renders the datetime as a a relative string (ex: 'x days ago')format
- type: STRING. Specifies format for rendering datetime, according to thestrftime
conversion format (see https://man7.org/linux/man-pages/man3/strftime.3.html). Common formating placeholders(see the link above for all available sequences):- %Y: The year, including the century (1900)
- %y: The year as a decimal number without a century
- %m: The month number [01,12]
- %d: The day of the month [01,31]
- %H: The hour (24-hour clock) [00,23]
- %M: The minute [00,59]
- %S: The second [00,59]
- %R: The time in 24-hour notation
- %B: The full month name
- %b: Abbreviated month name
path
- type: PATH.- Path to the sound file. Only .wav files are currently supported.
pos
- type: RESOLUTION_PAIR. Default is "0.012 0.9515"origin
- type: NORMALIZED_PAIR.- Where on the component
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the component exactly in the middle of the screen.
- Where on the component
textColor
- type: COLOR. Default is 777777FF.iconColor
- type: COLOR. Default is 777777FF.fontPath
- type: PATH.fontSize
- type: RESOLUTION_FLOAT.
type
- type: STRING.- Sets the scoll direction of the carousel.
- Accepted values are "horizontal", "vertical", "horizontal_wheel" or "vertical_wheel".
- Default is "horizontal".
size
- type: RESOLUTION_PAIR. Default is "1 0.2325"pos
- type: RESOLUTION_PAIR. Default is "0 0.38375".origin
- type: NORMALIZED_PAIR.- Where on the carousel
pos
refers to. For example, an origin of0.5 0.5
and apos
of0.5 0.5
would place the carousel exactly in the middle of the screen. If the "POSITION" and "SIZE" attributes are themable, "ORIGIN" is implied.
- Where on the carousel
color
- type: COLOR.- Controls the color of the carousel background.
- Default is FFFFFFD8
logoSize
- type: NORMALIZED_PAIR. Default is "0.25 0.155"logoScale
- type: FLOAT.- Selected logo is increased in size by this scale
- Default is 1.2
logoRotation
- type: FLOAT.- Angle in degrees that the logos should be rotated. Value should be positive.
- Default is 7.5
- This property only applies when
type
is "horizontal_wheel" or "vertical_wheel".
logoRotationOrigin
- type: NORMALIZED_PAIR.- Point around which the logos will be rotated. Defaults to
-5 0.5
. - This property only applies when
type
is "horizontal_wheel" or "vertical_wheel".
- Point around which the logos will be rotated. Defaults to
logoAlignment
- type: STRING.- Sets the alignment of the logos relative to the carousel.
- Accepted values are "top", "bottom" or "center" when
type
is "horizontal" or "horizontal_wheel". - Accepted values are "left", "right" or "center" when
type
is "vertical" or "vertical_wheel". - Default is "center"
maxLogoCount
- type: FLOAT.- Sets the number of logos to display in the carousel.
- Default is 3
zIndex
- type: FLOAT.- z-index value for component. Components will be rendered in order of z-index value from low to high.
The help system is a special element that displays a context-sensitive list of actions the user can take at any time. You should try and keep the position constant throughout every screen. Keep in mind the "default" settings (including position) are used whenever the user opens a menu.