feat: make camera follow player
Former-commit-id: d13b9416c74308eaf9df81b431b82152b7a20510
This commit is contained in:
parent
89a1054fbe
commit
6fb06a102e
3 changed files with 33 additions and 19 deletions
11
src/main.rs
11
src/main.rs
|
@ -55,7 +55,7 @@ fn main() {
|
||||||
.init_resource::<UiState>()
|
.init_resource::<UiState>()
|
||||||
.init_resource::<OpenWindows>()
|
.init_resource::<OpenWindows>()
|
||||||
.add_systems(Startup, (setup, setup_ui))
|
.add_systems(Startup, (setup, setup_ui))
|
||||||
.add_systems(Update, (render_ui, movement))
|
.add_systems(Update, (render_ui, movement, camera_follow))
|
||||||
.run();
|
.run();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,6 +69,15 @@ fn setup(mut commands: Commands, asset_server: Res<AssetServer>) {
|
||||||
tonemapping: Tonemapping::TonyMcMapface,
|
tonemapping: Tonemapping::TonyMcMapface,
|
||||||
..default()
|
..default()
|
||||||
});
|
});
|
||||||
|
commands.spawn(
|
||||||
|
SpriteBundle {
|
||||||
|
texture: asset_server.load("player/player-4x.png"),
|
||||||
|
transform: Transform {
|
||||||
|
scale: Vec3::splat(0.2),
|
||||||
|
..default()
|
||||||
|
},
|
||||||
|
..default()
|
||||||
|
});
|
||||||
commands.spawn((
|
commands.spawn((
|
||||||
SpriteBundle {
|
SpriteBundle {
|
||||||
texture: asset_server.load("player/player-4x.png"),
|
texture: asset_server.load("player/player-4x.png"),
|
||||||
|
|
|
@ -18,10 +18,9 @@ pub struct Player {
|
||||||
pub fn movement(
|
pub fn movement(
|
||||||
time: Res<Time>,
|
time: Res<Time>,
|
||||||
keys: Res<Input<KeyCode>>,
|
keys: Res<Input<KeyCode>>,
|
||||||
mut windows: Query<&mut Window>,
|
mut player: Query<(&Player, &mut Transform)>,
|
||||||
mut query: Query<(&Player, &mut Transform)>,
|
|
||||||
) {
|
) {
|
||||||
let (player, mut transform) = query.single_mut();
|
let (player, mut transform) = player.single_mut();
|
||||||
|
|
||||||
let mut rotation_factor = 0.;
|
let mut rotation_factor = 0.;
|
||||||
let mut movement_factor = 0.;
|
let mut movement_factor = 0.;
|
||||||
|
@ -31,13 +30,13 @@ pub fn movement(
|
||||||
movement_factor += 1.;
|
movement_factor += 1.;
|
||||||
} else if keys.pressed(KeyCode::S) {
|
} else if keys.pressed(KeyCode::S) {
|
||||||
movement_factor -= 1.;
|
movement_factor -= 1.;
|
||||||
}
|
}
|
||||||
|
|
||||||
if keys.pressed(KeyCode::A) {
|
if keys.pressed(KeyCode::A) {
|
||||||
rotation_factor += 1.;
|
rotation_factor += 1.;
|
||||||
} else if keys.pressed(KeyCode::D) {
|
} else if keys.pressed(KeyCode::D) {
|
||||||
rotation_factor -= 1.;
|
rotation_factor -= 1.;
|
||||||
}
|
}
|
||||||
|
|
||||||
if keys.pressed(KeyCode::Space) {
|
if keys.pressed(KeyCode::Space) {
|
||||||
blink_factor += 4.;
|
blink_factor += 4.;
|
||||||
|
@ -76,12 +75,18 @@ pub fn movement(
|
||||||
|
|
||||||
// Update the player translation with the translation
|
// Update the player translation with the translation
|
||||||
transform.translation += movement_direction * movement_distance;
|
transform.translation += movement_direction * movement_distance;
|
||||||
|
}
|
||||||
// Define the bounds of play (the window size)
|
|
||||||
let window = windows.single_mut();
|
// Function to make the camera follow the plaeyr
|
||||||
let bounds = Vec3::from((
|
pub fn camera_follow(
|
||||||
Vec2::new(window.resolution.width(), window.resolution.height()) / 2.,
|
mut player: Query<(&Player, &mut Transform)>,
|
||||||
0.,
|
mut cameras: Query<&mut Transform, (With<Camera>, Without<Player>)>,
|
||||||
));
|
) {
|
||||||
transform.translation = transform.translation.min(bounds).max(-bounds);
|
let (_, transform) = player.single_mut();
|
||||||
|
let pos = transform.translation;
|
||||||
|
|
||||||
|
for mut camera_transform in &mut cameras {
|
||||||
|
camera_transform.translation.x = pos.x;
|
||||||
|
camera_transform.translation.y = pos.y;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
10
src/ui.rs
10
src/ui.rs
|
@ -2,8 +2,8 @@ use bevy::prelude::*;
|
||||||
|
|
||||||
use bevy_egui::{egui, EguiContexts};
|
use bevy_egui::{egui, EguiContexts};
|
||||||
|
|
||||||
use crate::HYPERNOVA;
|
|
||||||
use crate::Player;
|
use crate::Player;
|
||||||
|
use crate::HYPERNOVA;
|
||||||
|
|
||||||
// Define UI resources
|
// Define UI resources
|
||||||
#[derive(Default, Resource)]
|
#[derive(Default, Resource)]
|
||||||
|
@ -111,10 +111,10 @@ pub fn render_ui(
|
||||||
ui.visuals_mut().menu_rounding = egui::Rounding::ZERO;
|
ui.visuals_mut().menu_rounding = egui::Rounding::ZERO;
|
||||||
ui.visuals_mut().selection.bg_fill = purple;
|
ui.visuals_mut().selection.bg_fill = purple;
|
||||||
|
|
||||||
let health = egui::widgets::ProgressBar::new(player.health)
|
let health =
|
||||||
.desired_width(window_width / 10.);
|
egui::widgets::ProgressBar::new(player.health).desired_width(window_width / 10.);
|
||||||
let stamina = egui::widgets::ProgressBar::new(player.stamina)
|
let stamina =
|
||||||
.desired_width(window_width / 10.);
|
egui::widgets::ProgressBar::new(player.stamina).desired_width(window_width / 10.);
|
||||||
|
|
||||||
egui::Grid::new("Stats")
|
egui::Grid::new("Stats")
|
||||||
.spacing(egui::Vec2::new(20., 10.))
|
.spacing(egui::Vec2::new(20., 10.))
|
||||||
|
|
Reference in a new issue