From 834749353a99e292b64f48a8a87f871a48ebda54 Mon Sep 17 00:00:00 2001 From: Snowram Date: Tue, 27 Apr 2021 23:11:45 +0200 Subject: [PATCH 1/8] Adds flame wyvern npc --- assets/common/npc_names.ron | 4 + .../voxel/bird_large_central_manifest.ron | 52 ++++++++++++ .../voxel/bird_large_lateral_manifest.ron | 84 +++++++++++++++++++ .../voxel/npc/wyvern_flame/male/beak.vox | 3 + .../voxel/npc/wyvern_flame/male/chest.vox | 3 + .../voxel/npc/wyvern_flame/male/foot_r.vox | 3 + .../voxel/npc/wyvern_flame/male/head.vox | 3 + .../voxel/npc/wyvern_flame/male/leg_r.vox | 3 + .../voxel/npc/wyvern_flame/male/neck.vox | 3 + .../npc/wyvern_flame/male/tail_front.vox | 3 + .../voxel/npc/wyvern_flame/male/tail_rear.vox | 3 + .../voxel/npc/wyvern_flame/male/wing_in_r.vox | 3 + .../npc/wyvern_flame/male/wing_mid_r.vox | 3 + .../npc/wyvern_flame/male/wing_out_r.vox | 3 + common/src/comp/body.rs | 5 +- common/src/comp/body/bird_large.rs | 10 ++- common/src/comp/inventory/loadout_builder.rs | 22 +++++ voxygen/anim/src/bird_large/fly.rs | 4 +- voxygen/anim/src/bird_large/idle.rs | 20 +---- voxygen/anim/src/bird_large/mod.rs | 13 +++ 20 files changed, 226 insertions(+), 21 deletions(-) create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/beak.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/chest.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/foot_r.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/head.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/leg_r.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/neck.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/tail_front.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/tail_rear.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/wing_in_r.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox create mode 100644 assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox diff --git a/assets/common/npc_names.ron b/assets/common/npc_names.ron index 0339622c22..2056193f41 100644 --- a/assets/common/npc_names.ron +++ b/assets/common/npc_names.ron @@ -1120,6 +1120,10 @@ keyword: "roc", generic: "Roc" ), + wyvern_flame: ( + keyword: "wyvern_flame", + generic: "Flame Wyvern" + ), ) ), quadruped_low: ( diff --git a/assets/voxygen/voxel/bird_large_central_manifest.ron b/assets/voxygen/voxel/bird_large_central_manifest.ron index a706aa79cf..6617997b69 100644 --- a/assets/voxygen/voxel/bird_large_central_manifest.ron +++ b/assets/voxygen/voxel/bird_large_central_manifest.ron @@ -155,4 +155,56 @@ central: ("npc.roc.male.tail_rear"), ) ), + (FlameWyvern, Male): ( + head: ( + offset: (-5.5, -5.0, 0.0), + central: ("npc.wyvern_flame.male.head"), + ), + beak: ( + offset: (-2.5, 0.0, -5.0), + central: ("npc.wyvern_flame.male.beak"), + ), + neck: ( + offset: (-2.5, 0.0, -3.5), + central: ("npc.wyvern_flame.male.neck"), + ), + chest: ( + offset: (-6.5, -12.0, -9.0), + central: ("npc.wyvern_flame.male.chest"), + ), + tail_front: ( + offset: (-2.5, -12.0, -7.0), + central: ("npc.wyvern_flame.male.tail_front"), + ), + tail_rear: ( + offset: (-4.5, -29.0, -8.0), + central: ("npc.wyvern_flame.male.tail_rear"), + ) + ), + (FlameWyvern, Female): ( + head: ( + offset: (-5.5, -5.0, 0.0), + central: ("npc.wyvern_flame.male.head"), + ), + beak: ( + offset: (-2.5, 0.0, -5.0), + central: ("npc.wyvern_flame.male.beak"), + ), + neck: ( + offset: (-2.5, 0.0, -3.5), + central: ("npc.wyvern_flame.male.neck"), + ), + chest: ( + offset: (-6.5, -12.0, -9.0), + central: ("npc.wyvern_flame.male.chest"), + ), + tail_front: ( + offset: (-2.5, -12.0, -7.0), + central: ("npc.wyvern_flame.male.tail_front"), + ), + tail_rear: ( + offset: (-4.5, -29.0, -8.0), + central: ("npc.wyvern_flame.male.tail_rear"), + ) + ), }) diff --git a/assets/voxygen/voxel/bird_large_lateral_manifest.ron b/assets/voxygen/voxel/bird_large_lateral_manifest.ron index fadf7ddb56..e0de44612f 100644 --- a/assets/voxygen/voxel/bird_large_lateral_manifest.ron +++ b/assets/voxygen/voxel/bird_large_lateral_manifest.ron @@ -251,4 +251,88 @@ lateral: ("npc.roc.male.foot_r"), ) ), + (FlameWyvern, Male): ( + wing_in_l: ( + offset: (-24.0, -9.0, -4.0), + lateral: ("npc.wyvern_flame.male.wing_in_r"), + ), + wing_in_r: ( + offset: (0.0, -9.0, -4.0), + lateral: ("npc.wyvern_flame.male.wing_in_r"), + ), + wing_mid_l: ( + offset: (-17.0, -27.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_mid_r"), + ), + wing_mid_r: ( + offset: (0.0, -27.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_mid_r"), + ), + wing_out_l: ( + offset: (-33.0, -31.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_out_r"), + ), + wing_out_r: ( + offset: (0.0, -31.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_out_r"), + ), + leg_l: ( + offset: (-3.0, -4.5, -5.5), + lateral: ("npc.wyvern_flame.male.leg_r"), + ), + leg_r: ( + offset: (-3.0, -4.5, -5.5), + lateral: ("npc.wyvern_flame.male.leg_r"), + ), + foot_l: ( + offset: (-3.5, -6.5, -13.0), + lateral: ("npc.wyvern_flame.male.foot_r"), + ), + foot_r: ( + offset: (-3.5, -6.5, -13.0), + lateral: ("npc.wyvern_flame.male.foot_r"), + ) + ), + (FlameWyvern, Female): ( + wing_in_l: ( + offset: (-24.0, -9.0, -4.0), + lateral: ("npc.wyvern_flame.male.wing_in_r"), + ), + wing_in_r: ( + offset: (0.0, -9.0, -4.0), + lateral: ("npc.wyvern_flame.male.wing_in_r"), + ), + wing_mid_l: ( + offset: (-17.0, -27.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_mid_r"), + ), + wing_mid_r: ( + offset: (0.0, -27.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_mid_r"), + ), + wing_out_l: ( + offset: (-33.0, -31.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_out_r"), + ), + wing_out_r: ( + offset: (0.0, -31.0, -2.0), + lateral: ("npc.wyvern_flame.male.wing_out_r"), + ), + leg_l: ( + offset: (-3.0, -4.5, -5.5), + lateral: ("npc.wyvern_flame.male.leg_r"), + ), + leg_r: ( + offset: (-3.0, -4.5, -5.5), + lateral: ("npc.wyvern_flame.male.leg_r"), + ), + foot_l: ( + offset: (-3.5, -6.5, -13.0), + lateral: ("npc.wyvern_flame.male.foot_r"), + ), + foot_r: ( + offset: (-3.5, -6.5, -13.0), + lateral: ("npc.wyvern_flame.male.foot_r"), + ) + ), }) \ No newline at end of file diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/beak.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/beak.vox new file mode 100644 index 0000000000..a9e07d1f0f --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/beak.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:bd57daae57284d5361d2b06c998c3f795c35b552e3231fd8a6846f66d8f777b5 +size 1624 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/chest.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/chest.vox new file mode 100644 index 0000000000..dcdb4ad549 --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/chest.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:42d64663c830e60c06b0d201914867c0afc3d1c065624a60df2360160f35ee73 +size 11124 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/foot_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/foot_r.vox new file mode 100644 index 0000000000..4b26f2e20d --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/foot_r.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:404b5d23587593f6b1dbadd51e9f4c68f7ffecaf35583a287bf5fa80934ec869 +size 1960 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/head.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/head.vox new file mode 100644 index 0000000000..f6f6116c95 --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/head.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:913ebab8a33288051ce0813db2146f2b24dac63baebf608b59f5b1a231ebdd9c +size 2704 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/leg_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/leg_r.vox new file mode 100644 index 0000000000..8aed222e76 --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/leg_r.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:751e1560b00f067c20cd3f6a56e82199d8eeddb8146b75fe6936dfa294f9651f +size 2248 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/neck.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/neck.vox new file mode 100644 index 0000000000..fc727abf14 --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/neck.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:39ee2a8f564263ff2291d45772e632b3076fc47f0c688ffb0fa5ef2ff7ce2e5c +size 2132 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/tail_front.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/tail_front.vox new file mode 100644 index 0000000000..a8d1bee79f --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/tail_front.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:84ee697628508e55464a1f9f2a1740c772839c502423a688f8702114b102d20a +size 2276 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/tail_rear.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/tail_rear.vox new file mode 100644 index 0000000000..b8c7df970e --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/tail_rear.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:6b12d66a475a1b079d003bd7588320afeba1180f99900feef8cc8c80f120ce82 +size 2508 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_in_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_in_r.vox new file mode 100644 index 0000000000..aedeb542ab --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_in_r.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:15cfcfcf4633d8f25825c13ee81f0509075d0223b5a1e47fb082442da8bfb876 +size 3484 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox new file mode 100644 index 0000000000..7c16da0238 --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:da971c1773c5f5b80c2fccbd52612a56d71d60842ec5ef82be484e42c5d6e5c6 +size 2116 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox new file mode 100644 index 0000000000..6eb0c5d63a --- /dev/null +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:6935d871d6e277c17a9266e567c81312892c6eab65df2b77c16c43a01d22aa8f +size 2240 diff --git a/common/src/comp/body.rs b/common/src/comp/body.rs index fe2243bd0d..ecc6bc3ac2 100644 --- a/common/src/comp/body.rs +++ b/common/src/comp/body.rs @@ -492,6 +492,7 @@ impl Body { bird_large::Species::Cockatrice => 4000, bird_large::Species::Phoenix => 6000, bird_large::Species::Roc => 5000, + bird_large::Species::FlameWyvern => 6000, }, Body::Humanoid(_) => 750, _ => 1000, @@ -746,7 +747,9 @@ impl Body { Body::QuadrupedLow(q) => matches!(q.species, quadruped_low::Species::Lavadrake), Body::BirdLarge(b) => matches!( b.species, - bird_large::Species::Phoenix | bird_large::Species::Cockatrice + bird_large::Species::Phoenix + | bird_large::Species::Cockatrice + | bird_large::Species::FlameWyvern ), _ => false, }, diff --git a/common/src/comp/body/bird_large.rs b/common/src/comp/body/bird_large.rs index 8d282c0480..361f87263b 100644 --- a/common/src/comp/body/bird_large.rs +++ b/common/src/comp/body/bird_large.rs @@ -37,6 +37,7 @@ make_case_elim!( Phoenix = 0, Cockatrice = 1, Roc = 2, + FlameWyvern = 3, } ); @@ -48,6 +49,7 @@ pub struct AllSpecies { pub phoenix: SpeciesMeta, pub cockatrice: SpeciesMeta, pub roc: SpeciesMeta, + pub wyvern_flame: SpeciesMeta, } impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies { @@ -59,11 +61,17 @@ impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies Species::Phoenix => &self.phoenix, Species::Cockatrice => &self.cockatrice, Species::Roc => &self.roc, + Species::FlameWyvern => &self.wyvern_flame, } } } -pub const ALL_SPECIES: [Species; 3] = [Species::Phoenix, Species::Cockatrice, Species::Roc]; +pub const ALL_SPECIES: [Species; 3] = [ + Species::Phoenix, + Species::Cockatrice, + Species::Roc, + Species::FlameWyvern, + ]; impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies { type IntoIter = std::iter::Copied>; diff --git a/common/src/comp/inventory/loadout_builder.rs b/common/src/comp/inventory/loadout_builder.rs index 052cbb467a..773482a097 100644 --- a/common/src/comp/inventory/loadout_builder.rs +++ b/common/src/comp/inventory/loadout_builder.rs @@ -447,6 +447,28 @@ impl LoadoutBuilder { quadruped_low::Species::Tortoise => { Some("common.items.npc_armor.quadruped_low.shell") }, + Body::BirdLarge(bird_large) => match (bird_large.species, bird_large.body_type) { + (bird_large::Species::Cockatrice, _) => { + main_tool = Some(Item::new_from_asset_expect( + "common.items.npc_weapons.unique.birdlargebreathe", + )); + }, + (bird_large::Species::Phoenix, _) => { + main_tool = Some(Item::new_from_asset_expect( + "common.items.npc_weapons.unique.birdlargefire", + )); + }, + (bird_large::Species::Roc, _) => { + main_tool = Some(Item::new_from_asset_expect( + "common.items.npc_weapons.unique.birdlargebasic", + )); + }, + (bird_large::Species::FlameWyvern, _) => { + main_tool = Some(Item::new_from_asset_expect( + "common.items.npc_weapons.unique.birdlargebreathe", + )); + }, + }, _ => None, }, Body::Theropod(body) => match body.species { diff --git a/voxygen/anim/src/bird_large/fly.rs b/voxygen/anim/src/bird_large/fly.rs index acb32f23f0..a3dc9384f6 100644 --- a/voxygen/anim/src/bird_large/fly.rs +++ b/voxygen/anim/src/bird_large/fly.rs @@ -98,8 +98,8 @@ impl Animation for FlyAnimation { next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 1.2 - 0.3); - next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 1.2 + 0.3); + next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 0.6 - 0.3) * Quaternion::rotation_x(-flap2 * 1.4); + next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 0.6 + 0.3) * Quaternion::rotation_x(-flap2 * 1.4); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = diff --git a/voxygen/anim/src/bird_large/idle.rs b/voxygen/anim/src/bird_large/idle.rs index c48f0fcf8f..7030506ad5 100644 --- a/voxygen/anim/src/bird_large/idle.rs +++ b/voxygen/anim/src/bird_large/idle.rs @@ -48,37 +48,23 @@ impl Animation for IdleAnimation { next.chest.orientation = Quaternion::rotation_x(0.0); next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); - next.neck.orientation = Quaternion::rotation_x(0.0); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(duck_head_look.x) - * Quaternion::rotation_x(-duck_head_look.y.abs() + wave_slow_cos * 0.01); next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); - next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); - next.tail_front.orientation = Quaternion::rotation_x(0.6); + next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); - next.tail_rear.orientation = Quaternion::rotation_x(-0.2); next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - next.wing_in_l.orientation = - Quaternion::rotation_y(-0.8 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.2); - next.wing_in_r.orientation = - Quaternion::rotation_y(0.8 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.2); - next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_y(-0.4) * Quaternion::rotation_z(0.2); - next.wing_out_r.orientation = Quaternion::rotation_y(0.4) * Quaternion::rotation_z(-0.2); next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_l.orientation = Quaternion::rotation_x(0.0); @@ -86,9 +72,9 @@ impl Animation for IdleAnimation { next.leg_r.orientation = Quaternion::rotation_x(0.0); next.foot_l.position = Vec3::new(-s_a.foot.0, s_a.foot.1, s_a.foot.2); - next.foot_l.orientation = Quaternion::rotation_x(0.0); + next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2); - next.foot_r.orientation = Quaternion::rotation_x(0.0); + next } diff --git a/voxygen/anim/src/bird_large/mod.rs b/voxygen/anim/src/bird_large/mod.rs index 432cd57338..46903e43c3 100644 --- a/voxygen/anim/src/bird_large/mod.rs +++ b/voxygen/anim/src/bird_large/mod.rs @@ -165,66 +165,79 @@ impl<'a> From<&'a Body> for SkeletonAttr { (Phoenix, _) => (2.5, 16.0), (Cockatrice, _) => (2.5, 16.0), (Roc, _) => (2.5, 27.5), + (FlameWyvern, _) => (2.5, 23.0), }, neck: match (body.species, body.body_type) { (Phoenix, _) => (2.5, -5.5), (Cockatrice, _) => (5.0, -1.5), (Roc, _) => (9.5, -1.5), + (FlameWyvern, _) => (11.0, -0.5), }, head: match (body.species, body.body_type) { (Phoenix, _) => (6.0, 12.0), (Cockatrice, _) => (8.0, 4.5), (Roc, _) => (17.0, -3.5), + (FlameWyvern, _) => (10.0, -1.5), }, beak: match (body.species, body.body_type) { (Phoenix, _) => (5.0, 3.0), (Cockatrice, _) => (2.0, -3.0), (Roc, _) => (0.0, -3.0), + (FlameWyvern, _) => (-1.0, 2.0), }, tail_front: match (body.species, body.body_type) { (Phoenix, _) => (-9.5, -1.0), (Cockatrice, _) => (-5.0, -2.5), (Roc, _) => (-7.5, -3.5), + (FlameWyvern, _) => (-10.0, -5.0), }, tail_rear: match (body.species, body.body_type) { (Phoenix, _) => (-11.0, 0.0), (Cockatrice, _) => (-8.0, -3.0), (Roc, _) => (-8.0, -3.0), + (FlameWyvern, _) => (-11.0, -1.0), }, wing_in: match (body.species, body.body_type) { (Phoenix, _) => (3.0, 2.5, 2.0), (Cockatrice, _) => (3.5, 7.0, 3.5), (Roc, _) => (5.5, 7.5, -1.0), + (FlameWyvern, _) => (5.5, 5.0, -2.0), }, wing_mid: match (body.species, body.body_type) { (Phoenix, _) => (10.0, 1.0, 0.0), (Cockatrice, _) => (6.0, 0.0, 0.0), (Roc, _) => (12.0, 1.0, -0.5), + (FlameWyvern, _) => (19.0, 15.0, -1.0), }, wing_out: match (body.species, body.body_type) { (Phoenix, _) => (7.0, 2.0, 1.5), (Cockatrice, _) => (4.0, -1.0, 1.0), (Roc, _) => (10.0, -2.0, 0.0), + (FlameWyvern, _) => (1.0, 1.0, 0.0), }, leg: match (body.species, body.body_type) { (Phoenix, _) => (4.0, 1.5, 12.0), (Cockatrice, _) => (3.5, 2.5, 13.0), (Roc, _) => (5.5, -1.5, 17.5), + (FlameWyvern, _) => (5.5, -2.0, 15.5), }, foot: match (body.species, body.body_type) { (Phoenix, _) => (0.5, -0.5, -2.5), (Cockatrice, _) => (0.5, -3.0, -3.0), (Roc, _) => (2.5, -2.5, -5.5), + (FlameWyvern, _) => (0.5, 0.0, -3.5), }, scaler: match (body.species, body.body_type) { (Phoenix, _) => (1.0), (Cockatrice, _) => (1.0), (Roc, _) => (1.0), + (FlameWyvern, _) => (1.0), }, feed: match (body.species, body.body_type) { (Phoenix, _) => (-0.65), (Cockatrice, _) => (-0.5), (Roc, _) => (-0.4), + (FlameWyvern, _) => (-0.65), }, } } From 9acae9fca01596c201bce4ae79f911d3b9c5e36c Mon Sep 17 00:00:00 2001 From: Snowram Date: Wed, 28 Apr 2021 01:08:14 +0200 Subject: [PATCH 2/8] More wyvern anim work --- .../voxel/bird_large_lateral_manifest.ron | 16 +++++++-------- .../npc/wyvern_flame/male/wing_mid_r.vox | 4 ++-- .../npc/wyvern_flame/male/wing_out_r.vox | 4 ++-- voxygen/anim/src/bird_large/fly.rs | 4 ++-- voxygen/anim/src/bird_large/idle.rs | 20 ++++++++++++++++--- voxygen/anim/src/bird_large/mod.rs | 4 ++-- voxygen/anim/src/bird_large/run.rs | 8 ++++++-- 7 files changed, 39 insertions(+), 21 deletions(-) diff --git a/assets/voxygen/voxel/bird_large_lateral_manifest.ron b/assets/voxygen/voxel/bird_large_lateral_manifest.ron index e0de44612f..0ea680f5eb 100644 --- a/assets/voxygen/voxel/bird_large_lateral_manifest.ron +++ b/assets/voxygen/voxel/bird_large_lateral_manifest.ron @@ -269,19 +269,19 @@ lateral: ("npc.wyvern_flame.male.wing_mid_r"), ), wing_out_l: ( - offset: (-33.0, -31.0, -2.0), + offset: (-18.0, -27.0, -2.0), lateral: ("npc.wyvern_flame.male.wing_out_r"), ), wing_out_r: ( - offset: (0.0, -31.0, -2.0), + offset: (0.0, -27.0, -2.0), lateral: ("npc.wyvern_flame.male.wing_out_r"), ), leg_l: ( - offset: (-3.0, -4.5, -5.5), + offset: (-3.0, -4.5, -8.0), lateral: ("npc.wyvern_flame.male.leg_r"), ), leg_r: ( - offset: (-3.0, -4.5, -5.5), + offset: (-3.0, -4.5, -8.0), lateral: ("npc.wyvern_flame.male.leg_r"), ), foot_l: ( @@ -311,19 +311,19 @@ lateral: ("npc.wyvern_flame.male.wing_mid_r"), ), wing_out_l: ( - offset: (-33.0, -31.0, -2.0), + offset: (-18.0, -27.0, -2.0), lateral: ("npc.wyvern_flame.male.wing_out_r"), ), wing_out_r: ( - offset: (0.0, -31.0, -2.0), + offset: (0.0, -27.0, -2.0), lateral: ("npc.wyvern_flame.male.wing_out_r"), ), leg_l: ( - offset: (-3.0, -4.5, -5.5), + offset: (-3.0, -4.5, -8.0), lateral: ("npc.wyvern_flame.male.leg_r"), ), leg_r: ( - offset: (-3.0, -4.5, -5.5), + offset: (-3.0, -4.5, -8.0), lateral: ("npc.wyvern_flame.male.leg_r"), ), foot_l: ( diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox index 7c16da0238..f680643bb4 100644 --- a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_mid_r.vox @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:da971c1773c5f5b80c2fccbd52612a56d71d60842ec5ef82be484e42c5d6e5c6 -size 2116 +oid sha256:fc34faf908c37cde975c79610c05373fe75c81f8da54b9e7ed10ecd821731d1b +size 2460 diff --git a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox index 6eb0c5d63a..99d22e1af9 100644 --- a/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox +++ b/assets/voxygen/voxel/npc/wyvern_flame/male/wing_out_r.vox @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:6935d871d6e277c17a9266e567c81312892c6eab65df2b77c16c43a01d22aa8f -size 2240 +oid sha256:0dd91e1e74eb978dbccef1b93d867a60667eca38dda161d1c92e0c56d9691d31 +size 1940 diff --git a/voxygen/anim/src/bird_large/fly.rs b/voxygen/anim/src/bird_large/fly.rs index a3dc9384f6..e3af646f3a 100644 --- a/voxygen/anim/src/bird_large/fly.rs +++ b/voxygen/anim/src/bird_large/fly.rs @@ -98,8 +98,8 @@ impl Animation for FlyAnimation { next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 0.6 - 0.3) * Quaternion::rotation_x(-flap2 * 1.4); - next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 0.6 + 0.3) * Quaternion::rotation_x(-flap2 * 1.4); + next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 0.6 - 0.3); + next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 0.6 + 0.3); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = diff --git a/voxygen/anim/src/bird_large/idle.rs b/voxygen/anim/src/bird_large/idle.rs index 7030506ad5..ec9d92a4dc 100644 --- a/voxygen/anim/src/bird_large/idle.rs +++ b/voxygen/anim/src/bird_large/idle.rs @@ -48,23 +48,37 @@ impl Animation for IdleAnimation { next.chest.orientation = Quaternion::rotation_x(0.0); next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); + next.neck.orientation = Quaternion::rotation_x(0.0); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(duck_head_look.x) + * Quaternion::rotation_x(0.4 -duck_head_look.y.abs() + wave_slow_cos * 0.01); next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); + next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); - + next.tail_front.orientation = Quaternion::rotation_x(0.3); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); + next.tail_rear.orientation = Quaternion::rotation_x(-0.0); next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + next.wing_in_l.orientation = + Quaternion::rotation_y(-0.8 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.4); + next.wing_in_r.orientation = + Quaternion::rotation_y(0.8 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.4); + next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_l.orientation = Quaternion::rotation_x(0.1)*Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = Quaternion::rotation_x(0.1)*Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_l.orientation = Quaternion::rotation_x(0.0) * Quaternion::rotation_y(0.1) * Quaternion::rotation_z(0.55); + next.wing_out_r.orientation = Quaternion::rotation_x(0.0) * Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(-0.55); next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_l.orientation = Quaternion::rotation_x(0.0); @@ -72,9 +86,9 @@ impl Animation for IdleAnimation { next.leg_r.orientation = Quaternion::rotation_x(0.0); next.foot_l.position = Vec3::new(-s_a.foot.0, s_a.foot.1, s_a.foot.2); - + next.foot_l.orientation = Quaternion::rotation_x(0.0); next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2); - + next.foot_r.orientation = Quaternion::rotation_x(0.0); next } diff --git a/voxygen/anim/src/bird_large/mod.rs b/voxygen/anim/src/bird_large/mod.rs index 46903e43c3..d30670afa9 100644 --- a/voxygen/anim/src/bird_large/mod.rs +++ b/voxygen/anim/src/bird_large/mod.rs @@ -165,7 +165,7 @@ impl<'a> From<&'a Body> for SkeletonAttr { (Phoenix, _) => (2.5, 16.0), (Cockatrice, _) => (2.5, 16.0), (Roc, _) => (2.5, 27.5), - (FlameWyvern, _) => (2.5, 23.0), + (FlameWyvern, _) => (2.5, 20.5), }, neck: match (body.species, body.body_type) { (Phoenix, _) => (2.5, -5.5), @@ -213,7 +213,7 @@ impl<'a> From<&'a Body> for SkeletonAttr { (Phoenix, _) => (7.0, 2.0, 1.5), (Cockatrice, _) => (4.0, -1.0, 1.0), (Roc, _) => (10.0, -2.0, 0.0), - (FlameWyvern, _) => (1.0, 1.0, 0.0), + (FlameWyvern, _) => (16.0, -3.0, 0.0), }, leg: match (body.species, body.body_type) { (Phoenix, _) => (4.0, 1.5, 12.0), diff --git a/voxygen/anim/src/bird_large/run.rs b/voxygen/anim/src/bird_large/run.rs index 7ac8b4c905..e5484b5d21 100644 --- a/voxygen/anim/src/bird_large/run.rs +++ b/voxygen/anim/src/bird_large/run.rs @@ -103,8 +103,12 @@ impl Animation for RunAnimation { next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - next.wing_in_l.orientation = Quaternion::rotation_y(-0.8) * Quaternion::rotation_z(0.2); - next.wing_in_r.orientation = Quaternion::rotation_y(0.8) * Quaternion::rotation_z(-0.2); + next.wing_in_l.orientation = Quaternion::rotation_x(foot2a * 0.5) + * Quaternion::rotation_y(-0.8) + * Quaternion::rotation_z(0.2); + next.wing_in_r.orientation = Quaternion::rotation_x(foot1a * 0.5) + * Quaternion::rotation_y(0.8) + * Quaternion::rotation_z(-0.2); next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); From aedb2e9d2baca60f977c894d213abab197ed7c04 Mon Sep 17 00:00:00 2001 From: jshipsey Date: Wed, 28 Apr 2021 09:24:43 -0400 Subject: [PATCH 3/8] wyvern walk --- common/src/comp/body/bird_large.rs | 2 +- voxygen/anim/src/bird_large/idle.rs | 18 ++++++++++----- voxygen/anim/src/bird_large/run.rs | 34 ++++++++++++++++++----------- 3 files changed, 35 insertions(+), 19 deletions(-) diff --git a/common/src/comp/body/bird_large.rs b/common/src/comp/body/bird_large.rs index 361f87263b..ca15f548fb 100644 --- a/common/src/comp/body/bird_large.rs +++ b/common/src/comp/body/bird_large.rs @@ -66,7 +66,7 @@ impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies } } -pub const ALL_SPECIES: [Species; 3] = [ +pub const ALL_SPECIES: [Species; 4] = [ Species::Phoenix, Species::Cockatrice, Species::Roc, diff --git a/voxygen/anim/src/bird_large/idle.rs b/voxygen/anim/src/bird_large/idle.rs index ec9d92a4dc..b42dd6b38a 100644 --- a/voxygen/anim/src/bird_large/idle.rs +++ b/voxygen/anim/src/bird_large/idle.rs @@ -52,7 +52,7 @@ impl Animation for IdleAnimation { next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_z(duck_head_look.x) - * Quaternion::rotation_x(0.4 -duck_head_look.y.abs() + wave_slow_cos * 0.01); + * Quaternion::rotation_x(0.4 - duck_head_look.y.abs() + wave_slow_cos * 0.01); next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); @@ -72,13 +72,21 @@ impl Animation for IdleAnimation { next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = Quaternion::rotation_x(0.1)*Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = Quaternion::rotation_x(0.1)*Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); + next.wing_mid_l.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(-0.1) + * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(0.1) + * Quaternion::rotation_z(-0.7); next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_x(0.0) * Quaternion::rotation_y(0.1) * Quaternion::rotation_z(0.55); - next.wing_out_r.orientation = Quaternion::rotation_x(0.0) * Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(-0.55); + next.wing_out_l.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(0.1) + * Quaternion::rotation_z(0.55); + next.wing_out_r.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(-0.1) + * Quaternion::rotation_z(-0.55); next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_l.orientation = Quaternion::rotation_x(0.0); diff --git a/voxygen/anim/src/bird_large/run.rs b/voxygen/anim/src/bird_large/run.rs index e5484b5d21..47b5b6e3fc 100644 --- a/voxygen/anim/src/bird_large/run.rs +++ b/voxygen/anim/src/bird_large/run.rs @@ -95,20 +95,28 @@ impl Animation for RunAnimation { * Quaternion::rotation_z(shortalt * 0.10); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); - next.tail_front.orientation = Quaternion::rotation_x(0.6 + short * -0.02); + next.tail_front.orientation = Quaternion::rotation_x(0.3 + short * -0.02); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); next.tail_rear.orientation = Quaternion::rotation_x(-0.2 + short * -0.1); - next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + next.wing_in_l.position = Vec3::new( + -s_a.wing_in.0, + s_a.wing_in.1 + foot1a * 2.0, + s_a.wing_in.2 + speednorm * 1.0 + foot1b * 1.0, + ); + next.wing_in_r.position = Vec3::new( + s_a.wing_in.0, + s_a.wing_in.1 + foot2a * 2.0, + s_a.wing_in.2 + speednorm * 1.0 + foot2b * 1.0, + ); - next.wing_in_l.orientation = Quaternion::rotation_x(foot2a * 0.5) - * Quaternion::rotation_y(-0.8) - * Quaternion::rotation_z(0.2); - next.wing_in_r.orientation = Quaternion::rotation_x(foot1a * 0.5) - * Quaternion::rotation_y(0.8) - * Quaternion::rotation_z(-0.2); + next.wing_in_l.orientation = Quaternion::rotation_x(foot2a * -0.05 + speednorm * -0.3) + * Quaternion::rotation_y(-0.8 + speednorm * 0.55 + foot2b * -0.2) + * Quaternion::rotation_z(0.2 + foot2a * 0.6); + next.wing_in_r.orientation = Quaternion::rotation_x(foot1a * -0.05 + speednorm * -0.3) + * Quaternion::rotation_y(0.8 + speednorm * -0.55 + foot1b * 0.2) + * Quaternion::rotation_z(-0.2 + foot1a * -0.6); next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); @@ -117,10 +125,10 @@ impl Animation for RunAnimation { next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = - Quaternion::rotation_y(-0.2 + short * 0.05) * Quaternion::rotation_z(0.2); - next.wing_out_r.orientation = - Quaternion::rotation_y(0.2 + short * -0.05) * Quaternion::rotation_z(-0.2); + next.wing_out_l.orientation = Quaternion::rotation_y(-0.2 + short * 0.05) + * Quaternion::rotation_z(0.2 + foot2a * 0.3); + next.wing_out_r.orientation = Quaternion::rotation_y(0.2 + short * -0.05) + * Quaternion::rotation_z(-0.2 + foot1a * 0.3); next.leg_l.position = Vec3::new( -s_a.leg.0 + speednorm * 1.5, From 299ca581eaa33e2b20cb7d3bb699cab8eeac60d1 Mon Sep 17 00:00:00 2001 From: Snowram Date: Fri, 30 Apr 2021 12:43:44 +0200 Subject: [PATCH 4/8] Split wyvern anims from the other birdlarge anims --- voxygen/anim/src/bird_large/alpha.rs | 15 +- voxygen/anim/src/bird_large/breathe.rs | 15 +- voxygen/anim/src/bird_large/feed.rs | 15 +- voxygen/anim/src/bird_large/fly.rs | 35 ++-- voxygen/anim/src/bird_large/idle.rs | 132 +++++++++------ voxygen/anim/src/bird_large/mod.rs | 6 + voxygen/anim/src/bird_large/run.rs | 197 +++++++++++++++-------- voxygen/anim/src/bird_large/shockwave.rs | 15 +- voxygen/anim/src/bird_large/shoot.rs | 15 +- voxygen/anim/src/bird_large/stunned.rs | 15 +- voxygen/anim/src/bird_large/swim.rs | 15 +- 11 files changed, 308 insertions(+), 167 deletions(-) diff --git a/voxygen/anim/src/bird_large/alpha.rs b/voxygen/anim/src/bird_large/alpha.rs index d2e718e96a..0f4c77ed3c 100644 --- a/voxygen/anim/src/bird_large/alpha.rs +++ b/voxygen/anim/src/bird_large/alpha.rs @@ -51,12 +51,15 @@ impl Animation for AlphaAnimation { 0.0 } * 1.3; - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06); next.chest.orientation = Quaternion::rotation_x(move1 * 0.5 - move2 * 0.8); diff --git a/voxygen/anim/src/bird_large/breathe.rs b/voxygen/anim/src/bird_large/breathe.rs index 94e6a8891a..8740ac86d3 100644 --- a/voxygen/anim/src/bird_large/breathe.rs +++ b/voxygen/anim/src/bird_large/breathe.rs @@ -51,12 +51,15 @@ impl Animation for BreatheAnimation { let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new( 0.0, diff --git a/voxygen/anim/src/bird_large/feed.rs b/voxygen/anim/src/bird_large/feed.rs index 11b9aec664..71e966add9 100644 --- a/voxygen/anim/src/bird_large/feed.rs +++ b/voxygen/anim/src/bird_large/feed.rs @@ -39,12 +39,15 @@ impl Animation for FeedAnimation { let wave_fast = (anim_time * 9.0).cos(); let beak = (anim_time * 16.0).sin(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 - 1.8); next.chest.orientation = Quaternion::rotation_x(s_a.feed); diff --git a/voxygen/anim/src/bird_large/fly.rs b/voxygen/anim/src/bird_large/fly.rs index e3af646f3a..b39bab980a 100644 --- a/voxygen/anim/src/bird_large/fly.rs +++ b/voxygen/anim/src/bird_large/fly.rs @@ -26,7 +26,7 @@ impl Animation for FlyAnimation { let fast = (anim_time * 4.0).sin(); // Harmonic series hack to get a sine/saw mix - let freq = 8.0; + let freq = if s_a.wyvern {6.0} else {8.0}; let off1 = 0.0; let off2 = -1.7; let off3 = -2.0; @@ -58,12 +58,15 @@ impl Animation for FlyAnimation { 0.0 } * 1.3; - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); next.neck.orientation = @@ -98,15 +101,21 @@ impl Animation for FlyAnimation { next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 0.6 - 0.3); - next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 0.6 + 0.3); + + if s_a.wyvern { + next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 0.6 - 0.3); + next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 0.6 + 0.3); + } else { + next.wing_out_l.orientation = Quaternion::rotation_y(-flap3 * 1.2 - 0.3); + next.wing_out_r.orientation = Quaternion::rotation_y(flap3 * 1.2 + 0.3); + } next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = - Quaternion::rotation_x(-flap2 * 0.2 + 0.1) * Quaternion::rotation_z(-tilt * 1.0); + Quaternion::rotation_x(-flap2 * 0.2 + 0.1) * Quaternion::rotation_z(tilt * 1.0); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); next.tail_rear.orientation = - Quaternion::rotation_x(-flap3 * 0.3 + 0.15) * Quaternion::rotation_z(-tilt * 0.8); + Quaternion::rotation_x(-flap3 * 0.3 + 0.15) * Quaternion::rotation_z(tilt * 0.8); next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2 - flap4 * 1.5); next.leg_l.orientation = Quaternion::rotation_x( @@ -151,10 +160,10 @@ impl Animation for FlyAnimation { next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = - Quaternion::rotation_x(0.04 - slow * 0.04) * Quaternion::rotation_z(-tilt * 1.0); + Quaternion::rotation_x(0.04 - slow * 0.04) * Quaternion::rotation_z(tilt * 1.0); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); next.tail_rear.orientation = - Quaternion::rotation_x(slow * 0.08) * Quaternion::rotation_z(-tilt * 0.8); + Quaternion::rotation_x(slow * 0.08) * Quaternion::rotation_z(tilt * 0.8); next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2 + slow * 0.05); next.leg_l.orientation = Quaternion::rotation_x(-1.2 + slow * -0.05) diff --git a/voxygen/anim/src/bird_large/idle.rs b/voxygen/anim/src/bird_large/idle.rs index b42dd6b38a..505f032398 100644 --- a/voxygen/anim/src/bird_large/idle.rs +++ b/voxygen/anim/src/bird_large/idle.rs @@ -37,58 +37,23 @@ impl Animation for IdleAnimation { ); let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 + 1.5); - next.chest.orientation = Quaternion::rotation_x(0.0); + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler / 8.0 * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); next.neck.orientation = Quaternion::rotation_x(0.0); - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(duck_head_look.x) - * Quaternion::rotation_x(0.4 - duck_head_look.y.abs() + wave_slow_cos * 0.01); - next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); - next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); - next.tail_front.orientation = Quaternion::rotation_x(0.3); - next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); - next.tail_rear.orientation = Quaternion::rotation_x(-0.0); - - next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - - next.wing_in_l.orientation = - Quaternion::rotation_y(-0.8 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.4); - next.wing_in_r.orientation = - Quaternion::rotation_y(0.8 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.4); - - next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = Quaternion::rotation_x(0.1) - * Quaternion::rotation_y(-0.1) - * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = Quaternion::rotation_x(0.1) - * Quaternion::rotation_y(0.1) - * Quaternion::rotation_z(-0.7); - - next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(0.1) - * Quaternion::rotation_z(0.55); - next.wing_out_r.orientation = Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(-0.1) - * Quaternion::rotation_z(-0.55); - - next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2); + next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2) / 8.0; next.leg_l.orientation = Quaternion::rotation_x(0.0); next.leg_r.position = Vec3::new(s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_r.orientation = Quaternion::rotation_x(0.0); @@ -98,6 +63,83 @@ impl Animation for IdleAnimation { next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2); next.foot_r.orientation = Quaternion::rotation_x(0.0); + if s_a.wyvern { + next.chest.position = + Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06) * s_a.scaler / 8.0; + next.chest.orientation = Quaternion::rotation_x(-0.1); + + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(duck_head_look.x) + * Quaternion::rotation_x(0.4 - duck_head_look.y.abs() + wave_slow_cos * 0.01); + + next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); + next.tail_front.orientation = Quaternion::rotation_x(0.38); + next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); + next.tail_rear.orientation = Quaternion::rotation_x(-0.1); + + next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + + next.wing_in_l.orientation = + Quaternion::rotation_y(-0.8 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.4); + next.wing_in_r.orientation = + Quaternion::rotation_y(0.8 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.4); + + next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_l.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(-0.1) + * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(0.1) + * Quaternion::rotation_z(-0.7); + + next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_l.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(0.1) + * Quaternion::rotation_z(0.55); + next.wing_out_r.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(-0.1) + * Quaternion::rotation_z(-0.55); + } else { + next.chest.position = + Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 + 1.5) * s_a.scaler + / 8.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(duck_head_look.x) + * Quaternion::rotation_x(-duck_head_look.y.abs() + wave_slow_cos * 0.01); + + next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); + next.tail_front.orientation = Quaternion::rotation_x(0.6); + next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); + next.tail_rear.orientation = Quaternion::rotation_x(-0.2); + + next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + + next.wing_in_l.orientation = + Quaternion::rotation_y(-0.8 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.2); + next.wing_in_r.orientation = + Quaternion::rotation_y(0.8 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.2); + + next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_l.orientation = + Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = + Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); + + next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_l.orientation = + Quaternion::rotation_y(-0.4) * Quaternion::rotation_z(0.2); + next.wing_out_r.orientation = + Quaternion::rotation_y(0.4) * Quaternion::rotation_z(-0.2); + } + next } } diff --git a/voxygen/anim/src/bird_large/mod.rs b/voxygen/anim/src/bird_large/mod.rs index d30670afa9..b8363215e3 100644 --- a/voxygen/anim/src/bird_large/mod.rs +++ b/voxygen/anim/src/bird_large/mod.rs @@ -124,6 +124,7 @@ pub struct SkeletonAttr { foot: (f32, f32, f32), scaler: f32, feed: f32, + wyvern: bool, } impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { @@ -153,6 +154,7 @@ impl Default for SkeletonAttr { foot: (0.0, 0.0, 0.0), scaler: 0.0, feed: 0.0, + wyvern: false, } } } @@ -239,6 +241,10 @@ impl<'a> From<&'a Body> for SkeletonAttr { (Roc, _) => (-0.4), (FlameWyvern, _) => (-0.65), }, + wyvern: match (body.species, body.body_type) { + (FlameWyvern, _) => true, + _ => false, + }, } } } diff --git a/voxygen/anim/src/bird_large/run.rs b/voxygen/anim/src/bird_large/run.rs index 47b5b6e3fc..89278109bd 100644 --- a/voxygen/anim/src/bird_large/run.rs +++ b/voxygen/anim/src/bird_large/run.rs @@ -65,12 +65,15 @@ impl Animation for RunAnimation { 0.0 } * 1.3; - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler* 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_x(-0.1 * speednorm + short * -0.05) @@ -85,67 +88,6 @@ impl Animation for RunAnimation { * Quaternion::rotation_y(tilt * 0.1) * Quaternion::rotation_z(shortalt * -0.1 - tilt * 0.5); - next.chest.position = Vec3::new( - 0.0, - s_a.chest.0, - s_a.chest.1 + short * 0.5 + 0.5 * speednorm, - ); - next.chest.orientation = Quaternion::rotation_x(short * 0.07) - * Quaternion::rotation_y(tilt * 0.8) - * Quaternion::rotation_z(shortalt * 0.10); - - next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); - next.tail_front.orientation = Quaternion::rotation_x(0.3 + short * -0.02); - - next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); - next.tail_rear.orientation = Quaternion::rotation_x(-0.2 + short * -0.1); - - next.wing_in_l.position = Vec3::new( - -s_a.wing_in.0, - s_a.wing_in.1 + foot1a * 2.0, - s_a.wing_in.2 + speednorm * 1.0 + foot1b * 1.0, - ); - next.wing_in_r.position = Vec3::new( - s_a.wing_in.0, - s_a.wing_in.1 + foot2a * 2.0, - s_a.wing_in.2 + speednorm * 1.0 + foot2b * 1.0, - ); - - next.wing_in_l.orientation = Quaternion::rotation_x(foot2a * -0.05 + speednorm * -0.3) - * Quaternion::rotation_y(-0.8 + speednorm * 0.55 + foot2b * -0.2) - * Quaternion::rotation_z(0.2 + foot2a * 0.6); - next.wing_in_r.orientation = Quaternion::rotation_x(foot1a * -0.05 + speednorm * -0.3) - * Quaternion::rotation_y(0.8 + speednorm * -0.55 + foot1b * 0.2) - * Quaternion::rotation_z(-0.2 + foot1a * -0.6); - - next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); - - next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = Quaternion::rotation_y(-0.2 + short * 0.05) - * Quaternion::rotation_z(0.2 + foot2a * 0.3); - next.wing_out_r.orientation = Quaternion::rotation_y(0.2 + short * -0.05) - * Quaternion::rotation_z(-0.2 + foot1a * 0.3); - - next.leg_l.position = Vec3::new( - -s_a.leg.0 + speednorm * 1.5, - s_a.leg.1 + foot1b * -2.3, - s_a.leg.2, - ); - next.leg_l.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot1a * 0.15) - * Quaternion::rotation_y(tilt * 0.5); - - next.leg_r.position = Vec3::new( - s_a.leg.0 + speednorm * -1.5, - s_a.leg.1 + foot2b * -2.3, - s_a.leg.2, - ); - next.leg_r.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot2a * 0.15) - * Quaternion::rotation_y(tilt * 0.5); - next.foot_l.position = Vec3::new( -s_a.foot.0, s_a.foot.1 + foot1b * -1.0, @@ -164,6 +106,127 @@ impl Animation for RunAnimation { * Quaternion::rotation_y(tilt * -1.0) * Quaternion::rotation_z(tilt * -0.5); + if s_a.wyvern { + next.chest.position = Vec3::new( + 0.0, + s_a.chest.0, + s_a.chest.1 + short * 0.5 + speednorm * -2.0, + ) * s_a.scaler + / 8.0; + next.chest.orientation = Quaternion::rotation_x(-0.1 + short * 0.07) + * Quaternion::rotation_y(tilt * 0.8) + * Quaternion::rotation_z(shortalt * 0.10); + + next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); + next.tail_front.orientation = + Quaternion::rotation_x(0.3 + short * -0.02) * Quaternion::rotation_z(tilt * 2.0); + + next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); + next.tail_rear.orientation = + Quaternion::rotation_x(-0.1 + short * -0.1) * Quaternion::rotation_z(tilt * 0.8); + + next.wing_in_l.position = Vec3::new( + -s_a.wing_in.0, + s_a.wing_in.1 + foot1a * 2.0, + s_a.wing_in.2 + speednorm * 1.0 + foot1b * 1.0, + ); + next.wing_in_r.position = Vec3::new( + s_a.wing_in.0, + s_a.wing_in.1 + foot2a * 2.0, + s_a.wing_in.2 + speednorm * 1.0 + foot2b * 1.0, + ); + + next.wing_in_l.orientation = Quaternion::rotation_x(foot2a * -0.05 + speednorm * -0.3) + * Quaternion::rotation_y(-0.8 + speednorm * 0.55 + foot2b * -0.2) + * Quaternion::rotation_z(0.2 + foot2a * 0.6); + next.wing_in_r.orientation = Quaternion::rotation_x(foot1a * -0.05 + speednorm * -0.3) + * Quaternion::rotation_y(0.8 + speednorm * -0.55 + foot1b * 0.2) + * Quaternion::rotation_z(-0.2 + foot1a * -0.6); + + next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_l.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(-0.1) + * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = Quaternion::rotation_x(0.1) + * Quaternion::rotation_y(0.1) + * Quaternion::rotation_z(-0.7); + + next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_l.orientation = Quaternion::rotation_y(0.2 + short * 0.05) + * Quaternion::rotation_z(0.3 + foot2a * 0.3); + next.wing_out_r.orientation = Quaternion::rotation_y(-0.2 + short * -0.05) + * Quaternion::rotation_z(-0.3 + foot1a * 0.3); + + next.leg_l.position = Vec3::new( + -s_a.leg.0, + s_a.leg.1 + foot1b * -2.3, + s_a.leg.2, + ) / 8.0; + next.leg_l.orientation = Quaternion::rotation_x(-1.0 * speednorm + foot1a * 0.15) + * Quaternion::rotation_y(tilt * 0.5); + + next.leg_r.position = Vec3::new( + s_a.leg.0, + s_a.leg.1 + foot2b * -2.3, + s_a.leg.2, + ) / 8.0; + next.leg_r.orientation = Quaternion::rotation_x(-1.0 * speednorm + foot2a * 0.15) + * Quaternion::rotation_y(tilt * 0.5); + } else { + next.chest.position = Vec3::new( + 0.0, + s_a.chest.0, + s_a.chest.1 + short * 0.5 + 0.5 * speednorm, + ) * s_a.scaler + / 8.0; + next.chest.orientation = Quaternion::rotation_x(short * 0.07) + * Quaternion::rotation_y(tilt * 0.8) + * Quaternion::rotation_z(shortalt * 0.10); + + next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); + next.tail_front.orientation = Quaternion::rotation_x(0.6 + short * -0.02); + + next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); + next.tail_rear.orientation = Quaternion::rotation_x(-0.2 + short * -0.1); + + next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); + + next.wing_in_l.orientation = Quaternion::rotation_y(-0.8) * Quaternion::rotation_z(0.2); + next.wing_in_r.orientation = Quaternion::rotation_y(0.8) * Quaternion::rotation_z(-0.2); + + next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); + next.wing_mid_l.orientation = + Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); + next.wing_mid_r.orientation = + Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); + + next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); + next.wing_out_l.orientation = + Quaternion::rotation_y(-0.2 + short * 0.05) * Quaternion::rotation_z(0.2); + next.wing_out_r.orientation = + Quaternion::rotation_y(0.2 + short * -0.05) * Quaternion::rotation_z(-0.2); + + next.leg_l.position = Vec3::new( + -s_a.leg.0, + s_a.leg.1 + foot1b * -2.3, + s_a.leg.2, + ) / 8.0; + next.leg_l.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot1a * 0.15) + * Quaternion::rotation_y(tilt * 0.5); + + next.leg_r.position = Vec3::new( + s_a.leg.0, + s_a.leg.1 + foot2b * -2.3, + s_a.leg.2, + ) / 8.0; + next.leg_r.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot2a * 0.15) + * Quaternion::rotation_y(tilt * 0.5); + } next } } diff --git a/voxygen/anim/src/bird_large/shockwave.rs b/voxygen/anim/src/bird_large/shockwave.rs index 4bac2d216a..b13f1c8608 100644 --- a/voxygen/anim/src/bird_large/shockwave.rs +++ b/voxygen/anim/src/bird_large/shockwave.rs @@ -38,12 +38,15 @@ impl Animation for ShockwaveAnimation { let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + movement1abs * 1.5); next.chest.orientation = Quaternion::rotation_x(movement1abs * 1.0 + movement2abs * -1.0); diff --git a/voxygen/anim/src/bird_large/shoot.rs b/voxygen/anim/src/bird_large/shoot.rs index 17bf8b54c9..d85aab489c 100644 --- a/voxygen/anim/src/bird_large/shoot.rs +++ b/voxygen/anim/src/bird_large/shoot.rs @@ -43,12 +43,15 @@ impl Animation for ShootAnimation { let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new( 0.0, diff --git a/voxygen/anim/src/bird_large/stunned.rs b/voxygen/anim/src/bird_large/stunned.rs index 680da225ac..7cc6588862 100644 --- a/voxygen/anim/src/bird_large/stunned.rs +++ b/voxygen/anim/src/bird_large/stunned.rs @@ -37,12 +37,15 @@ impl Animation for StunnedAnimation { let twitch2 = mirror * (twitch * 20.0).sin() * pullback; let movement1abs = movement1base * pullback; - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06); next.chest.orientation = Quaternion::rotation_x(movement1base * 0.5); diff --git a/voxygen/anim/src/bird_large/swim.rs b/voxygen/anim/src/bird_large/swim.rs index 8535b06c47..a1299944f6 100644 --- a/voxygen/anim/src/bird_large/swim.rs +++ b/voxygen/anim/src/bird_large/swim.rs @@ -41,12 +41,15 @@ impl Animation for SwimAnimation { let wave_fast = (anim_time * 6.0).sin(); let wave_fast_cos = (anim_time * 6.0).cos(); - next.head.scale = Vec3::one() * 0.98; - next.neck.scale = Vec3::one() * 1.02; - next.leg_l.scale = Vec3::one() * 0.98; - next.leg_r.scale = Vec3::one() * 0.98; - next.foot_l.scale = Vec3::one() * 1.02; - next.foot_r.scale = Vec3::one() * 1.02; + next.head.scale = Vec3::one() * 0.99; + next.neck.scale = Vec3::one() * 1.01; + next.leg_l.scale = Vec3::one() / 8.0; + next.leg_r.scale = Vec3::one() / 8.0; + next.foot_l.scale = Vec3::one() * 1.01; + next.foot_r.scale = Vec3::one() * 1.01; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.tail_front.scale = Vec3::one() * 1.01; + next.tail_rear.scale = Vec3::one() * 0.99; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 + 1.5); next.chest.orientation = Quaternion::rotation_x(0.0); From 1ad107f4a7b2938f8c73091b6ca3efb7d3973b3f Mon Sep 17 00:00:00 2001 From: jshipsey Date: Sun, 5 Sep 2021 03:43:22 -0400 Subject: [PATCH 5/8] animation tweaks --- common/src/comp/body/bird_large.rs | 2 +- common/src/comp/inventory/loadout_builder.rs | 25 +----- voxygen/anim/src/bird_large/alpha.rs | 55 ++++++------- voxygen/anim/src/bird_large/breathe.rs | 57 +++++--------- voxygen/anim/src/bird_large/feed.rs | 10 --- voxygen/anim/src/bird_large/fly.rs | 8 +- voxygen/anim/src/bird_large/idle.rs | 13 ++-- voxygen/anim/src/bird_large/run.rs | 36 ++++----- voxygen/anim/src/bird_large/shockwave.rs | 10 --- voxygen/anim/src/bird_large/shoot.rs | 81 ++++++++------------ voxygen/anim/src/bird_large/stunned.rs | 10 --- voxygen/anim/src/bird_large/swim.rs | 4 +- voxygen/src/scene/figure/mod.rs | 4 + 13 files changed, 114 insertions(+), 201 deletions(-) diff --git a/common/src/comp/body/bird_large.rs b/common/src/comp/body/bird_large.rs index ca15f548fb..fdc2dfdec0 100644 --- a/common/src/comp/body/bird_large.rs +++ b/common/src/comp/body/bird_large.rs @@ -71,7 +71,7 @@ pub const ALL_SPECIES: [Species; 4] = [ Species::Cockatrice, Species::Roc, Species::FlameWyvern, - ]; +]; impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies { type IntoIter = std::iter::Copied>; diff --git a/common/src/comp/inventory/loadout_builder.rs b/common/src/comp/inventory/loadout_builder.rs index 773482a097..5af8102058 100644 --- a/common/src/comp/inventory/loadout_builder.rs +++ b/common/src/comp/inventory/loadout_builder.rs @@ -352,6 +352,9 @@ fn default_main_tool(body: &Body) -> Item { (bird_large::Species::Roc, _) => Some(Item::new_from_asset_expect( "common.items.npc_weapons.unique.birdlargebasic", )), + (bird_large::Species::FlameWyvern, _) => Some(Item::new_from_asset_expect( + "common.items.npc_weapons.unique.birdlargebreathe", + )), }, _ => None, }; @@ -447,28 +450,6 @@ impl LoadoutBuilder { quadruped_low::Species::Tortoise => { Some("common.items.npc_armor.quadruped_low.shell") }, - Body::BirdLarge(bird_large) => match (bird_large.species, bird_large.body_type) { - (bird_large::Species::Cockatrice, _) => { - main_tool = Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargebreathe", - )); - }, - (bird_large::Species::Phoenix, _) => { - main_tool = Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargefire", - )); - }, - (bird_large::Species::Roc, _) => { - main_tool = Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargebasic", - )); - }, - (bird_large::Species::FlameWyvern, _) => { - main_tool = Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargebreathe", - )); - }, - }, _ => None, }, Body::Theropod(body) => match body.species { diff --git a/voxygen/anim/src/bird_large/alpha.rs b/voxygen/anim/src/bird_large/alpha.rs index 0f4c77ed3c..f6e5cd592d 100644 --- a/voxygen/anim/src/bird_large/alpha.rs +++ b/voxygen/anim/src/bird_large/alpha.rs @@ -7,7 +7,7 @@ use common::states::utils::StageSection; pub struct AlphaAnimation; impl Animation for AlphaAnimation { - type Dependency<'a> = (Option, Vec3, Vec3, bool); + type Dependency<'a> = (Option, f32, f32, Vec3, Vec3, bool); type Skeleton = BirdLargeSkeleton; #[cfg(feature = "use-dyn-lib")] @@ -16,7 +16,7 @@ impl Animation for AlphaAnimation { #[cfg_attr(feature = "be-dyn-lib", export_name = "bird_large_alpha")] fn update_skeleton_inner<'a>( skeleton: &Self::Skeleton, - (stage_section, orientation, last_ori, on_ground): Self::Dependency<'a>, + (stage_section, global_time, timer, orientation, last_ori, on_ground): Self::Dependency<'a>, anim_time: f32, _rate: &mut f32, s_a: &SkeletonAttr, @@ -34,9 +34,13 @@ impl Animation for AlphaAnimation { let pullback = 1.0 - move3; + let subtract = global_time - timer; + let check = subtract - subtract.trunc(); + let mirror = (check - 0.5).signum(); + let move1 = move1base * pullback; let move2 = move2base * pullback; - + let move1mirror = move1base * pullback * mirror; let ori: Vec2 = Vec2::from(orientation); let last_ori = Vec2::from(last_ori); let tilt = if ::vek::Vec2::new(ori, last_ori) @@ -51,28 +55,25 @@ impl Animation for AlphaAnimation { 0.0 } * 1.3; - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06); + next.chest.position = Vec3::new( + 0.0, + s_a.chest.0, + s_a.chest.1 + wave_slow_cos * 0.06 + move2 * -6.0, + ); next.chest.orientation = Quaternion::rotation_x(move1 * 0.5 - move2 * 0.8); next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); - next.neck.orientation = Quaternion::rotation_x(move1 * 0.5 - move2 * 0.8) - * Quaternion::rotation_z(move1 * tilt * 1.5); + next.neck.orientation = Quaternion::rotation_x(move1 * 0.5 - move2 * 0.4) + * Quaternion::rotation_z(move1 * tilt * 1.5) + * Quaternion::rotation_y(move1mirror * 0.3); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_x(move1 * 0.5 - move2 * 0.8); + next.head.orientation = Quaternion::rotation_x(move1 * -0.2 - move2 * 0.2) + * Quaternion::rotation_y(move1mirror * 0.5); next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); - next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); + next.beak.orientation = + Quaternion::rotation_x(wave_slow_cos * -0.02 + move1 * -0.5 + move2 * 0.5); if on_ground { next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); @@ -84,23 +85,25 @@ impl Animation for AlphaAnimation { next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_l.orientation = - Quaternion::rotation_y(-1.0 + wave_slow_cos * 0.06) * Quaternion::rotation_z(0.2); + Quaternion::rotation_y(-1.0 + wave_slow_cos * 0.06 + move1 * 1.0 + move2 * 0.5) + * Quaternion::rotation_z(0.2); next.wing_in_r.orientation = - Quaternion::rotation_y(1.0 - wave_slow_cos * 0.06) * Quaternion::rotation_z(-0.2); + Quaternion::rotation_y(1.0 - wave_slow_cos * 0.06 + move1 * -1.0 + move2 * -0.5) + * Quaternion::rotation_z(-0.2); next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = - Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = - Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); + next.wing_mid_l.orientation = Quaternion::rotation_y(-0.1 + move1 * -0.5) + * Quaternion::rotation_z(0.7 + move1 * -0.7); + next.wing_mid_r.orientation = Quaternion::rotation_y(0.1 + move1 * 0.5) + * Quaternion::rotation_z(-0.7 + move1 * 0.7); next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); next.wing_out_l.orientation = - Quaternion::rotation_y(-0.2) * Quaternion::rotation_z(0.2); + Quaternion::rotation_y(-0.2 + move1 * -0.3) * Quaternion::rotation_z(0.2); next.wing_out_r.orientation = - Quaternion::rotation_y(0.2) * Quaternion::rotation_z(-0.2); + Quaternion::rotation_y(0.2 + move1 * 0.3) * Quaternion::rotation_z(-0.2); } else { } diff --git a/voxygen/anim/src/bird_large/breathe.rs b/voxygen/anim/src/bird_large/breathe.rs index 8740ac86d3..224369283e 100644 --- a/voxygen/anim/src/bird_large/breathe.rs +++ b/voxygen/anim/src/bird_large/breathe.rs @@ -7,6 +7,7 @@ use common::{states::utils::StageSection, util::Dir}; pub struct BreatheAnimation; type BreatheAnimationDependency = ( + Vec3, f32, Vec3, Vec3, @@ -26,7 +27,7 @@ impl Animation for BreatheAnimation { #[cfg_attr(feature = "be-dyn-lib", export_name = "bird_large_breathe")] fn update_skeleton_inner<'a>( skeleton: &Self::Skeleton, - (global_time, orientation, last_ori, stage_section, timer, look_dir, on_ground): Self::Dependency<'a>, + (velocity,global_time, _orientation, _last_ori, stage_section, timer, look_dir, on_ground): Self::Dependency<'a>, anim_time: f32, _rate: &mut f32, s_a: &SkeletonAttr, @@ -51,16 +52,6 @@ impl Animation for BreatheAnimation { let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - next.chest.position = Vec3::new( 0.0, s_a.chest.0, @@ -68,7 +59,8 @@ impl Animation for BreatheAnimation { ); next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); - next.neck.orientation = Quaternion::rotation_x(movement1abs * 0.5 - movement2abs * 0.5); + next.neck.orientation = + Quaternion::rotation_x(movement1abs * 0.8 - movement2abs * 0.5 + twitch2 * -0.02); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = @@ -79,17 +71,19 @@ impl Animation for BreatheAnimation { if on_ground { next.chest.orientation = - Quaternion::rotation_x(movement1abs * 0.1 - movement2abs * 0.1); - + Quaternion::rotation_x(movement1abs * 0.2 - movement2abs * 0.5 + twitch2 * 0.03); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + movement2abs * -3.0); next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); next.wing_in_l.orientation = - Quaternion::rotation_y(-1.0 + movement1abs * 0.8 - movement2abs * 0.4) - * Quaternion::rotation_z(0.2 - movement1abs * 0.8 + movement2abs * 0.4); + Quaternion::rotation_y( + -1.0 + movement1abs * 0.8 - movement2abs * 0.4 + twitch2 * 0.03, + ) * Quaternion::rotation_z(0.2 - movement1abs * 0.8 + movement2abs * 0.4); next.wing_in_r.orientation = - Quaternion::rotation_y(1.0 - movement1abs * 0.8 + movement2abs * 0.4) - * Quaternion::rotation_z(-0.2 + movement1abs * 0.8 - movement2abs * 0.4); + Quaternion::rotation_y( + 1.0 - movement1abs * 0.8 + movement2abs * 0.4 + twitch2 * -0.03, + ) * Quaternion::rotation_z(-0.2 + movement1abs * 0.8 - movement2abs * 0.4); next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); @@ -107,28 +101,19 @@ impl Animation for BreatheAnimation { next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = - Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * 0.02); + Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * 0.1); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); next.tail_rear.orientation = - Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * 0.02); + Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * -0.2); } else { - let ori: Vec2 = Vec2::from(orientation); - let last_ori = Vec2::from(last_ori); - let tilt = if ::vek::Vec2::new(ori, last_ori) - .map(|o| o.magnitude_squared()) - .map(|m| m > 0.001 && m.is_finite()) - .reduce_and() - && ori.angle_between(last_ori).is_finite() - { - ori.angle_between(last_ori).min(0.2) - * last_ori.determine_side(Vec2::zero(), ori).signum() - } else { - 0.0 - } * 1.3; + if velocity.xy().magnitude() < 1.0 { + next.neck.orientation = + Quaternion::rotation_x(movement1abs * -0.4 - movement2abs * 0.5); - next.chest.orientation = - Quaternion::rotation_x(movement1abs * 0.1 - movement2abs * 0.1) - * Quaternion::rotation_y(tilt * 1.8); + next.head.orientation = Quaternion::rotation_x( + movement1abs * 0.5 - movement2abs * 0.5 + look_dir.z * 0.4, + ); + }; } next diff --git a/voxygen/anim/src/bird_large/feed.rs b/voxygen/anim/src/bird_large/feed.rs index 71e966add9..d9a0b8aec3 100644 --- a/voxygen/anim/src/bird_large/feed.rs +++ b/voxygen/anim/src/bird_large/feed.rs @@ -39,16 +39,6 @@ impl Animation for FeedAnimation { let wave_fast = (anim_time * 9.0).cos(); let beak = (anim_time * 16.0).sin(); - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 - 1.8); next.chest.orientation = Quaternion::rotation_x(s_a.feed); diff --git a/voxygen/anim/src/bird_large/fly.rs b/voxygen/anim/src/bird_large/fly.rs index b39bab980a..daba5c33ea 100644 --- a/voxygen/anim/src/bird_large/fly.rs +++ b/voxygen/anim/src/bird_large/fly.rs @@ -26,7 +26,7 @@ impl Animation for FlyAnimation { let fast = (anim_time * 4.0).sin(); // Harmonic series hack to get a sine/saw mix - let freq = if s_a.wyvern {6.0} else {8.0}; + let freq = if s_a.wyvern { 6.0 } else { 8.0 }; let off1 = 0.0; let off2 = -1.7; let off3 = -2.0; @@ -60,11 +60,11 @@ impl Animation for FlyAnimation { next.head.scale = Vec3::one() * 0.99; next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; + next.leg_l.scale = Vec3::one(); + next.leg_r.scale = Vec3::one(); next.foot_l.scale = Vec3::one() * 1.01; next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; next.tail_front.scale = Vec3::one() * 1.01; next.tail_rear.scale = Vec3::one() * 0.99; diff --git a/voxygen/anim/src/bird_large/idle.rs b/voxygen/anim/src/bird_large/idle.rs index 505f032398..077af67474 100644 --- a/voxygen/anim/src/bird_large/idle.rs +++ b/voxygen/anim/src/bird_large/idle.rs @@ -39,11 +39,11 @@ impl Animation for IdleAnimation { next.head.scale = Vec3::one() * 0.99; next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; + next.leg_l.scale = Vec3::one(); + next.leg_r.scale = Vec3::one(); next.foot_l.scale = Vec3::one() * 1.01; next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler / 8.0 * 0.99; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; next.tail_front.scale = Vec3::one() * 1.01; next.tail_rear.scale = Vec3::one() * 0.99; @@ -53,7 +53,7 @@ impl Animation for IdleAnimation { next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); next.beak.orientation = Quaternion::rotation_x(wave_slow_cos * -0.02 - 0.02); - next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2) / 8.0; + next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_l.orientation = Quaternion::rotation_x(0.0); next.leg_r.position = Vec3::new(s_a.leg.0, s_a.leg.1, s_a.leg.2); next.leg_r.orientation = Quaternion::rotation_x(0.0); @@ -65,7 +65,7 @@ impl Animation for IdleAnimation { if s_a.wyvern { next.chest.position = - Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06) * s_a.scaler / 8.0; + Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06) * s_a.scaler; next.chest.orientation = Quaternion::rotation_x(-0.1); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); @@ -104,8 +104,7 @@ impl Animation for IdleAnimation { * Quaternion::rotation_z(-0.55); } else { next.chest.position = - Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 + 1.5) * s_a.scaler - / 8.0; + Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06 + 1.5) * s_a.scaler; next.chest.orientation = Quaternion::rotation_x(0.0); next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); diff --git a/voxygen/anim/src/bird_large/run.rs b/voxygen/anim/src/bird_large/run.rs index 89278109bd..2e9e7fbb98 100644 --- a/voxygen/anim/src/bird_large/run.rs +++ b/voxygen/anim/src/bird_large/run.rs @@ -67,11 +67,11 @@ impl Animation for RunAnimation { next.head.scale = Vec3::one() * 0.99; next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; + next.leg_l.scale = Vec3::one(); + next.leg_r.scale = Vec3::one(); next.foot_l.scale = Vec3::one() * 1.01; next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler* 0.99; + next.chest.scale = Vec3::one() * s_a.scaler * 0.99; next.tail_front.scale = Vec3::one() * 1.01; next.tail_rear.scale = Vec3::one() * 0.99; @@ -93,7 +93,7 @@ impl Animation for RunAnimation { s_a.foot.1 + foot1b * -1.0, s_a.foot.2 + (foot1a * 1.5).max(0.0), ); - next.foot_l.orientation = Quaternion::rotation_x(0.2 * speednorm + foot1b * -0.5 + 0.1) + next.foot_l.orientation = Quaternion::rotation_x(0.2 * speednorm + foot1b * -0.8 + 0.1) * Quaternion::rotation_y(tilt * -1.0) * Quaternion::rotation_z(tilt * -0.5); @@ -102,7 +102,7 @@ impl Animation for RunAnimation { s_a.foot.1 + foot2b * -1.0, s_a.foot.2 + (foot2a * 1.5).max(0.0), ); - next.foot_r.orientation = Quaternion::rotation_x(0.2 * speednorm + foot2b * -0.5 + 0.1) + next.foot_r.orientation = Quaternion::rotation_x(0.2 * speednorm + foot2b * -0.8 + 0.1) * Quaternion::rotation_y(tilt * -1.0) * Quaternion::rotation_z(tilt * -0.5); @@ -111,8 +111,7 @@ impl Animation for RunAnimation { 0.0, s_a.chest.0, s_a.chest.1 + short * 0.5 + speednorm * -2.0, - ) * s_a.scaler - / 8.0; + ) * s_a.scaler; next.chest.orientation = Quaternion::rotation_x(-0.1 + short * 0.07) * Quaternion::rotation_y(tilt * 0.8) * Quaternion::rotation_z(shortalt * 0.10); @@ -162,16 +161,16 @@ impl Animation for RunAnimation { next.leg_l.position = Vec3::new( -s_a.leg.0, s_a.leg.1 + foot1b * -2.3, - s_a.leg.2, - ) / 8.0; + s_a.leg.2 + foot2b * -1.5, + ); next.leg_l.orientation = Quaternion::rotation_x(-1.0 * speednorm + foot1a * 0.15) * Quaternion::rotation_y(tilt * 0.5); next.leg_r.position = Vec3::new( s_a.leg.0, s_a.leg.1 + foot2b * -2.3, - s_a.leg.2, - ) / 8.0; + s_a.leg.2 + foot1b * -1.5, + ); next.leg_r.orientation = Quaternion::rotation_x(-1.0 * speednorm + foot2a * 0.15) * Quaternion::rotation_y(tilt * 0.5); } else { @@ -179,8 +178,7 @@ impl Animation for RunAnimation { 0.0, s_a.chest.0, s_a.chest.1 + short * 0.5 + 0.5 * speednorm, - ) * s_a.scaler - / 8.0; + ) * s_a.scaler; next.chest.orientation = Quaternion::rotation_x(short * 0.07) * Quaternion::rotation_y(tilt * 0.8) * Quaternion::rotation_z(shortalt * 0.10); @@ -211,19 +209,11 @@ impl Animation for RunAnimation { next.wing_out_r.orientation = Quaternion::rotation_y(0.2 + short * -0.05) * Quaternion::rotation_z(-0.2); - next.leg_l.position = Vec3::new( - -s_a.leg.0, - s_a.leg.1 + foot1b * -2.3, - s_a.leg.2, - ) / 8.0; + next.leg_l.position = Vec3::new(-s_a.leg.0, s_a.leg.1 + foot1b * -2.3, s_a.leg.2); next.leg_l.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot1a * 0.15) * Quaternion::rotation_y(tilt * 0.5); - next.leg_r.position = Vec3::new( - s_a.leg.0, - s_a.leg.1 + foot2b * -2.3, - s_a.leg.2, - ) / 8.0; + next.leg_r.position = Vec3::new(s_a.leg.0, s_a.leg.1 + foot2b * -2.3, s_a.leg.2); next.leg_r.orientation = Quaternion::rotation_x(-0.2 * speednorm + foot2a * 0.15) * Quaternion::rotation_y(tilt * 0.5); } diff --git a/voxygen/anim/src/bird_large/shockwave.rs b/voxygen/anim/src/bird_large/shockwave.rs index b13f1c8608..55305741da 100644 --- a/voxygen/anim/src/bird_large/shockwave.rs +++ b/voxygen/anim/src/bird_large/shockwave.rs @@ -38,16 +38,6 @@ impl Animation for ShockwaveAnimation { let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + movement1abs * 1.5); next.chest.orientation = Quaternion::rotation_x(movement1abs * 1.0 + movement2abs * -1.0); diff --git a/voxygen/anim/src/bird_large/shoot.rs b/voxygen/anim/src/bird_large/shoot.rs index d85aab489c..077db9a61b 100644 --- a/voxygen/anim/src/bird_large/shoot.rs +++ b/voxygen/anim/src/bird_large/shoot.rs @@ -6,7 +6,7 @@ use common::{states::utils::StageSection, util::Dir}; pub struct ShootAnimation; -type ShootAnimationDependency = (f32, Option, f32, Dir, bool); +type ShootAnimationDependency = (Vec3, f32, Option, f32, Dir, bool); impl Animation for ShootAnimation { type Dependency<'a> = ShootAnimationDependency; @@ -18,18 +18,17 @@ impl Animation for ShootAnimation { #[cfg_attr(feature = "be-dyn-lib", export_name = "bird_large_shoot")] fn update_skeleton_inner<'a>( skeleton: &Self::Skeleton, - (global_time, stage_section, timer, look_dir, on_ground): Self::Dependency<'a>, + (velocity, global_time, stage_section, timer, look_dir, on_ground): Self::Dependency<'a>, anim_time: f32, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let (movement1base, movement2base, movement3, twitch) = match stage_section { - Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0, 0.0), - Some(StageSection::Action) => (1.0, anim_time.min(1.0).powf(0.1), 0.0, anim_time), - Some(StageSection::Recover) => (1.0, 1.0, anim_time, 1.0), - _ => (0.0, 0.0, 0.0, 0.0), + let (movement1base, movement3, twitch) = match stage_section { + Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0), + Some(StageSection::Recover) => (1.0, anim_time.powf(0.25), anim_time), + _ => (0.0, 0.0, 0.0), }; let pullback = 1.0 - movement3; @@ -37,22 +36,11 @@ impl Animation for ShootAnimation { let check = subtract - subtract.trunc(); let mirror = (check - 0.5).signum(); let twitch2 = mirror * (twitch * 20.0).sin() * pullback; - let movement1abs = movement1base * pullback; - let movement2abs = movement2base * pullback; + let movement1mirror = movement1abs * mirror; let wave_slow_cos = (anim_time * 4.5).cos(); - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - next.chest.position = Vec3::new( 0.0, s_a.chest.0, @@ -61,51 +49,44 @@ impl Animation for ShootAnimation { next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = - Quaternion::rotation_x(movement1abs * 0.5 - movement2abs * 0.5 + look_dir.z * 0.4); + Quaternion::rotation_x(movement1abs * 0.5 + look_dir.z * 0.4 + twitch2) + * Quaternion::rotation_y(movement1mirror * 0.5); next.beak.position = Vec3::new(0.0, s_a.beak.0, s_a.beak.1); next.beak.orientation = Quaternion::rotation_x(movement1abs * -0.7 + twitch2 * 0.1); if on_ground { + next.chest.position = Vec3::new( + 0.0, + s_a.chest.0, + s_a.chest.1 + wave_slow_cos * 0.06 + twitch2 * 0.1 + movement1abs * -3.0, + ); next.neck.position = Vec3::new(0.0, s_a.neck.0, s_a.neck.1); - next.neck.orientation = Quaternion::rotation_x(movement1abs * 0.5 - movement2abs * 0.5); + next.neck.orientation = Quaternion::rotation_x(movement1abs * 0.5) + * Quaternion::rotation_y(movement1mirror * 0.2); - next.chest.orientation = - Quaternion::rotation_x(movement1abs * 0.1 - movement2abs * 0.1); - - next.wing_in_l.position = Vec3::new(-s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - next.wing_in_r.position = Vec3::new(s_a.wing_in.0, s_a.wing_in.1, s_a.wing_in.2); - - next.wing_in_l.orientation = - Quaternion::rotation_y(-1.0 + movement1abs * 0.8 - movement2abs * 0.4) - * Quaternion::rotation_z(0.2 - movement1abs * 0.8 + movement2abs * 0.4); - next.wing_in_r.orientation = - Quaternion::rotation_y(1.0 - movement1abs * 0.8 + movement2abs * 0.4) - * Quaternion::rotation_z(-0.2 + movement1abs * 0.8 - movement2abs * 0.4); - - next.wing_mid_l.position = Vec3::new(-s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_r.position = Vec3::new(s_a.wing_mid.0, s_a.wing_mid.1, s_a.wing_mid.2); - next.wing_mid_l.orientation = - Quaternion::rotation_y(-0.1) * Quaternion::rotation_z(0.7); - next.wing_mid_r.orientation = - Quaternion::rotation_y(0.1) * Quaternion::rotation_z(-0.7); - - next.wing_out_l.position = Vec3::new(-s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_r.position = Vec3::new(s_a.wing_out.0, s_a.wing_out.1, s_a.wing_out.2); - next.wing_out_l.orientation = - Quaternion::rotation_y(-0.2) * Quaternion::rotation_z(0.2); - next.wing_out_r.orientation = - Quaternion::rotation_y(0.2) * Quaternion::rotation_z(-0.2); + next.chest.orientation = Quaternion::rotation_x(movement1abs * 0.1); next.tail_front.position = Vec3::new(0.0, s_a.tail_front.0, s_a.tail_front.1); next.tail_front.orientation = - Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * 0.02); + Quaternion::rotation_x(-movement1abs * 0.1 + twitch2 * 0.02); next.tail_rear.position = Vec3::new(0.0, s_a.tail_rear.0, s_a.tail_rear.1); next.tail_rear.orientation = - Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * 0.02); + Quaternion::rotation_x(-movement1abs * 0.1 + twitch2 * 0.02); + + next.leg_l.orientation = Quaternion::rotation_x(movement1abs * -0.5); + next.leg_r.orientation = Quaternion::rotation_x(movement1abs * -0.5); + + next.foot_l.orientation = Quaternion::rotation_x(movement1abs * 0.3); + next.foot_r.orientation = Quaternion::rotation_x(movement1abs * 0.3); } else { } - + if velocity.xy().magnitude() < 1.0 { + next.wing_in_l.orientation = Quaternion::rotation_y(-1.0 + movement1abs * 0.8) + * Quaternion::rotation_z(0.2 - movement1abs * 0.8); + next.wing_in_r.orientation = Quaternion::rotation_y(1.0 - movement1abs * 0.8) + * Quaternion::rotation_z(-0.2 + movement1abs * 0.8); + }; next } } diff --git a/voxygen/anim/src/bird_large/stunned.rs b/voxygen/anim/src/bird_large/stunned.rs index 7cc6588862..5e27c654f9 100644 --- a/voxygen/anim/src/bird_large/stunned.rs +++ b/voxygen/anim/src/bird_large/stunned.rs @@ -37,16 +37,6 @@ impl Animation for StunnedAnimation { let twitch2 = mirror * (twitch * 20.0).sin() * pullback; let movement1abs = movement1base * pullback; - next.head.scale = Vec3::one() * 0.99; - next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; - next.foot_l.scale = Vec3::one() * 1.01; - next.foot_r.scale = Vec3::one() * 1.01; - next.chest.scale = Vec3::one() * s_a.scaler * 0.99; - next.tail_front.scale = Vec3::one() * 1.01; - next.tail_rear.scale = Vec3::one() * 0.99; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1 + wave_slow_cos * 0.06); next.chest.orientation = Quaternion::rotation_x(movement1base * 0.5); diff --git a/voxygen/anim/src/bird_large/swim.rs b/voxygen/anim/src/bird_large/swim.rs index a1299944f6..9c809bdd6a 100644 --- a/voxygen/anim/src/bird_large/swim.rs +++ b/voxygen/anim/src/bird_large/swim.rs @@ -43,8 +43,8 @@ impl Animation for SwimAnimation { next.head.scale = Vec3::one() * 0.99; next.neck.scale = Vec3::one() * 1.01; - next.leg_l.scale = Vec3::one() / 8.0; - next.leg_r.scale = Vec3::one() / 8.0; + next.leg_l.scale = Vec3::one(); + next.leg_r.scale = Vec3::one(); next.foot_l.scale = Vec3::one() * 1.01; next.foot_r.scale = Vec3::one() * 1.01; next.chest.scale = Vec3::one() * s_a.scaler * 0.99; diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index 9c409129f5..97bc171988 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -3427,6 +3427,7 @@ impl FigureMgr { anim::bird_large::BreatheAnimation::update_skeleton( &target_base, ( + rel_vel, time, ori * anim::vek::Vec3::::unit_y(), state.last_ori * anim::vek::Vec3::::unit_y(), @@ -3465,6 +3466,8 @@ impl FigureMgr { &target_base, ( Some(s.stage_section), + time, + state.state_time, ori * anim::vek::Vec3::::unit_y(), state.last_ori * anim::vek::Vec3::::unit_y(), physics.on_ground.is_some(), @@ -3490,6 +3493,7 @@ impl FigureMgr { anim::bird_large::ShootAnimation::update_skeleton( &target_base, ( + rel_vel, time, Some(s.stage_section), state.state_time, From 7a73e4240bd415f1420540ce2eeb22eae68b624a Mon Sep 17 00:00:00 2001 From: Snowram Date: Thu, 16 Sep 2021 01:25:00 +0200 Subject: [PATCH 6/8] Bird large beam offset hack --- common/src/comp/inventory/loadout_builder.rs | 9 ++--- common/src/states/basic_beam.rs | 35 ++++++++++++++++---- server/src/sys/agent.rs | 3 ++ voxygen/anim/src/bird_large/breathe.rs | 16 +++++---- voxygen/anim/src/bird_large/mod.rs | 5 +-- 5 files changed, 44 insertions(+), 24 deletions(-) diff --git a/common/src/comp/inventory/loadout_builder.rs b/common/src/comp/inventory/loadout_builder.rs index 5af8102058..24446d138d 100644 --- a/common/src/comp/inventory/loadout_builder.rs +++ b/common/src/comp/inventory/loadout_builder.rs @@ -343,18 +343,15 @@ fn default_main_tool(body: &Body) -> Item { )), }, Body::BirdLarge(bird_large) => match (bird_large.species, bird_large.body_type) { - (bird_large::Species::Cockatrice, _) => Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargebreathe", - )), + (bird_large::Species::Cockatrice | bird_large::Species::FlameWyvern, _) => Some( + Item::new_from_asset_expect("common.items.npc_weapons.unique.birdlargebreathe"), + ), (bird_large::Species::Phoenix, _) => Some(Item::new_from_asset_expect( "common.items.npc_weapons.unique.birdlargefire", )), (bird_large::Species::Roc, _) => Some(Item::new_from_asset_expect( "common.items.npc_weapons.unique.birdlargebasic", )), - (bird_large::Species::FlameWyvern, _) => Some(Item::new_from_asset_expect( - "common.items.npc_weapons.unique.birdlargebreathe", - )), }, _ => None, }; diff --git a/common/src/states/basic_beam.rs b/common/src/states/basic_beam.rs index d67604fdc9..ffa0e2f14c 100644 --- a/common/src/states/basic_beam.rs +++ b/common/src/states/basic_beam.rs @@ -12,6 +12,7 @@ use crate::{ behavior::{CharacterBehavior, JoinData}, utils::*, }, + terrain::Block, uid::Uid, util::Dir, }; @@ -160,9 +161,16 @@ impl CharacterBehavior for Data { )) .prerotated(pitch) }; + // Velocity relative to the current ground + let rel_vel = data.vel.0 - data.physics.ground_vel; // Gets offsets - let body_offsets = - beam_offsets(data.body, data.inputs.look_dir, update.ori.look_vec()); + let body_offsets = beam_offsets( + data.body, + data.inputs.look_dir, + update.ori.look_vec(), + rel_vel, + data.physics.on_ground, + ); let pos = Pos(data.pos.0 + body_offsets); // Create beam segment @@ -219,9 +227,17 @@ impl CharacterBehavior for Data { } } -fn height_offset(body: &Body, look_dir: Dir) -> f32 { +fn height_offset(body: &Body, look_dir: Dir, velocity: Vec3, on_ground: Option) -> f32 { match body { - Body::BirdLarge(_) => body.height() * 0.8, + // Hack to make the beam offset correspond to the animation + Body::BirdLarge(_) => { + body.height() * 0.3 + + if on_ground.is_none() { + (2.0 - velocity.xy().magnitude() * 0.25).max(-1.0) + } else { + 0.0 + } + }, Body::Golem(_) => { const DIR_COEFF: f32 = 2.0; body.height() * 0.9 + look_dir.z * DIR_COEFF @@ -234,10 +250,15 @@ fn height_offset(body: &Body, look_dir: Dir) -> f32 { } } -pub fn beam_offsets(body: &Body, look_dir: Dir, ori: Vec3) -> Vec3 { +pub fn beam_offsets( + body: &Body, + look_dir: Dir, + ori: Vec3, + velocity: Vec3, + on_ground: Option, +) -> Vec3 { let body_radius = body.min_radius(); - let body_offsets_z = height_offset(body, look_dir); - + let body_offsets_z = height_offset(body, look_dir, velocity, on_ground); Vec3::new( body_radius * ori.x * 1.1, body_radius * ori.y * 1.1, diff --git a/server/src/sys/agent.rs b/server/src/sys/agent.rs index 9aaaaa94e9..bab6cdb37b 100644 --- a/server/src/sys/agent.rs +++ b/server/src/sys/agent.rs @@ -1884,6 +1884,9 @@ impl<'a> AgentData<'a> { body, controller.inputs.look_dir, self.ori.look_vec(), + // Try to match animation by getting some context + self.vel.0 - self.physics_state.ground_vel, + self.physics_state.on_ground, ) }); let aim_to = Vec3::new( diff --git a/voxygen/anim/src/bird_large/breathe.rs b/voxygen/anim/src/bird_large/breathe.rs index 224369283e..1c5708d4d9 100644 --- a/voxygen/anim/src/bird_large/breathe.rs +++ b/voxygen/anim/src/bird_large/breathe.rs @@ -106,14 +106,16 @@ impl Animation for BreatheAnimation { next.tail_rear.orientation = Quaternion::rotation_x(-movement1abs * 0.1 + movement2abs * 0.1 + twitch2 * -0.2); } else { - if velocity.xy().magnitude() < 1.0 { - next.neck.orientation = - Quaternion::rotation_x(movement1abs * -0.4 - movement2abs * 0.5); + next.neck.orientation = Quaternion::rotation_x( + movement1abs * -0.4 + + movement2abs * (-0.5 + velocity.xy().magnitude() * 0.2).min(0.0), + ); - next.head.orientation = Quaternion::rotation_x( - movement1abs * 0.5 - movement2abs * 0.5 + look_dir.z * 0.4, - ); - }; + next.head.orientation = Quaternion::rotation_x( + movement1abs * 0.5 + + movement2abs * (-0.5 + velocity.xy().magnitude() * 0.2).min(0.0) + + look_dir.z * 0.4, + ); } next diff --git a/voxygen/anim/src/bird_large/mod.rs b/voxygen/anim/src/bird_large/mod.rs index b8363215e3..31569d6fd8 100644 --- a/voxygen/anim/src/bird_large/mod.rs +++ b/voxygen/anim/src/bird_large/mod.rs @@ -241,10 +241,7 @@ impl<'a> From<&'a Body> for SkeletonAttr { (Roc, _) => (-0.4), (FlameWyvern, _) => (-0.65), }, - wyvern: match (body.species, body.body_type) { - (FlameWyvern, _) => true, - _ => false, - }, + wyvern: matches!((body.species, body.body_type), (FlameWyvern, _)), } } } From cf6bf74f7a55b146c0b04a8ddafbf116fb3210fb Mon Sep 17 00:00:00 2001 From: Snowram Date: Sat, 18 Sep 2021 14:47:06 +0200 Subject: [PATCH 7/8] Set beam offset depending on body dimensions --- common/src/comp/body.rs | 8 -------- common/src/states/basic_beam.rs | 11 ++++++++++- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/common/src/comp/body.rs b/common/src/comp/body.rs index ecc6bc3ac2..fe389bae7e 100644 --- a/common/src/comp/body.rs +++ b/common/src/comp/body.rs @@ -147,14 +147,6 @@ impl< const EXTENSION: &'static str = "ron"; } -// Utility enum used to build Stadium points -// Read doc for [Body::sausage] for more. -// -// Actually can be removed I guess? -// We can just determine shape form dimensions. -// -// But I want Dachshund in Veloren at least somewhere XD - impl Body { pub fn is_humanoid(&self) -> bool { matches!(self, Body::Humanoid(_)) } diff --git a/common/src/states/basic_beam.rs b/common/src/states/basic_beam.rs index ffa0e2f14c..a9da6c3f24 100644 --- a/common/src/states/basic_beam.rs +++ b/common/src/states/basic_beam.rs @@ -257,7 +257,16 @@ pub fn beam_offsets( velocity: Vec3, on_ground: Option, ) -> Vec3 { - let body_radius = body.min_radius(); + let dim = body.dimensions(); + // The width (shoulder to shoulder) and length (nose to tail) + let (width, length) = (dim.x, dim.y); + let body_radius = if length > width { + // Dachshund-like + body.max_radius() + } else { + // Cyclops-like + body.min_radius() + }; let body_offsets_z = height_offset(body, look_dir, velocity, on_ground); Vec3::new( body_radius * ori.x * 1.1, From 3c2de422db8b0fe8355330a265118d621c00d380 Mon Sep 17 00:00:00 2001 From: Snowram Date: Tue, 21 Sep 2021 01:19:34 +0200 Subject: [PATCH 8/8] Adds Xtilt to BirdLarge skeleton --- voxygen/anim/src/bird_large/run.rs | 13 +++++++------ voxygen/src/scene/figure/mod.rs | 4 ++++ 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/voxygen/anim/src/bird_large/run.rs b/voxygen/anim/src/bird_large/run.rs index 2e9e7fbb98..b2909c201d 100644 --- a/voxygen/anim/src/bird_large/run.rs +++ b/voxygen/anim/src/bird_large/run.rs @@ -7,7 +7,7 @@ use core::f32::consts::PI; pub struct RunAnimation; impl Animation for RunAnimation { - type Dependency<'a> = (Vec3, Vec3, Vec3, f32); + type Dependency<'a> = (Vec3, Vec3, Vec3, Vec3, f32); type Skeleton = BirdLargeSkeleton; #[cfg(feature = "use-dyn-lib")] @@ -16,7 +16,7 @@ impl Animation for RunAnimation { #[cfg_attr(feature = "be-dyn-lib", export_name = "bird_large_run")] fn update_skeleton_inner<'a>( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, acc_vel): Self::Dependency<'a>, + (velocity, orientation, last_ori, avg_vel, acc_vel): Self::Dependency<'a>, anim_time: f32, rate: &mut f32, s_a: &SkeletonAttr, @@ -64,6 +64,7 @@ impl Animation for RunAnimation { } else { 0.0 } * 1.3; + let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()) * speednorm; next.head.scale = Vec3::one() * 0.99; next.neck.scale = Vec3::one() * 1.01; @@ -110,9 +111,9 @@ impl Animation for RunAnimation { next.chest.position = Vec3::new( 0.0, s_a.chest.0, - s_a.chest.1 + short * 0.5 + speednorm * -2.0, + s_a.chest.1 + short * 0.5 + x_tilt * 10.0 + speednorm * -2.0, ) * s_a.scaler; - next.chest.orientation = Quaternion::rotation_x(-0.1 + short * 0.07) + next.chest.orientation = Quaternion::rotation_x(-0.1 + short * 0.07 + x_tilt) * Quaternion::rotation_y(tilt * 0.8) * Quaternion::rotation_z(shortalt * 0.10); @@ -177,9 +178,9 @@ impl Animation for RunAnimation { next.chest.position = Vec3::new( 0.0, s_a.chest.0, - s_a.chest.1 + short * 0.5 + 0.5 * speednorm, + s_a.chest.1 + short * 0.5 + x_tilt * 10.0 + 0.5 * speednorm, ) * s_a.scaler; - next.chest.orientation = Quaternion::rotation_x(short * 0.07) + next.chest.orientation = Quaternion::rotation_x(short * 0.07 + x_tilt) * Quaternion::rotation_y(tilt * 0.8) * Quaternion::rotation_z(shortalt * 0.10); diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index 97bc171988..e0d87e8fc0 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -3336,6 +3336,9 @@ impl FigureMgr { FigureState::new(renderer, BirdLargeSkeleton::default(), body) }); + // Average velocity relative to the current ground + let rel_avg_vel = state.avg_vel - physics.ground_vel; + let (character, last_character) = match (character, last_character) { (Some(c), Some(l)) => (c, l), _ => continue, @@ -3366,6 +3369,7 @@ impl FigureMgr { // TODO: Update to use the quaternion. ori * anim::vek::Vec3::::unit_y(), state.last_ori * anim::vek::Vec3::::unit_y(), + rel_avg_vel, state.acc_vel, ), state.state_time,