16 unstable releases (3 breaking)

new 0.5.1 Jan 6, 2025
0.5.0 Dec 22, 2024
0.4.2 Dec 1, 2024
0.4.1 Nov 25, 2024
0.3.2 Jul 28, 2024

#64 in Game dev

Download history 59/week @ 2024-09-18 30/week @ 2024-09-25 17/week @ 2024-10-02 15/week @ 2024-10-09 6/week @ 2024-10-16 9/week @ 2024-10-30 111/week @ 2024-11-06 157/week @ 2024-11-13 156/week @ 2024-11-20 153/week @ 2024-11-27 42/week @ 2024-12-04 28/week @ 2024-12-11 112/week @ 2024-12-18 31/week @ 2024-12-25 141/week @ 2025-01-01

316 downloads per month

MIT license

175KB
3.5K SLoC

bevy_ecs_tiled

Crates.io docs license Crates.io Following released Bevy versions

bevy_ecs_tiled is a Bevy plugin for working with 2D tilemaps created with the Tiled map editor.

It relies upon:

Each tile or object is represented by a Bevy entity:

  • layers are children of the tilemap entity
  • tiles and objects are children of layers

Visibility and Transform are inherited: map -> layer -> tile / object

screenshot

Features

  • Orthogonal, isometric and hexagonal maps
  • Finite and infinite maps
  • Embedded and separate tileset
  • Easily spawn / despawn maps
  • Animated tiles
  • Rapier and Avian colliders added from tilesets and object layers (rapier or avian feature flag)
  • Tiled custom properties mapped to Bevy components (user_properties feature flag)

Documentation

This crate is documented in three places:

There is notably a FAQ that will hopefully answer most of your questions.

Good reading!

Getting started

Add dependencies to your Cargo.toml file:

[dependencies]
bevy = "0.15"
bevy_ecs_tiled = "0.5"
bevy_ecs_tilemap = "0.15"

Then add the plugin to your app and spawn a map:

use bevy::prelude::*;
use bevy_ecs_tiled::prelude::*;
use bevy_ecs_tilemap::prelude::*;

fn main() {
    App::new()
        // Add Bevy default plugins
        .add_plugins(DefaultPlugins)
        // Add bevy_ecs_tilemap plugin
        .add_plugins(TilemapPlugin)
        // Add bevy_ecs_tiled plugin
        .add_plugins(TiledMapPlugin::default())
        // Add our startup function to the schedule and run the app
        .add_systems(Startup, startup)
        .run();
}

fn startup(mut commands: Commands, asset_server: Res<AssetServer>) {
    // Spawn a 2D camera
    commands.spawn(Camera2d);

    // Load the map: ensure any tile / tileset paths are relative to assets/ folder
    let map_handle: Handle<TiledMap> = asset_server.load("map.tmx");

    // Spawn the map with default options
    commands.spawn(TiledMapHandle(map_handle));
}

Basically, all you have to do is to spawn a TiledMapHandle with the map asset you want to load (the map.tmx file). Note that this map asset should be in your local assets/ folder, as well as required dependencies (for instance, associated tilesets).

You can tweak how to load the map by adding various components on the map entity, notably:

You can browse the examples for more advanced use cases.

Bevy Compatibility

bevy bevy_ecs_tilemap bevy_ecs_tiled
0.15 0.15 0.5
0.14 0.14 0.3 - 0.4
0.13 main@e4f3cc6 branch 0.2
0.12 0.12 0.1

Assets credits

Contributing

If you can contribute, please do!

If you would like to contribute but don't know where to start, read this section in the book.

LICENSE

This work is licensed under the MIT license.

SPDX-License-Identifier: MIT

Dependencies

~44–78MB
~1.5M SLoC