flipper logic

This commit is contained in:
Evan Pratten 2021-04-24 16:46:06 -04:00
parent 43eab974b0
commit 8db5ff65ec
3 changed files with 44 additions and 21 deletions

View File

@ -1,19 +1,24 @@
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
// #[derive(Debug, PartialEq, Clone, Serialize, Deserialize)]
// #[serde(tag = "t", content = "c")]
// pub enum ShopItems {
// StunGun,
// AirBag,
// Flashlight { power: u8 },
// Flippers { speed_increase: u8 },
// }
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize)] #[derive(Debug, PartialEq, Clone, Serialize, Deserialize)]
pub struct StunGun { pub struct StunGun {
pub range: f32, pub range: f32,
pub duration: f64 pub duration: f64,
}
impl StunGun {
pub fn lvl1() -> Self {
Self {
range: 30.0,
duration: 0.5,
}
}
pub fn lvl2() -> Self {
Self {
range: 60.0,
duration: 0.75,
}
}
} }
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize)] #[derive(Debug, PartialEq, Clone, Serialize, Deserialize)]
@ -24,5 +29,18 @@ pub struct Flashlight;
#[derive(Debug, PartialEq, Clone, Serialize, Deserialize)] #[derive(Debug, PartialEq, Clone, Serialize, Deserialize)]
pub struct Flippers { pub struct Flippers {
pub speed_increase: f32 pub speed_increase: f32,
} }
impl Flippers {
pub fn lvl1() -> Self {
Self {
speed_increase: 1.2
}
}
pub fn lvl2() -> Self {
Self {
speed_increase: 1.5
}
}
}

View File

@ -126,6 +126,11 @@ pub fn update_player_movement(
} }
} }
// Handle flippers doing a speed increase
if game_core.player.inventory.flippers.is_some() {
let speed_multiplier = speed_multiplier * game_core.player.inventory.flippers.as_ref().unwrap().speed_increase;
}
// Update the player's breath // Update the player's breath
game_core.player.breath_percent = 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 - BREATH_DECREASE_PER_SECOND * dt as f32).clamp(0.0, 1.0);

View File

@ -7,10 +7,10 @@ const STUN_ATTACK_TIME: f64 = 0.75;
#[derive(Debug, Serialize, Deserialize, Default, Clone)] #[derive(Debug, Serialize, Deserialize, Default, Clone)]
pub struct PlayerInventory { pub struct PlayerInventory {
stun_gun: Option<StunGun>, pub stun_gun: Option<StunGun>,
air_bag: Option<AirBag>, pub air_bag: Option<AirBag>,
flashlight: Option<Flashlight>, pub flashlight: Option<Flashlight>,
flippers: Option<Flippers> pub flippers: Option<Flippers>
} }
#[derive(Debug, Default)] #[derive(Debug, Default)]
@ -78,7 +78,7 @@ impl Player {
/// Try to attack with the stun gun /// Try to attack with the stun gun
pub fn begin_attack(&mut self) { pub fn begin_attack(&mut self) {
if true || self.inventory.stun_gun.is_some() && self.stun_timer == 0.0 { if self.inventory.stun_gun.is_some() && self.stun_timer == 0.0 {
self.attacking_timer = self.inventory.stun_gun.as_ref().unwrap().duration; self.attacking_timer = self.inventory.stun_gun.as_ref().unwrap().duration;
} }
} }
@ -134,15 +134,15 @@ impl Player {
); );
// Calculate AOE ring // Calculate AOE ring
if self.attacking_timer != 0.0 { if self.attacking_timer != 0.0 && self.inventory.stun_gun.is_some() {
let aoe_ring = calculate_linear_slide( self.attacking_timer / STUN_ATTACK_TIME) as f32; let aoe_ring = calculate_linear_slide( self.attacking_timer / self.inventory.stun_gun.as_ref().unwrap().duration) as f32;
self.attacking_timer = (self.attacking_timer - dt).max(0.0); self.attacking_timer = (self.attacking_timer - dt).max(0.0);
// Render attack AOE // Render attack AOE
context_2d.draw_circle_lines( context_2d.draw_circle_lines(
self.position.x as i32, self.position.x as i32,
self.position.y as i32, self.position.y as i32,
AOE_RING_MAX_RADIUS * aoe_ring, self.inventory.stun_gun.as_ref().unwrap().range * aoe_ring,
TRANSLUCENT_WHITE_64, TRANSLUCENT_WHITE_64,
); );
} }