-
-
Notifications
You must be signed in to change notification settings - Fork 169
Managing Your Assets
To use assets in kha first you need to include them into your project (khafile.js) so khamake can find them during the build stage. By default the folder Assets is created and linked in khafile.js, but you can add other folders by adding project.addAssets('OtherAssetFolder/**'); in your khafiles.js.
One of the responsibilities of khamake beside building your project, is to transform your assets into more optimize format depending on your target. So for example if you add a .wav in your assets folder and you want to build for windows or mac, khamake will generate a .ogg file. If you target html5 and add the --ffmpeg command (node Kha/make html5 --ffmpeg "/path/to/ffmpeg.exe need the .exe) it will generate a .mp4 or in flash a .mp3. The same analogy works for image files.
khamake expects the assets to be in this formats:
- Images: png, jpg, hdr
- Sounds: wav (sample rate:44100Hz 16 bit)
- Videos: mp4
Any other format will not be changed and will be available in your code through Assets.blobs as Blob.
Before you can use an asset you need to load it into memory, to do so you need to use one of the loading method under the class Assets. If you want to load everything you can call loadEverything, but its only recommended if you don't use many assets, otherwise you will fill your memory.
To use your assets after they are loaded into memory, you just need to call Assets..nameOfAsset.
Every time you add more assets you need to call khamake again.
The names shown in Assets are loaded using a macro and a json file in the "-resources" folder, so all assets names must respect variable/function naming rules.
Normally khamake will flatten all assets paths and dump everything in the root folder.
This will also cause issues if you have multiple assets with the same name in different directories.
The following won't work as khamake will complain about duplicate tiles.png
.
/assets
/map1
tiles.png
/map2
tiles.png
To prevent this issue and keep the paths, add assets like this:
project.addAssets('assets/**', { nameBaseDir: 'assets', destination: '{dir}/{name}', name: '{dir}/{name}' });
You can now access them with kha.Assets.images.map1_tiles
or kha.Assets.images.map2_tiles
The separator for subdirectories is an underscore _
.
A minor issue with this procedure is that assets in the root folder will get a superfluous underscore added, so keep that in mind until it's fixed.
/assets/parrot.png
is accessed with
kha.Assets.images._parrot
It's possible to modify your assets at build time!
project.addAssets('assets/**', { scale: 0.5 });
- Introduction
- Getting Started
- Breaking Changes
- FAQ
- System targets
- Graphics targets
- Documentation
- API package descriptions