Bevy Heterogenous Texture Atlas Loader allows you to load heterogenous texture atlases according to a RON file manifest.
Suports Bevy 0.6 #
Add the TextureAtlasManifestLoaderPlugin
to your Bevy App.
Load the texture atlas manifest using the asset server:
rust
let manifest: Handle<TextureAtlasManifest> = asset_server.load("manifest.ron");
The plugin will then load the atlas image and create the TextureAtlas asset automatically.
Once the manifest is loaded, the handle can be accessed from the .atlas
field,
or directly using the asset path "manifest.ron#texture_atlas"
like so:
rust
fn some_system(
assets: Res<Assets<TextureAtlas>>,
...
) {
let atlas = assets.get("manifest.ron#texture_atlas").unwrap();
...
);
#
Given a sprite sheet with irregular sized and positioned sprites.
First create a manifest.ron
manifest file in your assets folder
(
path: "example.png",
width: 256,
height: 256,
sprites: Sprites ([
(
x: 18,
y: 19,
w: 46,
h: 48
),
(
x: 93,
y: 108,
w: 32,
h: 31
),
(
x: 176,
y: 34,
w: 20,
h: 34
),
])
)
Alternatively, you can give each sprite a unique name that can be used to look
up their TextureAtlas index.
(
path: "example.png",
width: 256,
height: 256,
sprites: NamedSprites ([
(
name: "yellow",
x: 18,
y: 19,
w: 46,
h: 48
),
(
name: "face",
x: 93,
y: 108,
w: 32,
h: 31
),
(
name: "patches",
x: 176,
y: 34,
w: 20,
h: 34
),
])
)
manifest.ron
.name: ""
to skip naming a sprite in a NamedSprites
listAdd this crate's dependency to your project's Cargo.toml
[dependencies]
section
bevy_heterogeneous_texture_atlas_loader = "0.2"
Write the app
```rust use bevy::prelude::; use bevy_heterogeneous_texture_atlas_loader::;
fn setup(
mut commands: Commands,
assetserver: Res
fn onmanifestloaded(
mut commands: Commands,
mut events: EventReader
fn main() { App::new() .addplugins(DefaultPlugins) .addplugin(TextureAtlasManifestLoaderPlugin) .addstartupsystem(setup) .addsystem(onmanifest_loaded) .run(); } ```
Result