Crates.io | bevy_simple_tilemap |
lib.rs | bevy_simple_tilemap |
version | 0.15.0 |
source | src |
created_at | 2021-05-22 12:24:32.111466 |
updated_at | 2024-07-04 18:58:47.191328 |
description | Refreshingly simple tilemap implementation for Bevy Engine. |
homepage | |
repository | https://github.com/forbjok/bevy_simple_tilemap.git |
max_upload_size | |
id | 400802 |
size | 177,622 |
Refreshingly simple tilemap implementation for Bevy Engine.
The main reason I started this was because I felt the existing tilemap implementations for Bevy were needlessly complicated to use when all you want to do is to as quickly and simply as possible render a grid of tiles to the screen, often exposing internal implementation details such as chunks to the user.
fn setup(
asset_server: Res<AssetServer>,
mut commands: Commands,
mut texture_atlases: ResMut<Assets<TextureAtlas>>,
) {
// Load tilesheet texture and make a texture atlas from it
let texture = asset_server.load("textures/tilesheet.png");
let atlas = TextureAtlasLayout::from_grid(vec2(16.0, 16.0), 4, 1, Some(vec2(1.0, 1.0)), None);
let texture_atlas = texture_atlases.add(atlas);
// Set up tilemap
let tilemap_bundle = TileMapBundle {
texture,
atlas: TextureAtlas {
layout: texture_atlas,
..Default::default()
},
..Default::default()
};
// Spawn tilemap
commands.spawn(tilemap_bundle);
}
tilemap.set_tile(ivec3(0, 0, 0), Some(Tile { sprite_index: 0, color: Color::WHITE }));
// List to store set tile operations
let mut tiles: Vec<(IVec3, Option<Tile>)> = Vec::new();
tiles.push((ivec3(0, 0, 0), Some(Tile { sprite_index: 0, color: Color::WHITE })));
tiles.push((ivec3(1, 0, 0), Some(Tile { sprite_index: 1, color: Color::WHITE })));
// Perform tile update
tilemap.set_tiles(tiles);