improved boost logic and hud
This commit is contained in:
parent
68f90199a7
commit
7836d5e889
@ -1,6 +1,6 @@
|
|||||||
use raylib::prelude::*;
|
use raylib::prelude::*;
|
||||||
|
|
||||||
use crate::gamecore::GameCore;
|
use crate::{gamecore::GameCore, pallette::TRANSLUCENT_WHITE_96};
|
||||||
|
|
||||||
pub fn render_hud(
|
pub fn render_hud(
|
||||||
draw_handle: &mut RaylibDrawHandle,
|
draw_handle: &mut RaylibDrawHandle,
|
||||||
@ -8,35 +8,94 @@ pub fn render_hud(
|
|||||||
window_center: Vector2,
|
window_center: Vector2,
|
||||||
) {
|
) {
|
||||||
// Get the relevant data
|
// Get the relevant data
|
||||||
let breath = game_core.player.breath_percent;
|
|
||||||
let dist_from_player_to_end = game_core
|
let dist_from_player_to_end = game_core
|
||||||
.player
|
.player
|
||||||
.position
|
.position
|
||||||
.distance_to(game_core.world.end_position);
|
.distance_to(game_core.world.end_position);
|
||||||
let dist_from_start_to_end = Vector2::zero().distance_to(game_core.world.end_position);
|
let dist_from_start_to_end = Vector2::zero().distance_to(game_core.world.end_position);
|
||||||
let progress = (dist_from_start_to_end - dist_from_player_to_end) / dist_from_start_to_end;
|
let progress = ((dist_from_start_to_end - dist_from_player_to_end) / dist_from_start_to_end)
|
||||||
|
.clamp(0.0, 1.0);
|
||||||
|
|
||||||
// Render the base of the progress bar
|
// Determine the progress slider position
|
||||||
// let progress_bar_rect = Rectangle {
|
let slider_bound_height = 20.0;
|
||||||
// x: 20.0,
|
let progress_slider_position = Vector2 {
|
||||||
// y: (window_center.y * 2.0) - 20.0 - 40.0,
|
x: window_center.x * 2.0,
|
||||||
// width: (window_center.x * 2.0) - 40.0,
|
y: (((window_center.y * 2.0) - (slider_bound_height * 2.0)) * progress)
|
||||||
// height: 40.0,
|
+ slider_bound_height,
|
||||||
// };
|
};
|
||||||
// draw_handle.draw_rectangle_rec(progress_bar_rect, Color::BLUE);
|
|
||||||
// draw_handle.draw_rectangle_lines_ex(progress_bar_rect, 6, Color::WHITE);
|
|
||||||
|
|
||||||
// // Render the slider of the progress bar
|
// Render the base of the slider
|
||||||
// let progress_bar_slider = Rectangle {
|
draw_handle.draw_rectangle(
|
||||||
// x: (((window_center.x * 2.0) - 40.0) * progress.abs().clamp(0.0, 1.0)) + 10.0,
|
(progress_slider_position.x - slider_bound_height) as i32,
|
||||||
// y: (window_center.y * 2.0) - 20.0 - 50.0,
|
(progress_slider_position.y - slider_bound_height / 2.0) as i32,
|
||||||
// width: 40.0,
|
slider_bound_height as i32,
|
||||||
// height: 60.0,
|
slider_bound_height as i32,
|
||||||
// };
|
TRANSLUCENT_WHITE_96,
|
||||||
// draw_handle.draw_rectangle_rec(progress_bar_slider, Color::BLUE);
|
);
|
||||||
// //TODO: This causes a render bug
|
draw_handle.draw_triangle(
|
||||||
// draw_handle.draw_rectangle_lines_ex(progress_bar_slider, 6, Color::WHITE);
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y - slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height - (slider_bound_height / 2.0)),
|
||||||
|
y: progress_slider_position.y,
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y + slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
TRANSLUCENT_WHITE_96,
|
||||||
|
);
|
||||||
|
|
||||||
|
// Render the outline of the slider
|
||||||
|
draw_handle.draw_line_ex(
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y - slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: progress_slider_position.x,
|
||||||
|
y: (progress_slider_position.y - slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
3.0,
|
||||||
|
Color::BLACK,
|
||||||
|
);
|
||||||
|
draw_handle.draw_line_ex(
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y + slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: progress_slider_position.x,
|
||||||
|
y: (progress_slider_position.y + slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
3.0,
|
||||||
|
Color::BLACK,
|
||||||
|
);
|
||||||
|
draw_handle.draw_line_ex(
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y - slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height - (slider_bound_height / 2.0)),
|
||||||
|
y: progress_slider_position.y,
|
||||||
|
},
|
||||||
|
3.0,
|
||||||
|
Color::BLACK,
|
||||||
|
);
|
||||||
|
draw_handle.draw_line_ex(
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height),
|
||||||
|
y: (progress_slider_position.y + slider_bound_height / 2.0),
|
||||||
|
},
|
||||||
|
Vector2 {
|
||||||
|
x: (progress_slider_position.x - slider_bound_height - (slider_bound_height / 2.0)),
|
||||||
|
y: progress_slider_position.y,
|
||||||
|
},
|
||||||
|
3.0,
|
||||||
|
Color::BLACK,
|
||||||
|
);
|
||||||
|
|
||||||
// TODO: Breath bar
|
|
||||||
// TODO: Boost bar
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
use raylib::prelude::*;
|
use raylib::prelude::*;
|
||||||
|
|
||||||
use crate::{gamecore::GameCore, pallette::{TRANSLUCENT_WHITE_128, TRANSLUCENT_WHITE_64, TRANSLUCENT_WHITE_96}};
|
use crate::{
|
||||||
|
gamecore::GameCore,
|
||||||
|
pallette::{TRANSLUCENT_WHITE_128, TRANSLUCENT_WHITE_64, TRANSLUCENT_WHITE_96},
|
||||||
|
};
|
||||||
|
|
||||||
const NORMAL_PLAYER_SPEED: i32 = 4;
|
const NORMAL_PLAYER_SPEED: i32 = 4;
|
||||||
const BOOST_PLAYER_SPEED: i32 = NORMAL_PLAYER_SPEED * 2;
|
const BOOST_PLAYER_SPEED: i32 = NORMAL_PLAYER_SPEED * 2;
|
||||||
@ -47,12 +50,16 @@ pub fn update_player_movement(
|
|||||||
speed_multiplier = NORMAL_PLAYER_SPEED as f32;
|
speed_multiplier = NORMAL_PLAYER_SPEED as f32;
|
||||||
|
|
||||||
// Handle boost regen
|
// Handle boost regen
|
||||||
game_core.player.boost_percent =
|
if !user_request_boost {
|
||||||
(game_core.player.boost_percent + BOOST_REGEN_PER_SECOND * dt as f32).clamp(0.0, 1.0);
|
game_core.player.boost_percent = (game_core.player.boost_percent
|
||||||
|
+ BOOST_REGEN_PER_SECOND * dt as f32)
|
||||||
|
.clamp(0.0, 1.0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update the player's breath
|
// Update the player's breath
|
||||||
game_core.player.breath_percent = (game_core.player.breath_percent - BREATH_DECREASE_PER_SECOND * dt as f32).clamp(0.0, 1.0);
|
game_core.player.breath_percent =
|
||||||
|
(game_core.player.breath_percent - BREATH_DECREASE_PER_SECOND * dt as f32).clamp(0.0, 1.0);
|
||||||
|
|
||||||
// Only do this if the mouse is far enough away
|
// Only do this if the mouse is far enough away
|
||||||
let player_real_movement = game_core.player.direction * speed_multiplier;
|
let player_real_movement = game_core.player.direction * speed_multiplier;
|
||||||
|
Reference in New Issue
Block a user