veloren/voxygen/src/anim/biped_large/mod.rs

164 lines
5.3 KiB
Rust
Raw Normal View History

pub mod idle;
pub mod jump;
pub mod run;
// Reexports
pub use self::idle::IdleAnimation;
pub use self::jump::JumpAnimation;
pub use self::run::RunAnimation;
use super::{Bone, Skeleton};
use crate::render::FigureBoneData;
2020-01-26 00:22:48 +00:00
use common::comp::{self};
#[derive(Clone)]
pub struct BipedLargeSkeleton {
head: Bone,
upper_torso: Bone,
lower_torso: Bone,
shoulder_l: Bone,
shoulder_r: Bone,
hand_l: Bone,
hand_r: Bone,
leg_l: Bone,
leg_r: Bone,
foot_l: Bone,
foot_r: Bone,
2020-01-29 06:38:08 +00:00
torso: Bone,
}
impl BipedLargeSkeleton {
pub fn new() -> Self {
Self {
head: Bone::default(),
upper_torso: Bone::default(),
lower_torso: Bone::default(),
shoulder_l: Bone::default(),
shoulder_r: Bone::default(),
hand_l: Bone::default(),
hand_r: Bone::default(),
leg_l: Bone::default(),
leg_r: Bone::default(),
foot_l: Bone::default(),
foot_r: Bone::default(),
2020-01-29 06:38:08 +00:00
torso: Bone::default(),
}
}
}
impl Skeleton for BipedLargeSkeleton {
2020-01-26 00:22:48 +00:00
type Attr = SkeletonAttr;
fn compute_matrices(&self) -> [FigureBoneData; 16] {
let upper_torso_mat = self.upper_torso.compute_base_matrix();
let shoulder_l_mat = self.shoulder_l.compute_base_matrix();
let shoulder_r_mat = self.shoulder_r.compute_base_matrix();
let leg_l_mat = self.leg_l.compute_base_matrix();
let leg_r_mat = self.leg_r.compute_base_matrix();
2020-01-29 06:38:08 +00:00
let torso_mat = self.torso.compute_base_matrix();
[
2020-01-29 06:38:08 +00:00
FigureBoneData::new(torso_mat * self.head.compute_base_matrix()),
FigureBoneData::new(torso_mat * upper_torso_mat),
FigureBoneData::new(
2020-01-29 06:38:08 +00:00
torso_mat * upper_torso_mat * self.lower_torso.compute_base_matrix(),
),
2020-01-29 06:38:08 +00:00
FigureBoneData::new(torso_mat * upper_torso_mat * shoulder_l_mat),
FigureBoneData::new(torso_mat * upper_torso_mat * shoulder_r_mat),
FigureBoneData::new(
2020-01-29 06:38:08 +00:00
torso_mat * upper_torso_mat * shoulder_l_mat * self.hand_l.compute_base_matrix(),
),
2020-01-29 06:38:08 +00:00
FigureBoneData::new(
torso_mat * upper_torso_mat * shoulder_r_mat * self.hand_r.compute_base_matrix(),
),
FigureBoneData::new(torso_mat * leg_l_mat),
FigureBoneData::new(torso_mat * leg_r_mat),
FigureBoneData::new(torso_mat * self.foot_l.compute_base_matrix()),
FigureBoneData::new(torso_mat * self.foot_r.compute_base_matrix()),
FigureBoneData::default(),
FigureBoneData::default(),
FigureBoneData::default(),
FigureBoneData::default(),
FigureBoneData::default(),
]
}
fn interpolate(&mut self, target: &Self, dt: f32) {
self.head.interpolate(&target.head, dt);
self.upper_torso.interpolate(&target.upper_torso, dt);
self.lower_torso.interpolate(&target.lower_torso, dt);
self.shoulder_l.interpolate(&target.shoulder_l, dt);
self.shoulder_r.interpolate(&target.shoulder_r, dt);
self.hand_l.interpolate(&target.hand_l, dt);
self.hand_r.interpolate(&target.hand_r, dt);
self.leg_l.interpolate(&target.leg_l, dt);
self.leg_r.interpolate(&target.leg_r, dt);
self.foot_l.interpolate(&target.foot_l, dt);
self.foot_r.interpolate(&target.foot_r, dt);
2020-01-29 06:38:08 +00:00
self.torso.interpolate(&target.torso, dt);
}
}
2020-01-26 00:22:48 +00:00
2020-01-29 06:38:08 +00:00
pub struct SkeletonAttr {
head: (f32, f32),
upper_torso: (f32, f32),
lower_torso: (f32, f32),
shoulder: (f32, f32, f32),
hand: (f32, f32, f32),
leg: (f32, f32, f32),
foot: (f32, f32, f32),
}
2020-01-26 00:22:48 +00:00
impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr {
type Error = ();
fn try_from(body: &'a comp::Body) -> Result<Self, Self::Error> {
match body {
comp::Body::BipedLarge(body) => Ok(SkeletonAttr::from(body)),
_ => Err(()),
}
}
}
impl Default for SkeletonAttr {
fn default() -> Self {
2020-01-29 06:38:08 +00:00
Self {
head: (0.0, 0.0),
upper_torso: (0.0, 0.0),
lower_torso: (0.0, 0.0),
shoulder: (0.0, 0.0, 0.0),
hand: (0.0, 0.0, 0.0),
leg: (0.0, 0.0, 0.0),
foot: (0.0, 0.0, 0.0),
}
2020-01-26 00:22:48 +00:00
}
}
impl<'a> From<&'a comp::biped_large::Body> for SkeletonAttr {
2020-01-29 06:38:08 +00:00
fn from(body: &'a comp::biped_large::Body) -> Self {
use comp::biped_large::Species::*;
Self {
head: match (body.species, body.body_type) {
(Giant, _) => (0.0, 28.5),
},
upper_torso: match (body.species, body.body_type) {
(Giant, _) => (0.0, 18.5),
},
lower_torso: match (body.species, body.body_type) {
(Giant, _) => (1.0, -9.5),
},
shoulder: match (body.species, body.body_type) {
(Giant, _) => (6.0, 0.5, 2.5),
},
hand: match (body.species, body.body_type) {
(Giant, _) => (3.5, -1.0, 3.0),
},
leg: match (body.species, body.body_type) {
(Giant, _) => (3.5, 0.0, 14.0),
},
foot: match (body.species, body.body_type) {
(Giant, _) => (4.0, 0.5, 11.0),
},
}
2020-01-26 00:22:48 +00:00
}
}