2019-10-24 01:10:26 +00:00
|
|
|
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};
|
2019-10-24 01:10:26 +00:00
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
pub struct BipedLargeSkeleton {
|
2019-10-25 23:18:34 +00:00
|
|
|
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,
|
2019-10-24 01:10:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl BipedLargeSkeleton {
|
|
|
|
pub fn new() -> Self {
|
|
|
|
Self {
|
2019-10-25 23:18:34 +00:00
|
|
|
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(),
|
2019-10-24 01:10:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Skeleton for BipedLargeSkeleton {
|
2020-01-26 00:22:48 +00:00
|
|
|
type Attr = SkeletonAttr;
|
2019-10-24 01:10:26 +00:00
|
|
|
fn compute_matrices(&self) -> [FigureBoneData; 16] {
|
2019-10-25 23:18:34 +00:00
|
|
|
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();
|
2019-10-24 01:10:26 +00:00
|
|
|
|
|
|
|
[
|
2020-01-29 06:38:08 +00:00
|
|
|
FigureBoneData::new(torso_mat * self.head.compute_base_matrix()),
|
|
|
|
FigureBoneData::new(torso_mat * upper_torso_mat),
|
2019-10-25 01:26:32 +00:00
|
|
|
FigureBoneData::new(
|
2020-01-29 06:38:08 +00:00
|
|
|
torso_mat * upper_torso_mat * self.lower_torso.compute_base_matrix(),
|
2019-10-25 01:26:32 +00:00
|
|
|
),
|
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),
|
2019-10-25 01:26:32 +00:00
|
|
|
FigureBoneData::new(
|
2020-01-29 06:38:08 +00:00
|
|
|
torso_mat * upper_torso_mat * shoulder_l_mat * self.hand_l.compute_base_matrix(),
|
2019-10-25 01:26:32 +00:00
|
|
|
),
|
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()),
|
2019-10-24 01:10:26 +00:00
|
|
|
FigureBoneData::default(),
|
|
|
|
FigureBoneData::default(),
|
|
|
|
FigureBoneData::default(),
|
|
|
|
FigureBoneData::default(),
|
|
|
|
FigureBoneData::default(),
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
fn interpolate(&mut self, target: &Self, dt: f32) {
|
2019-10-25 23:18:34 +00:00
|
|
|
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);
|
2019-10-24 01:10:26 +00:00
|
|
|
}
|
|
|
|
}
|
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
|
|
|
}
|
|
|
|
}
|