Bevy LDtk

Crates.io Docs.rs Katharos License

A [Bevy] plugin for loading [LDtk] 2D tile maps.

screenshot

( Screenshot assets from the CanariPack 8BIT TopDown art pack by Johan Vinet )

Usage

```rust use bevy::prelude::; use bevy_ldtk::;

fn main() { App::build() .addplugins(DefaultPlugins) .addplugin(LdtkPlugin) .addstartupsystem(setup.system()) .run(); }

fn setup(commands: &mut Commands, assetserver: Res) { commands // Spawn a camera .spawn(Camera2dBundle::default()) // Spawn a map bundle .spawn(LdtkMapBundle { // Specify the path to the map asset to load map: assetserver.load("map1.ldtk"), config: LdtkMapConfig { // Automatically set the clear color to the LDtk background color setclearcolor: true, // You can specify a scale or leave it set to 1 for 1 to 1 pixel size scale: 3.0, // Set which level to load out of the map or leave it to 0 for the default level level: 0, }, ..Default::default() }); } ```

Layers

When the map layers are spawned, the bottommost layer is spawned at the transform coordinate of the LdtkMapBundle's Transform component. Each layer after the bottom layer is placed one unit higher on the Z axis. To have your sprites for players, etc. appear on top of the rendered map, their Z axis translation must be higher than the map transform + the layer number that you want it to appear above.

Running the Example

bash cargo run --example display_map

You can also copy your own LDtk maps into the assets folder and then run them by specifying the map file name and the level. For instance, this will load the second level from map2.ldtk:

bash cargo run --example display_map -- map2.ldtk 1

Bevy Versions

| Bevy Version | Plugin Version | | ------------ | ---------------------------------------------- | | 0.4 | 0.2 | | master | with the bevy-unstable feature ( see below ) |

Using Bevy From Master

You can use this crate with Bevy master by adding a patch to your Cargo.toml and by adding the bevy-unstable feature to this crate:

```toml [dependencies]

Bevy version must be set to "0.4" and we will

override it in the patch below.

bevy = "0.4" bevy_ldtk = { version = "0.2", features = ["bevy-unstable"] }

[patch.crates-io] bevy = { git = "https://github.com/bevyengine/bevy.git" } ```

Note that as Bevy master may or may not introduce breaking API changes, this crate may or may not compile when using the bevy-unstable feature.

Features

Caveats

This plugin is in relatively early stages of development, and while it can load many basic maps, there are some caveats:

If you run into anything that isn't supported that you want to use in your game open an issue or PR to help prioritize what gets implemented.

License

Bevy LDtk is licensed under the Katharos License which places certain restrictions on what you are allowed to use it for. Please read and understand the terms before using Bevy LDtk for your project.