-
-
Notifications
You must be signed in to change notification settings - Fork 560
Assets
This page will familiarize you with what, where, when and how regarding game assets. Most of the asset loading is provided by JavaFX. FXGL simply wraps the API and brings them all together in AssetLoader
.
There is a special directory called assets
places under src
if you are not following the Maven directory structure. If you are, then it is placed under src/main/resources
. This is necessary for the build process to easily pick up assets and package them when you distribute your game in an executable. This also works when you are developing or debugging your game in the IDE.
After obtaining the reference to the asset loader (getAssetLoader()
) call load*
, where *
can be Texture, Music, Sound, etc. Below you can find the supported types of assets:
Note: some assets support more formats than listed here, e.g. Texture can be loaded as bmp
, however, this is the standardized list and assets are expected to be of that format.
Directory: assets/textures/
Format: jpg
, png
Description: any image you want to display will fall under this category.
Directory: assets/music/
Format: mp3
Description: long audio files, e.g. background music or recorded dialogues.
Directory: assets/sounds/
Format: wav
Description: very short audio files, e.g. sound effects that commonly occur.
Directory: assets/text/
Format: txt
Description: anything in textual format, e.g. text dialogues, in-game item names.
Directory: assets/scripts/
Format: js
Description: valid scripts that can be run, e.g. AI scripts or behavior, dynamic code snippets.
Directory: assets/properties/
Format: properties
Description: essentially Java resource bundle, a collection of simple key values, useful for system configuration.
Directory: assets/kv/
Format: kv
Description: similar to properties but the file gets parsed into your own custom data structure, useful for entity configuration.
Directory: assets/ai/
Format: tree
Description: this is a standard gdxAI Behavior Tree.
Directory: assets/data/
Format: anything
Description: this is where you store your own asset type that can be serialized with the default Java serialization mechanism.
Directory: anywhere under src
or if using Maven src/main/resources
Format: anything
Description: your own asset type that is serialized by you. Basically the loader simply gives you an InputStream
.