-
Notifications
You must be signed in to change notification settings - Fork 423
Setting up compiled resource stores
This tutorial assumes you have completed setting up your first project.
- Adding your resources library to the Resource Store
- Default resources structure
- Accessing resources from the resource store
The first time you set up your project, you will need to add a DllResourceStore
with the path to a resources library. This will enable you to load resources from the specified resource library at run-time, which then in turn allows caching to occur in the ResourceStore
. A few important resource stores are already created in the base Game
class which all game instances should inherit.
By default, your resources will be compiled into a dll with your project name and copied into your output directory. This is convenient for our purposes, as all we need to do now is add a DllResourceStore
to it using Resources.AddStore()
in our BackgroundDependencyLoader
method inside of our game class.
[BackgroundDependencyLoader]
private void load()
{
Resources.AddStore(new DllResourceStore(@"AwesomeGame.dll"));
}
Game
will automatically create the following stores that point to the respective paths for each store:
-
/Textures
(TextureStore
) -
/Tracks
(AudioManager.Tracks
) -
/Samples
(AudioManager.Samples
) -
/Shaders
(ShaderManager
) -
/Fonts
(FontStore
)
To add to these stores, simply add resources to the respective directories and specify them as EmbeddedResources
inside your .csproj
.
For example, to include your own Textures folder and all .png files inside of it recursively:
<ItemGroup>
<EmbeddedResource Include="Textures\**\*.png" />
</ItemGroup>
osu!framework loads Open Sans into the FontStore
by default. If you find that this is insufficient for your use, you may add your own fonts to the FontStore
by adding your own GlyphStore
s. This is preferably done at the initialization of your game within the BackgroundDependencyLoader
method inside your game class by invoking the following:
Fonts.AddStore(new GlyphStore(Resources, @"Fonts/AwesomeFont"));
This will cache our hypothetical "AwesomeFont" for use in any SpriteText
, which can be set using the Font
property.
After having added your own resources, you can now access them via dependency injection. You will need to specify the type of store you're trying to inject in the method parameters. For example, if I have a texture named awesomeTexture.png
inside of my Textures
folder, I can load it like this:
[BackgroundDependencyLoader]
private void load(TextureStore store)
{
texture = store.Get(@"awesomeTexture");
}
osu!framework will then load the resources for the first time if they have not been cached yet.
To retrieve other resources from other resource stores, simply specify the type of resource store you wish to retrieve from the cache via the load() method's parameters. For example, to retrieve tracks from the audio store, the following code will be sufficient.
ITrackStore tracks = null!;
[BackgroundDependencyLoader]
private void load(AudioManager audio)
{
tracks = audio.Tracks;
}
- Create your first project
- Learning framework key bindings
- Adding resource stores
- Adding custom key bindings
- Adding custom fonts