diff options
| author | metamuffin <metamuffin@disroot.org> | 2024-07-26 18:51:21 +0200 | 
|---|---|---|
| committer | metamuffin <metamuffin@disroot.org> | 2024-07-26 18:51:21 +0200 | 
| commit | 731c55b70f6d4c29a8ddaac229272caa4bd30084 (patch) | |
| tree | f6f3e7894013be126902658ecec893ab155064b7 /server/src/entity/weather.rs | |
| parent | 9c7673253f7dcc50d761345c3fdcd0d6d3654f3e (diff) | |
| download | hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar.bz2 hurrycurry-731c55b70f6d4c29a8ddaac229272caa4bd30084.tar.zst | |
refactor environment effects
Diffstat (limited to 'server/src/entity/weather.rs')
| -rw-r--r-- | server/src/entity/weather.rs | 51 | 
1 files changed, 0 insertions, 51 deletions
| diff --git a/server/src/entity/weather.rs b/server/src/entity/weather.rs deleted file mode 100644 index 79ac364f..00000000 --- a/server/src/entity/weather.rs +++ /dev/null @@ -1,51 +0,0 @@ -use super::EntityT; -use crate::{game::Game, InterpolateExt}; -use hurrycurry_protocol::PacketC; -use rand::{random, seq::IndexedRandom, thread_rng}; -use std::{ -    collections::VecDeque, -    time::{Duration, Instant}, -}; - -#[derive(Clone, Debug)] -pub struct WeatherController { -    next_event: Instant, -    event: usize, -} - -impl Default for WeatherController { -    fn default() -> Self { -        Self { -            next_event: Instant::now() + Duration::from_secs(10), -            event: Default::default(), -        } -    } -} -impl EntityT for WeatherController { -    fn tick( -        &mut self, -        game: &mut Game, -        _packet_out: &mut VecDeque<PacketC>, -        dt: f32, -    ) -> anyhow::Result<()> { -        if self.next_event < Instant::now() { -            self.next_event += Duration::from_secs_f32(30. + random::<f32>() * 40.); -            if self.event > 0 { -                self.event = 0; -            } else { -                self.event = *[0, 0, 1, 2].choose(&mut thread_rng()).unwrap(); -            } -        } - -        let (rain, wind) = match self.event { -            0 => (0., 0.), -            1 => (0.7, 0.), -            2 => (0., 0.7), -            _ => (1., 1.), -        }; -        game.environment.wind.exp_to(wind, dt * 0.05); -        game.environment.rain.exp_to(rain, dt * 0.15); -        eprintln!("{:#?}", game.environment); -        Ok(()) -    } -} | 
