/* * Copyright (C) Oscar Shrimpton 2020 * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ use std::f32::consts::PI; use stockton_input::{Axis, InputManager, Mouse}; use stockton_types::components::Transform; use stockton_types::Vector3; use crate::delta_time::Timing; pub trait FlycamInput { fn get_x_axis(&self) -> &Axis; fn get_y_axis(&self) -> &Axis; fn get_z_axis(&self) -> &Axis; } pub struct FlycamControlled { pub speed: f32, pub sensitivity: f32, } impl FlycamControlled { pub fn new(speed: f32, pixels_per_360: f32) -> Self { FlycamControlled { speed, sensitivity: (2.0 * PI) / pixels_per_360, } } } #[system(for_each)] pub fn flycam_move( #[resource] manager: &T, #[resource] timing: &Timing, #[resource] mouse: &Mouse, transform: &mut Transform, flycam: &FlycamControlled, ) where T: 'static + InputManager, T::Inputs: FlycamInput, { let inputs = manager.get_inputs(); let delta = Vector3::new( **inputs.get_x_axis() as f32 * flycam.speed * timing.delta_time, **inputs.get_y_axis() as f32 * flycam.speed * timing.delta_time, **inputs.get_z_axis() as f32 * flycam.speed * timing.delta_time, ); transform.translate(delta); let rotation = mouse.delta * flycam.sensitivity; transform.rotate(Vector3::new(-rotation.y, rotation.x, 0.0)); }