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,
|
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(),
|
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();
|
2019-10-24 01:10:26 +00:00
|
|
|
|
|
|
|
[
|
2019-10-25 23:18:34 +00:00
|
|
|
FigureBoneData::new(self.head.compute_base_matrix()),
|
2019-10-25 01:26:32 +00:00
|
|
|
FigureBoneData::new(upper_torso_mat),
|
2019-10-25 23:18:34 +00:00
|
|
|
FigureBoneData::new(self.lower_torso.compute_base_matrix() * upper_torso_mat),
|
2019-10-24 01:10:26 +00:00
|
|
|
FigureBoneData::new(shoulder_l_mat * upper_torso_mat),
|
|
|
|
FigureBoneData::new(shoulder_r_mat * upper_torso_mat),
|
2019-10-25 01:26:32 +00:00
|
|
|
FigureBoneData::new(
|
2019-10-25 23:18:34 +00:00
|
|
|
self.hand_l.compute_base_matrix() * shoulder_l_mat * upper_torso_mat,
|
2019-10-25 01:26:32 +00:00
|
|
|
),
|
|
|
|
FigureBoneData::new(
|
2019-10-25 23:18:34 +00:00
|
|
|
self.hand_r.compute_base_matrix() * shoulder_r_mat * upper_torso_mat,
|
2019-10-25 01:26:32 +00:00
|
|
|
),
|
2019-10-24 01:10:26 +00:00
|
|
|
FigureBoneData::new(leg_l_mat),
|
|
|
|
FigureBoneData::new(leg_r_mat),
|
2019-10-25 23:18:34 +00:00
|
|
|
FigureBoneData::new(self.foot_l.compute_base_matrix() * leg_l_mat),
|
|
|
|
FigureBoneData::new(self.foot_r.compute_base_matrix() * leg_r_mat),
|
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);
|
2019-10-24 01:10:26 +00:00
|
|
|
}
|
|
|
|
}
|
2020-01-26 00:22:48 +00:00
|
|
|
|
|
|
|
pub struct SkeletonAttr;
|
|
|
|
|
|
|
|
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 {
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> From<&'a comp::biped_large::Body> for SkeletonAttr {
|
|
|
|
fn from(_body: &'a comp::biped_large::Body) -> Self {
|
|
|
|
Self
|
|
|
|
}
|
|
|
|
}
|