use std::ops::Range;
use bevy::{math::uvec2, prelude::*, window::WindowResolution};
use bevy_simple_tilemap::prelude::*;
fn main() {
App::new()
.add_plugins(
DefaultPlugins
.set(WindowPlugin {
primary_window: Some(Window {
resolution: WindowResolution::new(1280, 720).with_scale_factor_override(1.0),
..Default::default()
}),
..default()
})
.set(ImagePlugin::default_nearest()),
)
.add_plugins(SimpleTileMapPlugin)
.add_systems(Startup, setup)
.add_systems(Update, (input_system, update_tiles_system))
.run();
}
fn input_system(
mut camera_transform_query: Query<&mut Transform, With<Camera2d>>,
mut tilemap_visible_query: Query<&mut Visibility, With<TileMap>>,
keyboard_input: Res<ButtonInput<KeyCode>>,
time: Res<Time>,
) {
const MOVE_SPEED: f32 = 1000.0;
const ZOOM_SPEED: f32 = 10.0;
if let Some(mut tf) = camera_transform_query.iter_mut().next() {
if keyboard_input.pressed(KeyCode::KeyX) {
tf.scale -= Vec3::splat(ZOOM_SPEED) * time.delta_secs();
} else if keyboard_input.pressed(KeyCode::KeyZ) {
tf.scale += Vec3::splat(ZOOM_SPEED) * time.delta_secs();
}
if keyboard_input.pressed(KeyCode::KeyA) {
tf.translation.x -= MOVE_SPEED * time.delta_secs();
} else if keyboard_input.pressed(KeyCode::KeyD) {
tf.translation.x += MOVE_SPEED * time.delta_secs();
}
if keyboard_input.pressed(KeyCode::KeyS) {
tf.translation.y -= MOVE_SPEED * time.delta_secs();
} else if keyboard_input.pressed(KeyCode::KeyW) {
tf.translation.y += MOVE_SPEED * time.delta_secs();
}
if keyboard_input.just_pressed(KeyCode::KeyV) {
let mut visibility = tilemap_visible_query.iter_mut().next().unwrap();
if *visibility == Visibility::Hidden {
*visibility = Visibility::Visible;
} else {
*visibility = Visibility::Hidden;
}
}
}
}
fn update_tiles_system(mut query: Query<&mut TileMap>, mut count: Local<u32>) {
const WIDTH: i32 = 1024;
const HEIGHT: i32 = 1024;
const X_RANGE: Range<i32> = -(WIDTH / 2)..(WIDTH / 2);
const Y_RANGE: Range<i32> = -(HEIGHT / 2)..(HEIGHT / 2);
*count += 1;
for mut tilemap in query.iter_mut() {
let mut tiles: Vec<(IVec3, Option<Tile>)> = Vec::with_capacity((WIDTH * HEIGHT) as usize);
let mut i = *count % 4;
for y in Y_RANGE {
let sprite_index = i % 4;
for x in X_RANGE {
tiles.push((
IVec3::new(x, y, 0),
Some(Tile {
sprite_index,
..Default::default()
}),
));
}
i += 1;
}
tilemap.set_tiles(tiles);
}
}
fn setup(
asset_server: Res<AssetServer>,
mut commands: Commands,
mut texture_atlases: ResMut<Assets<TextureAtlasLayout>>,
) {
let image = asset_server.load("textures/tilesheet.png");
let atlas = TextureAtlasLayout::from_grid(uvec2(16, 16), 4, 1, Some(uvec2(1, 1)), None);
let atlas_handle = texture_atlases.add(atlas);
commands.spawn(Camera2d::default());
commands.spawn((
TileMap::new(image, atlas_handle),
Transform {
scale: Vec3::splat(1.0),
translation: Vec3::new(-640.0, -360.0, 0.0),
..Default::default()
},
));
}