mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
ac60bf5794
Made functions that were called every frame significantly cheaper. Final UI fixes.
53 lines
1.5 KiB
Rust
53 lines
1.5 KiB
Rust
use crate::{comp, uid::Uid};
|
|
use comp::item::Reagent;
|
|
use serde::{Deserialize, Serialize};
|
|
use vek::*;
|
|
|
|
/// An outcome represents the final result of an instantaneous event. It implies
|
|
/// that said event has already occurred. It is not a request for that event to
|
|
/// occur, nor is it something that may be cancelled or otherwise altered. Its
|
|
/// primary purpose is to act as something for frontends (both server and
|
|
/// client) to listen to in order to receive feedback about events in the world.
|
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
pub enum Outcome {
|
|
Explosion {
|
|
pos: Vec3<f32>,
|
|
power: f32,
|
|
radius: f32,
|
|
is_attack: bool,
|
|
reagent: Option<Reagent>, // How can we better define this?
|
|
},
|
|
ProjectileShot {
|
|
pos: Vec3<f32>,
|
|
body: comp::Body,
|
|
vel: Vec3<f32>,
|
|
},
|
|
Beam {
|
|
pos: Vec3<f32>,
|
|
heal: bool,
|
|
},
|
|
ExpChange {
|
|
uid: Uid,
|
|
exp: i32,
|
|
},
|
|
SkillPointGain {
|
|
uid: Uid,
|
|
skill_tree: comp::skills::SkillGroupKind,
|
|
total_points: u16,
|
|
// TODO: Access ECS to get position from Uid to conserve bandwidth
|
|
pos: Vec3<f32>,
|
|
},
|
|
}
|
|
|
|
impl Outcome {
|
|
pub fn get_pos(&self) -> Option<Vec3<f32>> {
|
|
match self {
|
|
Outcome::Explosion { pos, .. } => Some(*pos),
|
|
Outcome::ProjectileShot { pos, .. } => Some(*pos),
|
|
Outcome::Beam { pos, .. } => Some(*pos),
|
|
Outcome::ExpChange { .. } => None,
|
|
Outcome::SkillPointGain { pos, .. } => Some(*pos),
|
|
}
|
|
}
|
|
}
|