A screen generarly consists of 4 separate elements, and 3 special transitional elements, which are its layers. These can contain any kind of object, so they can be Lua scripts, images, video, you name it. These follow a draw order rule to display them (Marked red are the transition-specific layers):
To create a file for a specific layer, just name the file as [ScreenName] [layer kind], so for example a Lua file that will control the Overlay layer from ScreenTitleMenu.
ScreenTitleMenu overlay.lua
An important thing to mention with screen layers is: every layer MUST return a table. This is needed so the screen manager can create the screen, so either an empty table or an ActorFrame with any kind of content will do. For in-depth information on how to create an ActorFrame base, please check:
Due to this draw order, keep in mind that objects created on higher levels will always be shown first before the others.
This layering rule also has rules on how objects behave on those layers, with Decorations being the one more reserved for specific elements.
The lowest drawn layer, being the first drawn. Can be used to elements that will contain visual glare for movement. A rule for this layer is its method for loading, which is cached. This means that any moment that changes are applied, they will not be shown until the user goes to a different screen that does not contain the same background file, or reloading using the "Reload Background Screens" option on OutFox's Creator Menu.
The middle layers, where most objects will reside. This can be used for main elements that the user can interact with, or crucial information. No special rules are in these layers, so they can used for all general Lua scripting.
A specifically-visual layer, where objects can be placed for decorations. Most actions are limited on this layer:
Pure visual layers that serve as entrance, exit and backing out of a screen respectively.
They are run as soon as the screen has to perform a change that will end up unloading itself.
StartTransitioningCommand. Using OnCommand or InitCommand willWith that example, let's add a background!