From 80fbf6e225c88fc6f1c77de9bb3650e3526724d8 Mon Sep 17 00:00:00 2001 From: Snowram Date: Thu, 26 Nov 2020 22:57:38 +0100 Subject: [PATCH 1/5] Initial fish work --- assets/common/npc_names.json | 22 +- .../voxel/fish_medium_central_manifest.ron | 46 ++ .../voxel/fish_medium_lateral_manifest.ron | 22 + .../voxel/fish_small_central_manifest.ron | 30 ++ .../voxel/fish_small_lateral_manifest.ron | 22 + assets/voxygen/voxel/npc/marlin/head.vox | Bin 1352 -> 0 bytes .../marlin/{rear.vox => male/chest_back.vox} | Bin 1360 -> 1360 bytes .../voxel/npc/marlin/male/chest_front.vox | Bin 0 -> 1476 bytes .../voxel/npc/marlin/{ => male}/fin_l.vox | Bin 1152 -> 1152 bytes .../voxel/npc/marlin/{ => male}/fin_r.vox | Bin 1152 -> 1152 bytes assets/voxygen/voxel/npc/marlin/male/head.vox | Bin 0 -> 1352 bytes assets/voxygen/voxel/npc/marlin/male/tail.vox | Bin 0 -> 1308 bytes assets/voxygen/voxel/npc/marlin/tail.vox | Bin 1308 -> 0 bytes assets/voxygen/voxel/npc/marlin/torso.vox | Bin 1476 -> 0 bytes common/src/comp/body.rs | 10 +- common/src/comp/body/fish_medium.rs | 119 +++-- common/src/comp/body/fish_small.rs | 72 ++- common/src/generation.rs | 2 + common/src/npc.rs | 24 +- common/src/states/utils.rs | 4 +- voxygen/anim/src/fish_medium/idle.rs | 43 +- voxygen/anim/src/fish_medium/jump.rs | 28 +- voxygen/anim/src/fish_medium/mod.rs | 76 +++- voxygen/anim/src/fish_medium/run.rs | 28 +- voxygen/anim/src/fish_small/idle.rs | 22 +- voxygen/anim/src/fish_small/jump.rs | 22 +- voxygen/anim/src/fish_small/mod.rs | 54 ++- voxygen/anim/src/fish_small/run.rs | 22 +- voxygen/src/anim/src/fish_medium/swim.rs | 78 ++++ voxygen/src/anim/src/fish_medium/swimidle.rs | 57 +++ voxygen/src/anim/src/fish_small/swim.rs | 46 ++ voxygen/src/scene/figure/load.rs | 425 ++++++++++++++---- voxygen/src/scene/figure/mod.rs | 22 +- world/src/layer/wildlife.rs | 19 +- 34 files changed, 1015 insertions(+), 300 deletions(-) create mode 100644 assets/voxygen/voxel/fish_medium_central_manifest.ron create mode 100644 assets/voxygen/voxel/fish_medium_lateral_manifest.ron create mode 100644 assets/voxygen/voxel/fish_small_central_manifest.ron create mode 100644 assets/voxygen/voxel/fish_small_lateral_manifest.ron delete mode 100644 assets/voxygen/voxel/npc/marlin/head.vox rename assets/voxygen/voxel/npc/marlin/{rear.vox => male/chest_back.vox} (70%) create mode 100644 assets/voxygen/voxel/npc/marlin/male/chest_front.vox rename assets/voxygen/voxel/npc/marlin/{ => male}/fin_l.vox (88%) rename assets/voxygen/voxel/npc/marlin/{ => male}/fin_r.vox (88%) create mode 100644 assets/voxygen/voxel/npc/marlin/male/head.vox create mode 100644 assets/voxygen/voxel/npc/marlin/male/tail.vox delete mode 100644 assets/voxygen/voxel/npc/marlin/tail.vox delete mode 100644 assets/voxygen/voxel/npc/marlin/torso.vox create mode 100644 voxygen/src/anim/src/fish_medium/swim.rs create mode 100644 voxygen/src/anim/src/fish_medium/swimidle.rs create mode 100644 voxygen/src/anim/src/fish_small/swim.rs diff --git a/assets/common/npc_names.json b/assets/common/npc_names.json index a6ed9ad6a5..121b6da491 100644 --- a/assets/common/npc_names.json +++ b/assets/common/npc_names.json @@ -700,16 +700,30 @@ "fish_small": { "body": { "keyword": "fish_small", - "names": [] + "names": [ + "Dagon" + ] }, - "species": null + "species": { + "sardine": { + "keyword": "sardine", + "generic": "Sardine" + } + } }, "fish_medium": { "body": { "keyword": "fish_medium", - "names": [] + "names": [ + "Njord" + ] }, - "species": null + "species": { + "marlin": { + "keyword": "marlin", + "generic": "Marlin" + } + } }, "bird_small": { "body": { diff --git a/assets/voxygen/voxel/fish_medium_central_manifest.ron b/assets/voxygen/voxel/fish_medium_central_manifest.ron new file mode 100644 index 0000000000..bba6d4e700 --- /dev/null +++ b/assets/voxygen/voxel/fish_medium_central_manifest.ron @@ -0,0 +1,46 @@ +({ + (Marlin, Male): ( + head: ( + offset: (-2.5, 0.0, -3.0), + central: ("npc.marlin.male.head"), + ), + jaw: ( + offset: (-4.0, 0.0, -1.5), + central: ("armor.empty"), + ), + chest_front: ( + offset: (-2.5, -5.0, -2.5), + central: ("npc.marlin.male.chest_front"), + ), + chest_back: ( + offset: (-2.5, -7.0, -3.5), + central: ("npc.marlin.male.chest_back"), + ), + tail: ( + offset: (-0.5, -11.0, -4.5), + central: ("npc.marlin.male.tail"), + ), + ), + (Marlin, Female): ( + head: ( + offset: (-2.5, 0.0, -3.0), + central: ("npc.marlin.male.head"), + ), + jaw: ( + offset: (-4.0, 0.0, -1.5), + central: ("armor.empty"), + ), + chest_front: ( + offset: (-2.5, -5.0, -2.5), + central: ("npc.marlin.male.chest_front"), + ), + chest_back: ( + offset: (-2.5, -7.0, -3.5), + central: ("npc.marlin.male.chest_back"), + ), + tail: ( + offset: (-0.5, -11.0, -4.5), + central: ("npc.marlin.male.tail"), + ), + ), +}) diff --git a/assets/voxygen/voxel/fish_medium_lateral_manifest.ron b/assets/voxygen/voxel/fish_medium_lateral_manifest.ron new file mode 100644 index 0000000000..cd6184b305 --- /dev/null +++ b/assets/voxygen/voxel/fish_medium_lateral_manifest.ron @@ -0,0 +1,22 @@ +({ + (Marlin, Male): ( + fin_l: ( + offset: (-3.0, -5.0, -4.0), + lateral: ("npc.marlin.male.fin_l"), + ), + fin_r: ( + offset: (0.0, -5.0, -4.0), + lateral: ("npc.marlin.male.fin_r"), + ), + ), + (Marlin, Female): ( + fin_l: ( + offset: (-3.0, -5.0, -4.0), + lateral: ("npc.marlin.male.fin_l"), + ), + fin_r: ( + offset: (0.0, -5.0, -4.0), + lateral: ("npc.marlin.male.fin_r"), + ), + ), +}) diff --git a/assets/voxygen/voxel/fish_small_central_manifest.ron b/assets/voxygen/voxel/fish_small_central_manifest.ron new file mode 100644 index 0000000000..13abb5b285 --- /dev/null +++ b/assets/voxygen/voxel/fish_small_central_manifest.ron @@ -0,0 +1,30 @@ +({ + (Sardine, Male): ( + head: ( + offset: (-4.0, 0.0, -3.0), + central: ("npc.sardine.male.head"), + ), + chest: ( + offset: (-5.0, -7.5, -3.0), + central: ("npc.sardine.male.chest"), + ), + tail: ( + offset: (-1.0, -9.0, -1.5), + central: ("npc.sardine.male.tail"), + ), + ), + (Sardine, Female): ( + head: ( + offset: (-4.0, 0.0, -3.0), + central: ("npc.sardine.male.head"), + ), + chest: ( + offset: (-5.0, -7.5, -3.0), + central: ("npc.sardine.male.chest"), + ), + tail: ( + offset: (-1.0, -9.0, -1.5), + central: ("npc.sardine.male.tail"), + ), + ), +}) diff --git a/assets/voxygen/voxel/fish_small_lateral_manifest.ron b/assets/voxygen/voxel/fish_small_lateral_manifest.ron new file mode 100644 index 0000000000..c93e3579df --- /dev/null +++ b/assets/voxygen/voxel/fish_small_lateral_manifest.ron @@ -0,0 +1,22 @@ +({ + (Sardine, Male): ( + fin_l: ( + offset: (-1.5, -5.0, -3.0), + lateral: ("npc.sardine.male.fin_l"), + ), + fin_r: ( + offset: (-1.5, -5.0, -3.0), + lateral: ("npc.sardine.male.fin_r"), + ), + ), + (Sardine, Female): ( + fin_l: ( + offset: (-1.5, -5.0, -3.0), + lateral: ("npc.sardine.male.fin_l"), + ), + fin_r: ( + offset: (-1.5, -5.0, -3.0), + lateral: ("npc.sardine.male.fin_r"), + ), + ), +}) diff --git a/assets/voxygen/voxel/npc/marlin/head.vox b/assets/voxygen/voxel/npc/marlin/head.vox deleted file mode 100644 index 830d13093434be0e6f25aff636d1339d60775928..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1352 zcmXAnv1=4T6o=o;?(ObHoBI#sT5V*svN3uhDbz%{7;S81KoHBM5lm+qF+~tw5Ueb6 zwUxnAh%jZ?tFE@YGAV>SznR?Lw>$IO-I;IS%;uA=YhOg<(dyb`E^=!i@@(zpgR8m2 z?+Oq}16wa%uGNkPzq`T4#$RX z@Vxu<;k{LUf$(5X@ zMe;}<=|u8K&cyC*hNX93Sk8iE>ta6rWcgzFn38 zA4Nc!Oc_`iq?838rJ?vJ^-+9Esqj&J6d%P$@hRoQNAXd76d%PWmsIgld=wwWNAW3T zE|tkP`3OKxeIh;)pNLPyC*o6<1D}XbL?SX_Wbm>?`K8Y{Xp`d;@hQuOPsAtU^X4WZ zJ7Qno-Z%U4&fY)2ZGXSNw(UD&o7d%XdCMy0%4C~-kTZ0^C*TwC3HStj$~M3!;1lo( z_yl~)*1#tq9PkN<1boVNVX(l9frkP?pgwsE1?m&1PoO@5`UL7joOcT-()wpc9e^z_tbvzhJh Y@7uw_fla4Vn@lD)9*=D_8u6^if0Wdmd;kCd diff --git a/assets/voxygen/voxel/npc/marlin/rear.vox b/assets/voxygen/voxel/npc/marlin/male/chest_back.vox similarity index 70% rename from assets/voxygen/voxel/npc/marlin/rear.vox rename to assets/voxygen/voxel/npc/marlin/male/chest_back.vox index 2afa3c2035d98e1fa77038ef5ca1757ccc3eb6d1..ec135bb30f3fc9d96de84b4d6a0930b70a0be243 100644 GIT binary patch delta 305 zcmXZXu}uUp5Jb_Lon0fHpa&8ffryNdyJoHhdZCev>~{D8mY)7PuxvjrkIT>NeIz~o z`@Y^jpUsB#jw~(rFKu9)eQug!my!^gBULvBw z)bF4B*EMNaAHZ6>vQKB7qVMunYOku(YO1zD*>KvT=JfK-)u%wP57!pG6uY^vKnEiG zfe1qa3_;`$gjqUE2no;BNy2l^10ztN;XS-^J7%D|nSiAk0v)KS@C)xmYy8bXHu^M= adl!?}5rHwr7bO4`^0g>=McP;rT0)l4Gpxi@E!EPyM?cyh6Y;bpa*@oaNaK~a1|9?O$FCb z8^3TZwWW5{j@t8!3Z$wQHAqdZtEDv5hT2j=Ix0w2Gp=SF6{Mkpv{aCe3a)C{zhQqW zxP}U@rGob@zXNJ$patos-gUd)Lj`rW;~QwXcfG0iy&Ydc-P`pIw7sR5K6CoafePwA zbD-@ny&EuRz#OOt>;tmF_zlKGwZZ-yjN8O#bNTGa!!4=HQONxA(kvzWu(xNwkB;o$ z^|k#uIWfDqD7hu2MhGBgJenrpM#+_2$+@*i9?2sQkvx)9ERYBCKpqGJIe#YPLN3vM zO3uVcAYTd*0+92M#8<*6;gj%5_!K>S5_$WTPrHYT@qxdL3ice{C=}flCR{(PQ6Y+`oM0_GX5ub7#_(Xgn z5|Irfi_|h80}F3{HWb%LK+Sf+5Hn zR&WI~IE7=Fz!*j_wDo#ztJTWp^SRAtGdnvwv-9(Fn@lD)9*=D_8rg6-WUR=4=0mNC literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/npc/marlin/fin_l.vox b/assets/voxygen/voxel/npc/marlin/male/fin_l.vox similarity index 88% rename from assets/voxygen/voxel/npc/marlin/fin_l.vox rename to assets/voxygen/voxel/npc/marlin/male/fin_l.vox index 7d6e0852233d9caaeee0f888791d2edc3b6f4b08..876f99f1bc59468f15720a3bef6481823797a9ac 100644 GIT binary patch delta 95 zcmWm4Q4N4F5ChO_Z+t8vXg~-C_~!%Afq+TC3TAF9=7C<5mnKbHZS`FbH?v8y&+Fbd gb!HLLI^6=m05M1e9NG{p=z0t!2*s(L@jY|-0m7aUc>n+a delta 95 zcmXYlK@EUF5ChxZ^03> b0;Cz3-ZB9(BO?$q0WmYvbq1D=MSLs(oUss; delta 93 zcmZqRY~Y-r5X8#Bz`zW}5s^`zHb6EA@BuLsBja0UAZB7F^!E32x6Hug6T{nrU=3ff|W(K zwsNr)B22mLR$JR`nG}N8Gn0Ked*}V~X6EdDv-x=I>SqyoxVHX?A~$;?&(^o^U#T~I zxRuMW0$VS(*So-g&m9O+W(h))S%d_kV+;u-gjoj?sSr{)izz%w)X;^0v13dPy)cWA zYF!EQxXPRmnH!l)1xfKNq{u#z`D7`cN*7N8AGb| z0$hYkcCA|#OBJO+rp`O^n?*QBf65SbnyyO-i0Ha7g% z&W`^*Iq~0nd+tX^E%##73<~1Tty=*GMsDOr&d@V?CePet@=Q)~C0BAKR{|yH&xKsb zCHoJlnK%j5%OHaSIsYhp6?_Ul1)qXX)5E9WQ}Fruv1Y(l1)qXX!KdI;@M%8-pMp=p zr{GiYsXwjYQ}8MH6d}h4yJlj18$O25%lBW;TY!%tU~FbAY%J2+f{!sUe2o4WKCM;w z7(RxN;bZu;_Tgjr7(RxN;Zs{`_!vHhkKtqZv^KZSRGWG!kkg-xPsS(Xlkv&;wAX=8 z#wR0@*)X$sdqs89r|XQ#@yYnK*M?8VC*$+_1|qxSU*6nv|NhqBJ-_9DzP<9D+v1zo z&n7e+9I0rWwZuz(4SVISzZj9>@@=z}a_ z0TUR*KJ3B>hA@D>FPBSSEEYbUPJKKc`@zA1A08h1Xf*QSaOi`3_m?pFd!{sWX17G!l|Dg>bpBq}JSbYVf3kPu_KAf+2!5FIKcS4d0@ z&CEo_h*Ttx8CWv2CD|E19=o|bcfR+0_H&O~0LVsvE$ItwNnhxf8+EI>N~kKvuf}SirQNHx>Q@^T^;X?_qOu;Vf|~oL#sPZJ zX|^h$+l*B<8&$MxP|GtYpbKTYdG_StuFCXr((>}sEJpjVzi+>0Gy8XaZNE=W%q}i+ zZZUB6;6P^FT8Ka+kO%TWPSZTOC->ZVa!=019JwQR-M*t5F z$axSsMSLPY5ub=p*25>_6Y=@^F=fD15ub=p#3$kt@yVZoPsAtU6Y+`oq)&_ZM0_GX zQRMhwmrVlafKR~Z)%@#C3GfLB1SSg%92g{*1)o48;1j4%z$cdqpMX!mC*TwC$>qZ* z;1lo(_yl}XNdrCspMX!mC*YIIoGX)T(&2!d`gnXiJ{}*BkH;r32Rq96k;ohmXT2Zv%WBJ`Nv;kHaT#4SXEJ4j+ez!zXVS26MdV=;R0-^+{XEQ6EQr z9QAS3$59{Rv|AuRs!X!sz(@E9AK@c>giqdn_y`~2BYcDpLjpNI!bkWBAEp6ve1wni z5i(2-ljA7=~Xvwvz%&{sGDg3p#aTDg>bpq$((-bYVd!AtA#liL;uKCymhOQduNo%Qw9yBZNtSVLOS{3&y##B2kbgGUk)vH?dqz8>^@|vu- zQ$r6L_2@T~8hUEzH;ie>TIOpR)AC$9X=!(AkNZ%mW6qAXI@apet-47EeRVqn`i=Tz z{dK4Qs;~ZJKzpO~2lNN40c^kxc>4IkmUyXr%r7q7Q}Xw_yZ-C&(EnXs`R|hx_s^e8 z?#Z}D2q1U5ZV6}@xse+=O^@V}Jkp8ek(`SM@<1NQ13@6?=OP!mqW@6NBsb=2Dq#lg|L;)FPjaRX z_yl|cJ^`PAPuT|e1bhNM0iS?R*&6r+gabYSk$_LxE=(49Ffb?(1nQHwP@q16`UL6| zs866i#Cf-XL9R@;;lxMy2p{1ie1uQge)tF<;Uj#64^sj;KEg-%2p^UKa(sl3@DVaB z4dhHH9u@OcDNu7wVGJV}f|js=OPIka9KjUEFoK~k lmrGwP7CxWPeKwo<+1Z(&pP&15I`#2*?4!}hhr=ObrT>&HiU|M! diff --git a/assets/voxygen/voxel/npc/marlin/torso.vox b/assets/voxygen/voxel/npc/marlin/torso.vox deleted file mode 100644 index a0c220bd89bbd9663dac240fd91a892317ac5832..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1476 zcmXAny>AmS7>D2U`96}CA^!o&3JbEBmZU6ANT7et2&$rTb4 zLo+cjQ86MF$zyakWoFAi!0__e&E<*hU;Odhd$*YF-~KEjPj_~wH1fR?dA@t_csmXF z41q{)!T!sG-IIb2pF^m{cD0mU1r|y$P#2~zi>hzU)~v}4r?nYQTQguhnAK33!PG)y zTK;RNm1$=dTGKG6VNS!GhB?i&q;J`;f*KlAaF*>V&S{M>uDcp4uu!HpJD7f8nnh)X zok?TUG9D~i(=G;PYtfi()^GQ<*<$ThZ<$vVrfbb`Vc5SZOayyMwVkotBW+1* zX{{~$indB^@?oBZGPS8T%&Yld@HOmHByUmzSzB>W95O{e5(#|E{m~&&i4E#YN6F23ijeM3te22y_B@ zAP?kp)suU2&%l#=avF8yj@*$u0!PkQgrY9UC<&x1fCmTU{1N$y_(XgnJ`ta+ zhfl;O;`8fc%7CLHJ`taYPsAtUlWzl`h)={P;uG;nw-)h<_(Xi7kmG}0HVOO&d;&g) z@4w!Z0H1(B;IP2PflYE*@CkGRK7slKd~&Jq3HStj0zLtsTt0jPJ^`PAPrxUYG~g5P z3HStj0zSFSxiZNnT@J{pkH^R3{f9;yC#tM6Xi*T3Ih>Cpqx#T~hMy!k1m$|Rd~k+ZeK$Km7fariiV z@@s&P!^h#{@NxL$R|6l1u*1h8;_%6@3!6C>Iwm;+M}5*Of@*nae7-I zK&ni#;lfAo5qtz6!AJ1PuOB{wkKiNt2tI5H^g=3h*1jaA|*}xjEU { pub quadruped_small: BodyData>, pub quadruped_medium: BodyData>, pub bird_medium: BodyData>, - pub fish_medium: BodyData, + pub fish_medium: BodyData>, pub dragon: BodyData>, pub bird_small: BodyData, - pub fish_small: BodyData, + pub fish_small: BodyData>, pub biped_large: BodyData>, pub object: BodyData, pub golem: BodyData>, @@ -87,6 +87,8 @@ impl core::ops::Index for AllBodies &self.quadruped_small.body, NpcKind::Wolf => &self.quadruped_medium.body, NpcKind::Duck => &self.bird_medium.body, + NpcKind::Sardine => &self.fish_medium.body, + NpcKind::Marlin => &self.fish_small.body, NpcKind::Ogre => &self.biped_large.body, NpcKind::StoneGolem => &self.golem.body, NpcKind::Archaeos => &self.theropod.body, @@ -231,10 +233,10 @@ impl Body { bird_medium::Species::Cockatrice => 1.8, _ => 1.1, }, - Body::FishMedium(_) => 1.1, + Body::FishMedium(_) => 0.8, Body::Dragon(_) => 16.0, Body::BirdSmall(_) => 1.1, - Body::FishSmall(_) => 0.9, + Body::FishSmall(_) => 0.6, Body::BipedLarge(body) => match body.species { biped_large::Species::Slysaurok => 2.3, biped_large::Species::Occultsaurok => 2.8, diff --git a/common/src/comp/body/fish_medium.rs b/common/src/comp/body/fish_medium.rs index e1fe43cb74..8ddd3695b2 100644 --- a/common/src/comp/body/fish_medium.rs +++ b/common/src/comp/body/fish_medium.rs @@ -6,86 +6,73 @@ make_proj_elim!( body, #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] pub struct Body { - pub head: Head, - pub torso: Torso, - pub rear: Rear, - pub tail: Tail, - pub fin_l: FinL, - pub fin_r: FinR, + pub species: Species, + pub body_type: BodyType, } ); impl Body { pub fn random() -> Self { let mut rng = thread_rng(); - Self { - head: *(&ALL_HEADS).choose(&mut rng).unwrap(), - torso: *(&ALL_TORSOS).choose(&mut rng).unwrap(), - rear: *(&ALL_REARS).choose(&mut rng).unwrap(), - tail: *(&ALL_TAILS).choose(&mut rng).unwrap(), - fin_l: *(&ALL_FIN_LS).choose(&mut rng).unwrap(), - fin_r: *(&ALL_FIN_RS).choose(&mut rng).unwrap(), + let species = *(&ALL_SPECIES).choose(&mut rng).unwrap(); + Self::random_with(&mut rng, &species) + } + + #[inline] + pub fn random_with(rng: &mut impl rand::Rng, &species: &Species) -> Self { + let body_type = *(&ALL_BODY_TYPES).choose(rng).unwrap(); + Self { species, body_type } + } +} + +impl From for super::Body { + fn from(body: Body) -> Self { super::Body::FishMedium(body) } +} + +make_case_elim!( + species, + #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] + #[repr(u32)] + pub enum Species { + Marlin = 0, + } +); + +/// Data representing per-species generic data. +/// +/// NOTE: Deliberately don't (yet?) implement serialize. +#[derive(Clone, Debug, Deserialize)] +pub struct AllSpecies { + pub marlin: SpeciesMeta, +} + +impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies { + type Output = SpeciesMeta; + + #[inline] + fn index(&self, &index: &'a Species) -> &Self::Output { + match index { + Species::Marlin => &self.marlin, } } } -make_case_elim!( - head, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum Head { - Default = 0, - } -); +pub const ALL_SPECIES: [Species; 1] = [Species::Marlin]; -const ALL_HEADS: [Head; 1] = [Head::Default]; +impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies { + type IntoIter = std::iter::Copied>; + type Item = Species; + + fn into_iter(self) -> Self::IntoIter { ALL_SPECIES.iter().copied() } +} make_case_elim!( - torso, + body_type, #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] #[repr(u32)] - pub enum Torso { - Default = 0, + pub enum BodyType { + Female = 0, + Male = 1, } ); -const ALL_TORSOS: [Torso; 1] = [Torso::Default]; - -make_case_elim!( - rear, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum Rear { - Default = 0, - } -); -const ALL_REARS: [Rear; 1] = [Rear::Default]; - -make_case_elim!( - tail, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum Tail { - Default = 0, - } -); -const ALL_TAILS: [Tail; 1] = [Tail::Default]; - -make_case_elim!( - fin_l, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum FinL { - Default = 0, - } -); -const ALL_FIN_LS: [FinL; 1] = [FinL::Default]; - -make_case_elim!( - fin_r, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum FinR { - Default = 0, - } -); -const ALL_FIN_RS: [FinR; 1] = [FinR::Default]; +pub const ALL_BODY_TYPES: [BodyType; 2] = [BodyType::Female, BodyType::Male]; diff --git a/common/src/comp/body/fish_small.rs b/common/src/comp/body/fish_small.rs index 31753df95d..b962d56ea4 100644 --- a/common/src/comp/body/fish_small.rs +++ b/common/src/comp/body/fish_small.rs @@ -6,39 +6,73 @@ make_proj_elim!( body, #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] pub struct Body { - pub torso: Torso, - pub tail: Tail, + pub species: Species, + pub body_type: BodyType, } ); impl Body { pub fn random() -> Self { let mut rng = thread_rng(); - Self { - torso: *(&ALL_TORSOS).choose(&mut rng).unwrap(), - tail: *(&ALL_TAILS).choose(&mut rng).unwrap(), + let species = *(&ALL_SPECIES).choose(&mut rng).unwrap(); + Self::random_with(&mut rng, &species) + } + + #[inline] + pub fn random_with(rng: &mut impl rand::Rng, &species: &Species) -> Self { + let body_type = *(&ALL_BODY_TYPES).choose(rng).unwrap(); + Self { species, body_type } + } +} + +impl From for super::Body { + fn from(body: Body) -> Self { super::Body::FishSmall(body) } +} + +make_case_elim!( + species, + #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] + #[repr(u32)] + pub enum Species { + Sardine = 0, + } +); + +/// Data representing per-species generic data. +/// +/// NOTE: Deliberately don't (yet?) implement serialize. +#[derive(Clone, Debug, Deserialize)] +pub struct AllSpecies { + pub sardine: SpeciesMeta, +} + +impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies { + type Output = SpeciesMeta; + + #[inline] + fn index(&self, &index: &'a Species) -> &Self::Output { + match index { + Species::Sardine => &self.sardine, } } } -make_case_elim!( - torso, - #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] - #[repr(u32)] - pub enum Torso { - Default = 0, - } -); +pub const ALL_SPECIES: [Species; 1] = [Species::Sardine]; -const ALL_TORSOS: [Torso; 1] = [Torso::Default]; +impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies { + type IntoIter = std::iter::Copied>; + type Item = Species; + + fn into_iter(self) -> Self::IntoIter { ALL_SPECIES.iter().copied() } +} make_case_elim!( - tail, + body_type, #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] #[repr(u32)] - pub enum Tail { - Default = 0, + pub enum BodyType { + Female = 0, + Male = 1, } ); - -const ALL_TAILS: [Tail; 1] = [Tail::Default]; +pub const ALL_BODY_TYPES: [BodyType; 2] = [BodyType::Female, BodyType::Male]; diff --git a/common/src/generation.rs b/common/src/generation.rs index 4e5dd28649..c16131918b 100644 --- a/common/src/generation.rs +++ b/common/src/generation.rs @@ -121,6 +121,8 @@ impl EntityInfo { Some(get_npc_name(&NPC_NAMES.quadruped_medium, body.species)) }, Body::BirdMedium(body) => Some(get_npc_name(&NPC_NAMES.bird_medium, body.species)), + Body::FishSmall(body) => Some(get_npc_name(&NPC_NAMES.fish_small, body.species)), + Body::FishMedium(body) => Some(get_npc_name(&NPC_NAMES.fish_medium, body.species)), Body::Theropod(body) => Some(get_npc_name(&NPC_NAMES.theropod, body.species)), Body::QuadrupedSmall(body) => { Some(get_npc_name(&NPC_NAMES.quadruped_small, body.species)) diff --git a/common/src/npc.rs b/common/src/npc.rs index 881aea55fa..ee997f4726 100644 --- a/common/src/npc.rs +++ b/common/src/npc.rs @@ -13,6 +13,8 @@ pub enum NpcKind { Wolf, Pig, Duck, + Sardine, + Marlin, Ogre, Archaeos, StoneGolem, @@ -20,11 +22,13 @@ pub enum NpcKind { Crocodile, } -pub const ALL_NPCS: [NpcKind; 9] = [ +pub const ALL_NPCS: [NpcKind; 11] = [ NpcKind::Humanoid, NpcKind::Wolf, NpcKind::Pig, NpcKind::Duck, + NpcKind::Sardine, + NpcKind::Marlin, NpcKind::Ogre, NpcKind::Archaeos, NpcKind::StoneGolem, @@ -93,6 +97,8 @@ pub fn kind_to_body(kind: NpcKind) -> Body { NpcKind::Pig => comp::quadruped_small::Body::random().into(), NpcKind::Wolf => comp::quadruped_medium::Body::random().into(), NpcKind::Duck => comp::bird_medium::Body::random().into(), + NpcKind::Sardine => comp::fish_small::Body::random().into(), + NpcKind::Marlin => comp::fish_medium::Body::random().into(), NpcKind::Ogre => comp::biped_large::Body::random().into(), NpcKind::Archaeos => comp::theropod::Body::random().into(), NpcKind::StoneGolem => comp::golem::Body::random().into(), @@ -195,6 +201,22 @@ impl NpcBody { comp::bird_medium::Body::random_with, ) }) + .or_else(|| { + parse( + s, + NpcKind::Sardine, + &npc_names.fish_small, + comp::fish_small::Body::random_with, + ) + }) + .or_else(|| { + parse( + s, + NpcKind::Marlin, + &npc_names.fish_medium, + comp::fish_medium::Body::random_with, + ) + }) .or_else(|| { parse( s, diff --git a/common/src/states/utils.rs b/common/src/states/utils.rs index a57cce9e00..09abdbfe44 100644 --- a/common/src/states/utils.rs +++ b/common/src/states/utils.rs @@ -58,10 +58,10 @@ impl Body { quadruped_medium::Species::Horse => 180.0, }, Body::BirdMedium(_) => 80.0, - Body::FishMedium(_) => 50.0, + Body::FishMedium(_) => 80.0, Body::Dragon(_) => 250.0, Body::BirdSmall(_) => 75.0, - Body::FishSmall(_) => 40.0, + Body::FishSmall(_) => 60.0, Body::BipedLarge(_) => 75.0, Body::Object(_) => 40.0, Body::Golem(_) => 60.0, diff --git a/voxygen/anim/src/fish_medium/idle.rs b/voxygen/anim/src/fish_medium/idle.rs index 09b0c820e6..3c8497f5e7 100644 --- a/voxygen/anim/src/fish_medium/idle.rs +++ b/voxygen/anim/src/fish_medium/idle.rs @@ -1,6 +1,7 @@ use super::{super::Animation, FishMediumSkeleton, SkeletonAttr}; //use std::{f32::consts::PI, ops::Mul}; use super::super::vek::*; +use std::f32::consts::PI; pub struct IdleAnimation; @@ -15,36 +16,38 @@ impl Animation for IdleAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, _global_time: Self::Dependency, - _anim_time: f64, + anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 10.88; - next.torso.scale = Vec3::one() * 1.01; - next.rear.scale = Vec3::one() * 0.98; - next.tail.scale = Vec3::one() / 11.0; - next.fin_l.scale = Vec3::one() / 11.0; - next.fin_r.scale = Vec3::one() / 10.5; + let slower = (anim_time as f32 * 1.0 + PI).sin(); + let slow = (anim_time as f32 * 3.5 + PI).sin(); + let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); - next.head.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest_front.scale = Vec3::one() / 11.0; - next.torso.position = Vec3::new(0.0, 4.5, 2.0); - next.torso.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(slowalt * -0.1); - next.rear.position = Vec3::new(0.0, 3.1, -4.5); - next.rear.orientation = Quaternion::rotation_z(0.0); + next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); + next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.tail.position = Vec3::new(0.0, -13.0, 8.0) / 11.0; - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; + next.chest_front.orientation = Quaternion::rotation_x(0.0); - next.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; - next.fin_l.orientation = Quaternion::rotation_y(0.0); + next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); + next.chest_back.orientation = Quaternion::rotation_z(slowalt * 0.1); - next.fin_r.position = Vec3::new(0.0, 0.0, 12.0) / 11.0; - next.fin_r.orientation = Quaternion::rotation_y(0.0); + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(slow * 0.1); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); next } } diff --git a/voxygen/anim/src/fish_medium/jump.rs b/voxygen/anim/src/fish_medium/jump.rs index 7b54e4f476..c7b4162e2d 100644 --- a/voxygen/anim/src/fish_medium/jump.rs +++ b/voxygen/anim/src/fish_medium/jump.rs @@ -17,33 +17,31 @@ impl Animation for JumpAnimation { _global_time: Self::Dependency, _anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 10.88; - next.torso.scale = Vec3::one() * 1.01; - next.rear.scale = Vec3::one() * 0.98; - next.tail.scale = Vec3::one() / 11.0; - next.fin_l.scale = Vec3::one() / 11.0; - next.fin_r.scale = Vec3::one() / 10.5; + next.chest_front.scale = Vec3::one() / 11.0; - next.head.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.torso.position = Vec3::new(0.0, 4.5, 2.0); - next.torso.orientation = Quaternion::rotation_x(0.0); + next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); + next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.rear.position = Vec3::new(0.0, 3.1, -4.5); - next.rear.orientation = Quaternion::rotation_z(0.0); + next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; + next.chest_front.orientation = Quaternion::rotation_x(0.0); - next.tail.position = Vec3::new(0.0, -13.0, 8.0) / 11.0; + next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); + next.chest_back.orientation = Quaternion::rotation_z(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); next.fin_l.orientation = Quaternion::rotation_y(0.0); - next.fin_r.position = Vec3::new(0.0, 0.0, 12.0) / 11.0; + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); next.fin_r.orientation = Quaternion::rotation_y(0.0); next } diff --git a/voxygen/anim/src/fish_medium/mod.rs b/voxygen/anim/src/fish_medium/mod.rs index 63b1b7e6b9..4448b4edad 100644 --- a/voxygen/anim/src/fish_medium/mod.rs +++ b/voxygen/anim/src/fish_medium/mod.rs @@ -1,9 +1,14 @@ pub mod idle; pub mod jump; pub mod run; +pub mod swim; +pub mod swimidle; // Reexports -pub use self::{idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation}; +pub use self::{ + idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation, + swimidle::SwimIdleAnimation, +}; use super::{make_bone, vek::*, FigureBoneData, Skeleton}; use common::comp::{self}; @@ -13,8 +18,9 @@ pub type Body = comp::fish_medium::Body; skeleton_impls!(struct FishMediumSkeleton { + head, - + torso, - + rear, + + jaw, + + chest_front, + + chest_back, + tail, + fin_l, + fin_r, @@ -24,7 +30,7 @@ impl Skeleton for FishMediumSkeleton { type Attr = SkeletonAttr; type Body = Body; - const BONE_COUNT: usize = 6; + const BONE_COUNT: usize = 7; #[cfg(feature = "use-dyn-lib")] const COMPUTE_FN: &'static [u8] = b"fish_medium_compute_mats\0"; @@ -34,22 +40,31 @@ impl Skeleton for FishMediumSkeleton { base_mat: Mat4, buf: &mut [FigureBoneData; super::MAX_BONE_COUNT], ) -> Vec3 { - let torso_mat = base_mat * Mat4::::from(self.torso); - let rear_mat = torso_mat * Mat4::::from(self.rear); + let chest_front_mat = base_mat * Mat4::::from(self.chest_front); + let chest_back_mat = Mat4::::from(self.chest_back); + let head_mat = Mat4::::from(self.head); *(<&mut [_; Self::BONE_COUNT]>::try_from(&mut buf[0..Self::BONE_COUNT]).unwrap()) = [ - make_bone(torso_mat * Mat4::::from(self.head)), - make_bone(torso_mat), - make_bone(rear_mat), - make_bone(rear_mat * Mat4::::from(self.tail)), - make_bone(rear_mat * Mat4::::from(self.fin_l)), - make_bone(rear_mat * Mat4::::from(self.fin_r)), + make_bone(chest_front_mat * head_mat), + make_bone(chest_front_mat * head_mat * Mat4::::from(self.jaw)), + make_bone(chest_front_mat), + make_bone(chest_front_mat * chest_back_mat), + make_bone(chest_front_mat * chest_back_mat * Mat4::::from(self.tail)), + make_bone(chest_front_mat * Mat4::::from(self.fin_l)), + make_bone(chest_front_mat * Mat4::::from(self.fin_r)), ]; Vec3::default() } } -pub struct SkeletonAttr; +pub struct SkeletonAttr { + head: (f32, f32), + jaw: (f32, f32), + chest_front: (f32, f32), + chest_back: (f32, f32), + tail: (f32, f32), + fin: (f32, f32, f32), +} impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { type Error = (); @@ -63,9 +78,40 @@ impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { } impl Default for SkeletonAttr { - fn default() -> Self { Self } + fn default() -> Self { + Self { + head: (0.0, 0.0), + jaw: (0.0, 0.0), + chest_front: (0.0, 0.0), + chest_back: (0.0, 0.0), + tail: (0.0, 0.0), + fin: (0.0, 0.0, 0.0), + } + } } impl<'a> From<&'a Body> for SkeletonAttr { - fn from(_body: &'a Body) -> Self { Self } + fn from(body: &'a Body) -> Self { + use comp::fish_medium::Species::*; + Self { + head: match (body.species, body.body_type) { + (Marlin, _) => (2.0, 1.5), + }, + jaw: match (body.species, body.body_type) { + (Marlin, _) => (2.5, -3.0), + }, + chest_front: match (body.species, body.body_type) { + (Marlin, _) => (0.0, 2.5), + }, + chest_back: match (body.species, body.body_type) { + (Marlin, _) => (-1.0, 1.0), + }, + tail: match (body.species, body.body_type) { + (Marlin, _) => (-7.0, 0.0), + }, + fin: match (body.species, body.body_type) { + (Marlin, _) => (2.5, 1.0, 3.5), + }, + } + } } diff --git a/voxygen/anim/src/fish_medium/run.rs b/voxygen/anim/src/fish_medium/run.rs index ec875b0441..81ed079734 100644 --- a/voxygen/anim/src/fish_medium/run.rs +++ b/voxygen/anim/src/fish_medium/run.rs @@ -17,33 +17,31 @@ impl Animation for RunAnimation { _global_time: Self::Dependency, _anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 10.88; - next.torso.scale = Vec3::one() * 1.01; - next.rear.scale = Vec3::one() * 0.98; - next.tail.scale = Vec3::one() / 11.0; - next.fin_l.scale = Vec3::one() / 11.0; - next.fin_r.scale = Vec3::one() / 10.5; + next.chest_front.scale = Vec3::one() / 11.0; - next.head.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.torso.position = Vec3::new(0.0, 4.5, 2.0); - next.torso.orientation = Quaternion::rotation_x(0.0); + next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); + next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.rear.position = Vec3::new(0.0, 3.1, -4.5); - next.rear.orientation = Quaternion::rotation_z(0.0); + next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; + next.chest_front.orientation = Quaternion::rotation_x(0.0); - next.tail.position = Vec3::new(0.0, -13.0, 8.0) / 11.0; + next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); + next.chest_back.orientation = Quaternion::rotation_z(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); next.fin_l.orientation = Quaternion::rotation_y(0.0); - next.fin_r.position = Vec3::new(0.0, 0.0, 12.0) / 11.0; + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); next.fin_r.orientation = Quaternion::rotation_y(0.0); next } diff --git a/voxygen/anim/src/fish_small/idle.rs b/voxygen/anim/src/fish_small/idle.rs index 841627ec41..42a0fd663e 100644 --- a/voxygen/anim/src/fish_small/idle.rs +++ b/voxygen/anim/src/fish_small/idle.rs @@ -17,18 +17,26 @@ impl Animation for IdleAnimation { _global_time: Self::Dependency, _anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.torso.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; - next.torso.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.torso.scale = Vec3::one() / 10.88; + next.head.scale = Vec3::one() / 11.0; - next.tail.position = Vec3::new(0.0, 4.5, 2.0); - next.tail.orientation = Quaternion::rotation_x(0.0); - next.tail.scale = Vec3::one() * 1.01; + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_y(0.0); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_y(0.0); next } } diff --git a/voxygen/anim/src/fish_small/jump.rs b/voxygen/anim/src/fish_small/jump.rs index 5af66c2869..b02202ee0f 100644 --- a/voxygen/anim/src/fish_small/jump.rs +++ b/voxygen/anim/src/fish_small/jump.rs @@ -17,18 +17,26 @@ impl Animation for JumpAnimation { _global_time: Self::Dependency, _anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.torso.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; - next.torso.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.torso.scale = Vec3::one() / 10.88; + next.head.scale = Vec3::one() / 11.0; - next.tail.position = Vec3::new(0.0, 4.5, 2.0); - next.tail.orientation = Quaternion::rotation_x(0.0); - next.tail.scale = Vec3::one() * 1.01; + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_y(0.0); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_y(0.0); next } } diff --git a/voxygen/anim/src/fish_small/mod.rs b/voxygen/anim/src/fish_small/mod.rs index f055901750..a18c569e2f 100644 --- a/voxygen/anim/src/fish_small/mod.rs +++ b/voxygen/anim/src/fish_small/mod.rs @@ -1,9 +1,10 @@ pub mod idle; pub mod jump; pub mod run; +pub mod swim; // Reexports -pub use self::{idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation}; +pub use self::{idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation}; use super::{make_bone, vek::*, FigureBoneData, Skeleton}; use common::comp::{self}; @@ -12,36 +13,46 @@ use core::convert::TryFrom; pub type Body = comp::fish_small::Body; skeleton_impls!(struct FishSmallSkeleton { - + torso, + + head, + + chest, + tail, + + fin_l, + + fin_r, }); impl Skeleton for FishSmallSkeleton { type Attr = SkeletonAttr; type Body = Body; - const BONE_COUNT: usize = 2; + const BONE_COUNT: usize = 5; #[cfg(feature = "use-dyn-lib")] const COMPUTE_FN: &'static [u8] = b"fish_small_compute_mats\0"; #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_compute_mats")] - fn compute_matrices_inner( &self, base_mat: Mat4, buf: &mut [FigureBoneData; super::MAX_BONE_COUNT], ) -> Vec3 { - let torso_mat = base_mat * Mat4::::from(self.torso); + let chest_mat = base_mat * Mat4::::from(self.chest); *(<&mut [_; Self::BONE_COUNT]>::try_from(&mut buf[0..Self::BONE_COUNT]).unwrap()) = [ - make_bone(torso_mat), - make_bone(torso_mat * Mat4::::from(self.tail)), + make_bone(chest_mat * Mat4::::from(self.head)), + make_bone(chest_mat), + make_bone(chest_mat * Mat4::::from(self.tail)), + make_bone(chest_mat * Mat4::::from(self.fin_l)), + make_bone(chest_mat * Mat4::::from(self.fin_r)), ]; Vec3::default() } } -pub struct SkeletonAttr; +pub struct SkeletonAttr { + head: (f32, f32), + chest: (f32, f32), + tail: (f32, f32), + fin: (f32, f32, f32), +} impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { type Error = (); @@ -55,9 +66,32 @@ impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { } impl Default for SkeletonAttr { - fn default() -> Self { Self } + fn default() -> Self { + Self { + head: (0.0, 0.0), + chest: (0.0, 0.0), + tail: (0.0, 0.0), + fin: (0.0, 0.0, 0.0), + } + } } impl<'a> From<&'a Body> for SkeletonAttr { - fn from(_body: &'a Body) -> Self { Self } + fn from(body: &'a Body) -> Self { + use comp::fish_small::Species::*; + Self { + head: match (body.species, body.body_type) { + (Sardine, _) => (1.5, 2.0), + }, + chest: match (body.species, body.body_type) { + (Sardine, _) => (0.0, 5.0), + }, + tail: match (body.species, body.body_type) { + (Sardine, _) => (-6.0, 0.0), + }, + fin: match (body.species, body.body_type) { + (Sardine, _) => (3.5, 6.0, -1.0), + }, + } + } } diff --git a/voxygen/anim/src/fish_small/run.rs b/voxygen/anim/src/fish_small/run.rs index f19d685e9e..c3fa97be8e 100644 --- a/voxygen/anim/src/fish_small/run.rs +++ b/voxygen/anim/src/fish_small/run.rs @@ -17,18 +17,26 @@ impl Animation for RunAnimation { (_velocity, _global_time): Self::Dependency, _anim_time: f64, _rate: &mut f32, - _skeleton_attr: &SkeletonAttr, + s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.torso.position = Vec3::new(0.0, 7.5, 15.0) / 11.0; - next.torso.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - next.torso.scale = Vec3::one() / 10.88; + next.head.scale = Vec3::one() / 11.0; - next.tail.position = Vec3::new(0.0, 4.5, 2.0); - next.tail.orientation = Quaternion::rotation_x(0.0); - next.tail.scale = Vec3::one() * 1.01; + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_y(0.0); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_y(0.0); next } } diff --git a/voxygen/src/anim/src/fish_medium/swim.rs b/voxygen/src/anim/src/fish_medium/swim.rs new file mode 100644 index 0000000000..dc4ebf2c55 --- /dev/null +++ b/voxygen/src/anim/src/fish_medium/swim.rs @@ -0,0 +1,78 @@ +use super::{ + super::{vek::*, Animation}, + FishMediumSkeleton, SkeletonAttr, +}; +use std::f32::consts::PI; + +pub struct SwimAnimation; + +type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + +impl Animation for SwimAnimation { + type Dependency = SwimAnimationDependency; + type Skeleton = FishMediumSkeleton; + + #[cfg(feature = "use-dyn-lib")] + const UPDATE_FN: &'static [u8] = b"fish_medium_swim\0"; + + #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_swim")] + + fn update_skeleton_inner( + skeleton: &Self::Skeleton, + (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, + anim_time: f64, + rate: &mut f32, + s_a: &SkeletonAttr, + ) -> Self::Skeleton { + let mut next = (*skeleton).clone(); + + let slower = (anim_time as f32 * 1.0 + PI).sin(); + let slow = (anim_time as f32 * 3.5 + PI).sin(); + let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); + let fast = (anim_time as f32 * 5.5 + PI).sin(); + let fastalt = (anim_time as f32 * 5.5 + PI + 0.2).sin(); + + 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.8) + * last_ori.determine_side(Vec2::zero(), ori).signum() + } else { + 0.0 + } * 1.3; + let abstilt = tilt.abs(); + let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); + + let squash = if abstilt > 0.2 { 0.35 } else { 1.0 }; //condenses the body at strong turns + + next.chest_front.scale = Vec3::one() / 11.0; + + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(slowalt * -0.1 + tilt * -2.0); + + next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); + next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; + next.chest_front.orientation = + Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt); + + next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); + next.chest_back.orientation = Quaternion::rotation_z(fastalt * 0.3 + tilt * 2.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(fast * 0.3 + tilt * 2.0); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_z(fast * 0.3 - 0.1 + tilt * -0.5); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_z(-fast * 0.3 + 0.1 + tilt * -0.5); + next + } +} diff --git a/voxygen/src/anim/src/fish_medium/swimidle.rs b/voxygen/src/anim/src/fish_medium/swimidle.rs new file mode 100644 index 0000000000..3abd898a32 --- /dev/null +++ b/voxygen/src/anim/src/fish_medium/swimidle.rs @@ -0,0 +1,57 @@ +use super::{ + super::{vek::*, Animation}, + FishMediumSkeleton, SkeletonAttr, +}; +use std::{f32::consts::PI, ops::Mul}; + +pub struct SwimIdleAnimation; + +type SwimIdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + +impl Animation for SwimIdleAnimation { + type Dependency = SwimIdleAnimationDependency; + type Skeleton = FishMediumSkeleton; + + #[cfg(feature = "use-dyn-lib")] + const UPDATE_FN: &'static [u8] = b"fish_medium_swimidle\0"; + + #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_swimidle")] + + fn update_skeleton_inner( + skeleton: &Self::Skeleton, + (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, + anim_time: f64, + rate: &mut f32, + s_a: &SkeletonAttr, + ) -> Self::Skeleton { + let mut next = (*skeleton).clone(); + + let slower = (anim_time as f32 * 1.0 + PI).sin(); + let slow = (anim_time as f32 * 3.5 + PI).sin(); + let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); + + next.chest_front.scale = Vec3::one() / 11.0; + + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(slowalt * -0.1); + + next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); + next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; + next.chest_front.orientation = Quaternion::rotation_x(0.0); + + next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); + next.chest_back.orientation = Quaternion::rotation_z(slowalt * 0.1); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(slow * 0.1); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); + next + } +} diff --git a/voxygen/src/anim/src/fish_small/swim.rs b/voxygen/src/anim/src/fish_small/swim.rs new file mode 100644 index 0000000000..774dc43316 --- /dev/null +++ b/voxygen/src/anim/src/fish_small/swim.rs @@ -0,0 +1,46 @@ +use super::{ + super::{vek::*, Animation}, + FishSmallSkeleton, SkeletonAttr, +}; + +pub struct SwimAnimation; + +type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + +impl Animation for SwimAnimation { + type Dependency = SwimAnimationDependency; + type Skeleton = FishSmallSkeleton; + + #[cfg(feature = "use-dyn-lib")] + const UPDATE_FN: &'static [u8] = b"fish_small_swim\0"; + + #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_swim")] + + fn update_skeleton_inner( + skeleton: &Self::Skeleton, + (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, + _anim_time: f64, + _rate: &mut f32, + s_a: &SkeletonAttr, + ) -> Self::Skeleton { + let mut next = (*skeleton).clone(); + + next.head.scale = Vec3::one() / 11.0; + + next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); + next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_y(0.0); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_y(0.0); + next + } +} diff --git a/voxygen/src/scene/figure/load.rs b/voxygen/src/scene/figure/load.rs index 9ca1f4c3fa..12ef0b1ea9 100644 --- a/voxygen/src/scene/figure/load.rs +++ b/voxygen/src/scene/figure/load.rs @@ -6,7 +6,8 @@ use common::{ bird_medium::{self, BodyType as BMBodyType, Species as BMSpecies}, bird_small, dragon::{self, BodyType as DBodyType, Species as DSpecies}, - fish_medium, fish_small, + fish_medium::{self, BodyType as FMBodyType, Species as FMSpecies}, + fish_small::{self, BodyType as FSBodyType, Species as FSSpecies}, golem::{self, BodyType as GBodyType, Species as GSpecies}, humanoid::{self, Body, BodyType, EyeColor, Skin, Species}, object, @@ -2086,17 +2087,257 @@ impl TheropodLateralSpec { } } //// +#[derive(Deserialize)] +struct FishMediumCentralSpec(HashMap<(FMSpecies, FMBodyType), SidedFMCentralVoxSpec>); + +#[derive(Deserialize)] +struct SidedFMCentralVoxSpec { + head: FishMediumCentralSubSpec, + jaw: FishMediumCentralSubSpec, + chest_front: FishMediumCentralSubSpec, + chest_back: FishMediumCentralSubSpec, + tail: FishMediumCentralSubSpec, +} +#[derive(Deserialize)] +struct FishMediumCentralSubSpec { + offset: [f32; 3], // Should be relative to initial origin + central: VoxSimple, +} +#[derive(Deserialize)] +struct FishMediumLateralSpec(HashMap<(FMSpecies, FMBodyType), SidedFMLateralVoxSpec>); +#[derive(Deserialize)] +struct SidedFMLateralVoxSpec { + fin_l: FishMediumLateralSubSpec, + fin_r: FishMediumLateralSubSpec, +} +#[derive(Deserialize)] +struct FishMediumLateralSubSpec { + offset: [f32; 3], // Should be relative to initial origin + lateral: VoxSimple, +} + make_vox_spec!( fish_medium::Body, - struct FishMediumSpec {}, - |FigureKey { body, .. }, _spec| { + struct FishMediumSpec { + central: FishMediumCentralSpec = "voxygen.voxel.fish_medium_central_manifest", + lateral: FishMediumLateralSpec = "voxygen.voxel.fish_medium_lateral_manifest", + }, + |FigureKey { body, .. }, spec| { [ - Some(mesh_fish_medium_head(body.head)), - Some(mesh_fish_medium_torso(body.torso)), - Some(mesh_fish_medium_rear(body.rear)), - Some(mesh_fish_medium_tail(body.tail)), - Some(mesh_fish_medium_fin_l(body.fin_l)), - Some(mesh_fish_medium_fin_r(body.fin_r)), + Some(spec.central.asset.mesh_head( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_jaw( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_chest_front( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_chest_back( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_tail( + body.species, + body.body_type, + )), + Some(spec.lateral.asset.mesh_fin_l( + body.species, + body.body_type, + )), + Some(spec.lateral.asset.mesh_fin_r( + body.species, + body.body_type, + )), + None, + None, + None, + None, + None, + None, + None, + None, + None, + ] + }, +); + +impl FishMediumCentralSpec { + fn mesh_head(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No head specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.head.central.0); + + (central, Vec3::from(spec.head.offset)) + } + + fn mesh_jaw(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No jaw specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.jaw.central.0); + + (central, Vec3::from(spec.jaw.offset)) + } + + fn mesh_chest_front(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No front chest specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.chest_front.central.0); + + (central, Vec3::from(spec.chest_front.offset)) + } + + fn mesh_chest_back(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No back chest specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.chest_back.central.0); + + (central, Vec3::from(spec.chest_back.offset)) + } + + fn mesh_tail(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No tail specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.tail.central.0); + + (central, Vec3::from(spec.tail.offset)) + } +} + +impl FishMediumLateralSpec { + fn mesh_fin_l(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No fin specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let lateral = graceful_load_segment(&spec.fin_l.lateral.0); + + (lateral, Vec3::from(spec.fin_l.offset)) + } + + fn mesh_fin_r(&self, species: FMSpecies, body_type: FMBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No fin specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let lateral = graceful_load_segment(&spec.fin_r.lateral.0); + + (lateral, Vec3::from(spec.fin_r.offset)) + } +} + +//// +#[derive(Deserialize)] +struct FishSmallCentralSpec(HashMap<(FSSpecies, FSBodyType), SidedFSCentralVoxSpec>); + +#[derive(Deserialize)] +struct SidedFSCentralVoxSpec { + head: FishSmallCentralSubSpec, + chest: FishSmallCentralSubSpec, + tail: FishSmallCentralSubSpec, +} +#[derive(Deserialize)] +struct FishSmallCentralSubSpec { + offset: [f32; 3], // Should be relative to initial origin + central: VoxSimple, +} +#[derive(Deserialize)] +struct FishSmallLateralSpec(HashMap<(FSSpecies, FSBodyType), SidedFSLateralVoxSpec>); +#[derive(Deserialize)] +struct SidedFSLateralVoxSpec { + fin_l: FishSmallLateralSubSpec, + fin_r: FishSmallLateralSubSpec, +} +#[derive(Deserialize)] +struct FishSmallLateralSubSpec { + offset: [f32; 3], // Should be relative to initial origin + lateral: VoxSimple, +} + +make_vox_spec!( + fish_small::Body, + struct FishSmallSpec { + central: FishSmallCentralSpec = "voxygen.voxel.fish_small_central_manifest", + lateral: FishSmallLateralSpec = "voxygen.voxel.fish_small_lateral_manifest", + }, + |FigureKey { body, .. }, spec| { + [ + Some(spec.central.asset.mesh_head( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_chest( + body.species, + body.body_type, + )), + Some(spec.central.asset.mesh_tail( + body.species, + body.body_type, + )), + Some(spec.lateral.asset.mesh_fin_l( + body.species, + body.body_type, + )), + Some(spec.lateral.asset.mesh_fin_r( + body.species, + body.body_type, + )), + None, None, None, None, @@ -2111,58 +2352,88 @@ make_vox_spec!( }, ); -fn mesh_fish_medium_head(head: fish_medium::Head) -> BoneMeshes { - load_mesh( - match head { - fish_medium::Head::Default => "npc.marlin.head", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) +impl FishSmallCentralSpec { + fn mesh_head(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No head specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.head.central.0); + + (central, Vec3::from(spec.head.offset)) + } + + fn mesh_chest(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No chest specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.chest.central.0); + + (central, Vec3::from(spec.chest.offset)) + } + + fn mesh_tail(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No tail specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let central = graceful_load_segment(&spec.tail.central.0); + + (central, Vec3::from(spec.tail.offset)) + } } -fn mesh_fish_medium_torso(torso: fish_medium::Torso) -> BoneMeshes { - load_mesh( - match torso { - fish_medium::Torso::Default => "npc.marlin.torso", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} +impl FishSmallLateralSpec { + fn mesh_fin_l(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No fin specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let lateral = graceful_load_segment(&spec.fin_l.lateral.0); -fn mesh_fish_medium_rear(rear: fish_medium::Rear) -> BoneMeshes { - load_mesh( - match rear { - fish_medium::Rear::Default => "npc.marlin.rear", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} + (lateral, Vec3::from(spec.fin_l.offset)) + } -fn mesh_fish_medium_tail(tail: fish_medium::Tail) -> BoneMeshes { - load_mesh( - match tail { - fish_medium::Tail::Default => "npc.marlin.tail", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} + fn mesh_fin_r(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { + let spec = match self.0.get(&(species, body_type)) { + Some(spec) => spec, + None => { + error!( + "No fin specification exists for the combination of {:?} and {:?}", + species, body_type + ); + return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); + }, + }; + let lateral = graceful_load_segment(&spec.fin_r.lateral.0); -fn mesh_fish_medium_fin_l(fin_l: fish_medium::FinL) -> BoneMeshes { - load_mesh( - match fin_l { - fish_medium::FinL::Default => "npc.marlin.fin_l", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} - -fn mesh_fish_medium_fin_r(fin_r: fish_medium::FinR) -> BoneMeshes { - load_mesh( - match fin_r { - fish_medium::FinR::Default => "npc.marlin.fin_r", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) + (lateral, Vec3::from(spec.fin_r.offset)) + } } //// @@ -2583,49 +2854,7 @@ fn mesh_bird_small_wing_r(wing_r: bird_small::WingR) -> BoneMeshes { Vec3::new(-7.0, -6.0, -6.0), ) } -//// -make_vox_spec!( - fish_small::Body, - struct FishSmallSpec {}, - |FigureKey { body, .. }, _spec| { - [ - Some(mesh_fish_small_torso(body.torso)), - Some(mesh_fish_small_tail(body.tail)), - None, - None, - None, - None, - None, - None, - None, - None, - None, - None, - None, - None, - None, - None, - ] - }, -); -fn mesh_fish_small_torso(torso: fish_small::Torso) -> BoneMeshes { - load_mesh( - match torso { - fish_small::Torso::Default => "npc.cardinalfish.torso", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} - -fn mesh_fish_small_tail(tail: fish_small::Tail) -> BoneMeshes { - load_mesh( - match tail { - fish_small::Tail::Default => "npc.cardinalfish.tail", - }, - Vec3::new(-7.0, -6.0, -6.0), - ) -} //// #[derive(Deserialize)] struct BipedLargeCentralSpec(HashMap<(BLSpecies, BLBodyType), SidedBLCentralVoxSpec>); diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index cea487d962..cd58b7d409 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -2203,11 +2203,18 @@ impl FigureMgr { &mut state_animation_rate, skeleton_attr, ), - - // TODO! - _ => anim::fish_medium::IdleAnimation::update_skeleton( + // Idle Water + (_, false, true) => anim::fish_medium::SwimIdleAnimation::update_skeleton( &FishMediumSkeleton::default(), - time, + (vel.0, ori, state.last_ori, time, state.avg_vel), + state.state_time, + &mut state_animation_rate, + skeleton_attr, + ), + // Swim + (_, true, true) => anim::fish_medium::SwimAnimation::update_skeleton( + &FishMediumSkeleton::default(), + (vel.0, ori, state.last_ori, time, state.avg_vel), state.state_time, &mut state_animation_rate, skeleton_attr, @@ -2598,11 +2605,10 @@ impl FigureMgr { &mut state_animation_rate, skeleton_attr, ), - - // TODO! - _ => anim::fish_small::IdleAnimation::update_skeleton( + // Swim + (_, _, true) => anim::fish_small::SwimAnimation::update_skeleton( &FishSmallSkeleton::default(), - time, + (vel.0, ori, state.last_ori, time, state.avg_vel), state.state_time, &mut state_animation_rate, skeleton_attr, diff --git a/world/src/layer/wildlife.rs b/world/src/layer/wildlife.rs index fac6efe6b0..54c7d3970b 100644 --- a/world/src/layer/wildlife.rs +++ b/world/src/layer/wildlife.rs @@ -1,8 +1,8 @@ use crate::{column::ColumnSample, sim::SimChunk, IndexRef, CONFIG}; use common::{ comp::{ - biped_large, bird_medium, quadruped_low, quadruped_medium, quadruped_small, theropod, - Alignment, + biped_large, bird_medium, fish_medium, quadruped_low, quadruped_medium, quadruped_small, + theropod, Alignment, }, generation::{ChunkSupplement, EntityInfo}, terrain::Block, @@ -761,6 +761,21 @@ pub fn apply_wildlife_supplement<'a, R: Rng>( close(c.temp, CONFIG.desert_temp + 0.2, 0.3) * BASE_DENSITY * 5.0 }, }, + // Underwater + Entry { + make_entity: |pos, rng| { + EntityInfo::at(pos) + .with_body( + fish_medium::Body::random_with(rng, &fish_medium::Species::Marlin).into(), + ) + .with_alignment(Alignment::Wild) + }, + group_size: 3..5, + is_underwater: true, + get_density: |c, col| { + close(c.temp, CONFIG.temperate_temp, 1.0) * col.tree_density * BASE_DENSITY * 5.0 + }, + }, ]; for y in 0..vol.size_xy().y as i32 { From 6f200ffe9361e3476f1b0a32f428f61a79a3c26f Mon Sep 17 00:00:00 2001 From: Snowram Date: Sun, 29 Nov 2020 17:22:13 +0100 Subject: [PATCH 2/5] Improves fish_small, new npc --- assets/common/npc_names.json | 8 +-- .../voxel/fish_small_central_manifest.ron | 28 ++++------- .../voxel/fish_small_lateral_manifest.ron | 20 ++++---- .../voxel/npc/clownfish/male/chest.vox | Bin 0 -> 1756 bytes .../voxel/npc/clownfish/male/fin_l.vox | Bin 0 -> 1132 bytes .../voxel/npc/clownfish/male/fin_r.vox | Bin 0 -> 1132 bytes .../voxygen/voxel/npc/clownfish/male/tail.vox | Bin 0 -> 1172 bytes assets/voxygen/voxel/npc/gecko/male/Gecko.vox | Bin 57760 -> 0 bytes assets/voxygen/voxel/npc/mindflayer/leg_l.vox | Bin 4940 -> 0 bytes assets/voxygen/voxel/npc/mindflayer/leg_r.vox | Bin 4940 -> 0 bytes .../voxel/npc/mindflayer/torso_lower.vox | Bin 9004 -> 0 bytes .../voxel/npc/mindflayer/torso_lower2.vox | Bin 1996 -> 0 bytes common/src/comp/body.rs | 2 +- common/src/comp/body/fish_small.rs | 8 +-- common/src/npc.rs | 8 +-- voxygen/anim/src/fish_medium/idle.rs | 1 - voxygen/anim/src/fish_small/idle.rs | 5 +- voxygen/anim/src/fish_small/jump.rs | 5 +- voxygen/anim/src/fish_small/mod.rs | 21 ++++---- voxygen/anim/src/fish_small/run.rs | 5 +- voxygen/src/anim/src/fish_medium/swim.rs | 8 +-- voxygen/src/anim/src/fish_medium/swimidle.rs | 7 ++- voxygen/src/anim/src/fish_small/swim.rs | 35 +++++++++---- voxygen/src/anim/src/fish_small/swimidle.rs | 46 ++++++++++++++++++ voxygen/src/scene/figure/load.rs | 22 +-------- voxygen/src/scene/figure/mod.rs | 10 +++- 26 files changed, 132 insertions(+), 107 deletions(-) create mode 100644 assets/voxygen/voxel/npc/clownfish/male/chest.vox create mode 100644 assets/voxygen/voxel/npc/clownfish/male/fin_l.vox create mode 100644 assets/voxygen/voxel/npc/clownfish/male/fin_r.vox create mode 100644 assets/voxygen/voxel/npc/clownfish/male/tail.vox delete mode 100644 assets/voxygen/voxel/npc/gecko/male/Gecko.vox delete mode 100644 assets/voxygen/voxel/npc/mindflayer/leg_l.vox delete mode 100644 assets/voxygen/voxel/npc/mindflayer/leg_r.vox delete mode 100644 assets/voxygen/voxel/npc/mindflayer/torso_lower.vox delete mode 100644 assets/voxygen/voxel/npc/mindflayer/torso_lower2.vox create mode 100644 voxygen/src/anim/src/fish_small/swimidle.rs diff --git a/assets/common/npc_names.json b/assets/common/npc_names.json index 121b6da491..210da2b2db 100644 --- a/assets/common/npc_names.json +++ b/assets/common/npc_names.json @@ -686,7 +686,7 @@ "species": { "reddragon": { "keyword": "reddragon", - "generic": "Reddragon" + "generic": "Red Dragon" } } }, @@ -705,9 +705,9 @@ ] }, "species": { - "sardine": { - "keyword": "sardine", - "generic": "Sardine" + "clownfish": { + "keyword": "clownfish", + "generic": "Clownfish" } } }, diff --git a/assets/voxygen/voxel/fish_small_central_manifest.ron b/assets/voxygen/voxel/fish_small_central_manifest.ron index 13abb5b285..cd6a16b8f8 100644 --- a/assets/voxygen/voxel/fish_small_central_manifest.ron +++ b/assets/voxygen/voxel/fish_small_central_manifest.ron @@ -1,30 +1,22 @@ ({ - (Sardine, Male): ( - head: ( - offset: (-4.0, 0.0, -3.0), - central: ("npc.sardine.male.head"), - ), + (Clownfish, Male): ( chest: ( - offset: (-5.0, -7.5, -3.0), - central: ("npc.sardine.male.chest"), + offset: (-1.5, -7.5, -5.0), + central: ("npc.clownfish.male.chest"), ), tail: ( - offset: (-1.0, -9.0, -1.5), - central: ("npc.sardine.male.tail"), + offset: (-0.5, -5.0, -2.5), + central: ("npc.clownfish.male.tail"), ), ), - (Sardine, Female): ( - head: ( - offset: (-4.0, 0.0, -3.0), - central: ("npc.sardine.male.head"), - ), + (Clownfish, Female): ( chest: ( - offset: (-5.0, -7.5, -3.0), - central: ("npc.sardine.male.chest"), + offset: (-1.5, -7.5, -5.0), + central: ("npc.clownfish.male.chest"), ), tail: ( - offset: (-1.0, -9.0, -1.5), - central: ("npc.sardine.male.tail"), + offset: (-0.5, -5.0, -2.5), + central: ("npc.clownfish.male.tail"), ), ), }) diff --git a/assets/voxygen/voxel/fish_small_lateral_manifest.ron b/assets/voxygen/voxel/fish_small_lateral_manifest.ron index c93e3579df..55415f9a5d 100644 --- a/assets/voxygen/voxel/fish_small_lateral_manifest.ron +++ b/assets/voxygen/voxel/fish_small_lateral_manifest.ron @@ -1,22 +1,22 @@ ({ - (Sardine, Male): ( + (Clownfish, Male): ( fin_l: ( - offset: (-1.5, -5.0, -3.0), - lateral: ("npc.sardine.male.fin_l"), + offset: (-0.5, -3.0, -4.0), + lateral: ("npc.clownfish.male.fin_l"), ), fin_r: ( - offset: (-1.5, -5.0, -3.0), - lateral: ("npc.sardine.male.fin_r"), + offset: (-0.5, -3.0, -4.0), + lateral: ("npc.clownfish.male.fin_r"), ), ), - (Sardine, Female): ( + (Clownfish, Female): ( fin_l: ( - offset: (-1.5, -5.0, -3.0), - lateral: ("npc.sardine.male.fin_l"), + offset: (-0.5, -3.0, -4.0), + lateral: ("npc.clownfish.male.fin_l"), ), fin_r: ( - offset: (-1.5, -5.0, -3.0), - lateral: ("npc.sardine.male.fin_r"), + offset: (-0.5, -3.0, -4.0), + lateral: ("npc.clownfish.male.fin_r"), ), ), }) diff --git a/assets/voxygen/voxel/npc/clownfish/male/chest.vox b/assets/voxygen/voxel/npc/clownfish/male/chest.vox new file mode 100644 index 0000000000000000000000000000000000000000..eeae4a175bda655ba06e1a34df355a0c758b181c GIT binary patch literal 1756 zcmXBSziu5x7>4n0XLrxP1PNaO$QMAtbi|1iWE4dRkU)+?M1h1fHJvGtDDf2_hMvZE zfJ{k2F}Gk*)1;(|7=E*ya`Q@wUKPQFHuj6Npo-oDKr)lc3Og$mi=^`O^Mof_|rU@xc(~Kou#OfLeu~Q?B zagT$ZBTnhb^dLQ9VUGDCAtp5vBF(0qO*{Ly8VRwe7d^&U^&=s6Y9z#74-(>_MnW9* zARXt&aZ;b=N9i;_o*v9krib&Rh=t3-W#OVmLU{2B2{EgY5Q}=zV~kZl5@M%DLhSYI z)y6oekq}2cNXLbX8tJrf!NbM6tXx(uD;G5q!s1Uzh*^z6j(U)eE0?uTNMn4kKAvLd*|6Euyz?A25@J;&A$Dpc#9obrIJgf9aa1FX@w7Ad z-r2&kHxG8$WtD0Dz9=rjZfnR%sRgoCSH$y&_o=@RZ_!K^c&$bC!3ZKGf+um)L#>xzv@s*D)=aczlKABJEvmFCI znNQ}E`D8xZ(cqK$WImZl_R#IPm@K<7Ys!MmXB?r-C-cdCGM~(6J679?8M`!AX4v?S zqsAxr1fSp&eB2H>pWqXGf{!U7=M#K_Pw?>=$oT}H;1gs#8gdhcn?vJk;XUqfiyK_y z3YR#?8RB*H5B`Y$&Yk*4{D5n`z$MOchIoy8+~F2CxW*MOagH-5r1$&#`+j$K*Kcoc d`_0WwzrMciS65g4^768upP%=$vopOB{{eF_ktzTH literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/npc/clownfish/male/fin_l.vox b/assets/voxygen/voxel/npc/clownfish/male/fin_l.vox new file mode 100644 index 0000000000000000000000000000000000000000..148f279b980b3fc4c508ae90d14350dc77ab5a67 GIT binary patch literal 1132 zcmXBSv1(L76b9gvm`1R0pFr8l%EIX+O=LxasGw|!Vj&2pwp%+J!F>W@e1v@iSxd`# zg~i$?rB!hJX3WjM_wLW!d%vBTix-!7zedEfv-9Upad{H)>io^)TjPtrBe@~!xP1NQ z{GRjpyZQgr4LCK*`RFu`C5~MmyOyIH{pFKKXY*#`fBpX3dv8)DrAYj*n!f3q{>KMr z{TTM{eeX}tTHUf+u*qM)W+v6FdRq)uQ*naB~=Vr98-9cCwX?tYsxjSx8((fA}-{oxSTX z@<}#wAuCzRLgGpevX`A~Wg}}@$x;?}NbiTkq3`$mzT55kcDwDH&8Dx{>%Lm8`f|DK Ji^am&h<`NbX)*u+ literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/npc/clownfish/male/fin_r.vox b/assets/voxygen/voxel/npc/clownfish/male/fin_r.vox new file mode 100644 index 0000000000000000000000000000000000000000..148f279b980b3fc4c508ae90d14350dc77ab5a67 GIT binary patch literal 1132 zcmXBSv1(L76b9gvm`1R0pFr8l%EIX+O=LxasGw|!Vj&2pwp%+J!F>W@e1v@iSxd`# zg~i$?rB!hJX3WjM_wLW!d%vBTix-!7zedEfv-9Upad{H)>io^)TjPtrBe@~!xP1NQ z{GRjpyZQgr4LCK*`RFu`C5~MmyOyIH{pFKKXY*#`fBpX3dv8)DrAYj*n!f3q{>KMr z{TTM{eeX}tTHUf+u*qM)W+v6FdRq)uQ*naB~=Vr98-9cCwX?tYsxjSx8((fA}-{oxSTX z@<}#wAuCzRLgGpevX`A~Wg}}@$x;?}NbiTkq3`$mzT55kcDwDH&8Dx{>%Lm8`f|DK Ji^am&h<`NbX)*u+ literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/npc/clownfish/male/tail.vox b/assets/voxygen/voxel/npc/clownfish/male/tail.vox new file mode 100644 index 0000000000000000000000000000000000000000..bbcfa2cde9c8da80060f496ca8519722d6d00d38 GIT binary patch literal 1172 zcmXZay^2#o7zW_)B(bwFcmYZ-z{2UoW+ftv_=A#VT`UA)YP;BJA($%=#!JW@NGvVq z7J{|SmR5`7Gowk~{JhMW^JHeuo}J(R5)n^MPM`XSkBf+xrxy>e_a7dUT>GE%R~M(x zd+BkrzfI9%Au+X>ru#9I`835sVy2tvWIoeL%yn~}%;!3p7Uo#A7mpsCm}@+K{`%8e zt5PIOlK59uebra}_jf+^eb}3~tvx>RU0;kZ`hICPJ{yqz$oj1B(Ry;lo; z=tCd+h#{%os~c65Rufc%2gO_EsXVpnc?PfOi=L)jjUuT`GPQ+X;+<>`M{BmJ2ri5|W16oBGpg{Safh~AgNQ+Nu`SSp^v zQ+SH?Db{B!pY(iIC@D!fHQ+NuGzcp4x}4lg*~nT}vUEaPJ06eia5%L6 ce&2SxUE6NAZL`_5^?Kb_t5sVrm&Qi?1<^)r2mk;8 literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/npc/gecko/male/Gecko.vox b/assets/voxygen/voxel/npc/gecko/male/Gecko.vox deleted file mode 100644 index 2a48cdf07c19c368154a3e5e0b53e3586f4eb60f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 57760 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 diff --git a/assets/voxygen/voxel/npc/mindflayer/leg_r.vox b/assets/voxygen/voxel/npc/mindflayer/leg_r.vox deleted file mode 100644 index abc705d27e1ade7b3255198b0df3b00defbfc72d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4940 zcmajieW>4M8OQPK_r31xzVGkj@64TT?x9WR)6TY>b2^<pH!xz7bZr&WaiW{RH7 zD0&6gg-j^|*Ci_Slw4(?2r%vwGD?-HiYbBD1sN1j1Q;TDV&))ICD&ry8}}%=&JhWj z`^@K+GN?+KsZmy3S29(jskpDXuj!B*Uf(cVbX<3QZlBNX^F4i;i9<3-Lv$#Ict)nq zlbJA2rVNqm64h*Wp3E4+{MmE%rc`^Jvp3ZXy{RJfI1l$Q?jsV!=&d&>pa?KTBxL#+ zxkiq>CovN&8+Dgt{Y~{Y?&Ridk~9z6)_^_W25) zui*KLfmkuM*&5EAvW|4eapE}KoMYwNG*Hl^d;?dI&|y-5eeES z>ytq&u(QC<0y_)rEU>e{&ccViNDhr*Ixr0plIRj0G|@2)5t8XL9W>K14G{@a(wFqm zlAdXZNRW!YqK8)WOhZJ1)buqyw5DeoA`+ybZ|I>7J<|}8AZ=i0ft`hyw54z95s^@I zM#BKwN$E3&W1z9Rb~gT~0dBKsmw6wOz1gYpNdT2$@G(;pwO<&VPYkH<3B0(DZh926`GYt_5 z(k6D5*i~Xz^esIi5{izzBk#x&k)VCDJ{iO^yUOe;v#ZRmGP}y`iVTVXgCz1q4n=?= zLNZ;ZgCf8Xksu{~Ne@MUAtFI4`idTk07FEA)buqy6aj{a1Zn6SdME-65ed>}c9q#x zW>@quL?jd)c}EUIM1uA+yW;&;vZs^ykwFn)kW8M*p$ITUNJ&@HK@nhxkczINgCf8XAvIl1 z2StD(LK?b;4vGLngtQgsuQ-3j`RQPYC_1u^42B5pSDc^sSRStf%bz#t`gNe)GTK`Qc!9Et#g)Z{fe6afZl$QyDf0u0i2Ja@-) zcRY8;ze8lHKj@)=WUf&_5g=uMqF0hZ5g-*=MFvHH)MPao6amtZHDpi(NK1yI?eh$M zo}oYZ-0e5t#Q(p}{Ww39lav0z^Ws|uXZ)h!fBD~shyC>F?X#7?y7lLuXlQhyZ{BmY zkA3|{ADQ0dGG;FOE0<&Extv+(L)*m{Js`ej>@r{b6Y;!Xygej7|A_d)SH!Q{Ui-EO zhJ5_7`Tq24pYmHL#djPP|MCg(N8aYWJC^wJeJlOq$<@B`)Tl3=81|Kim-yKXRY=u><0_jEK+d{j?vrmG?cg%`cfh z&-ab3^n*KA`QBBld~Er0e|+6)e`U)p{wNsPH~IcA-Q|-H?)GOM z{fZy_#<(AOV!xj{{-mFMbKo~@TTC&eXINjhc@_`S8s9u=i5H<%#a`c@v#5& z?Zy6{uQ=!V_g*V==YR3ffAt+#E%9BOmiZO;Px{plKIIc9f8_^$`5XV%nLqfG@4WA8 zE?W5U`4`ERzFbCqjqLGj(bNC{ diff --git a/assets/voxygen/voxel/npc/mindflayer/torso_lower.vox b/assets/voxygen/voxel/npc/mindflayer/torso_lower.vox deleted file mode 100644 index 0c63b54be9f4a1d1d27f38a6807c109a04d90db4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9004 zcmajkZOm?0Stsy)&VBE_*V|re?|nbdDQ&S}L1_z$yjaC5wuOTfty-NBDOe{4GsASq zn4@W+sU}h-0m2L-<7ni(kO?6ZBbi}3Bx<4(Qzs@y2^wRfh8RQi%Y2)R^KH%V=}i1G zs3-a5T6?YQ|D5i1rE&T4aO*%IULI~Fvh_l>ZmiblT;cLT|6#asR7YmQ zVYnViWX}uLy0Nl(K5@pm>=pHJ9Bv(t!;SGcT%W9GH4sT;iv2~cG*&it`zQ5G{@nU7 z`dQ;}eWX~Q)HBX6_9wqD$64hNtb=pTtuICI#36d-iuG*_$ypk1T;`CRamD&JUUYGm zzUs)ddS6b~ zXPi5`qF&zgF)?q$jX<<+tkxU5^*L9VclX4~cCkKL6AqVd#KR?bcj-o@S+DANymVt? zCLAxh7d>Rp3)Q-@vU%P)aU5mGOV=l60+B?fIA7FCV`XFK#F_Ks>X$O zvuDn%kHK^B%$fBe+KbklTOZP;>qpKw=a8Le&zxVZi+qvi%=)-^UOaPVeXO3VXU;Cx z%{OWOnK)gnSKnv#j>PrSt;TA-u{#UL%f8!X-|ey)zU+Hl_Ps9qHkW;y%f5|s5}Cq6 zrLnTHGfr~MZ0wvEXZ!4&7=y|&T65xzWAe<2GmhCaC(bU`#hP(Z8LOYm&go*^{N4m& zyL_{;T5s&k2NKQ$P^YTjg?K` z&NR!+hihRzd?k{|6c#Ftl}+ESe++WraBU8UuLL5AOkttYSlQV1pXA0U8)c&`kwm7j zP-(1e?D|h~W0Fm>NtQ?=Q&^}pRyKD1C%G}pX4x!DB#|jBR2nNAyZ)2hSY(TAktLGI z6c#Ftm5p8hNp4(Z7g++4M5eG%X{>DQoaDwT%S<5F!_8C=pR6?N)!xR=iMi<`wu3ox zZoQGW!>z)?JRZ%{(L5c^)6qN~&C}659nI6xJRQx`(L5c^)6qQXCr-zkNzIh$_}7bC zY4%rjV`rLW2*g=N&6HV2tu*_qy0J3`Ic5Se$f=nU9P znkhwAtu*_qy0LR&Tx6LE#6@;Feljmd^K>*%NAq<2WV63I-`F`ZR#|2OvC7t?dD3sa z+S}MUF*kk0b~I1UtvAwkyp^}(jlx3p9LCX1jb>^zQ=^$0&D3b7Ml&^7`7gdD2U>zp5KM(=0Gi!3vNSY*{qDY9y%*I$t>xcCbOiEGEHVlAI<)%ZcMX&0&&)_X3DHztu*_qy0J3`Ic5Se$f=nU9PnkhwAtu*_qy0LR&Tx6LE#6@a>O*gCOFwW*^Hb=8Ln$6K{ zj%IT-o1@tr&E{w}NBXAO9OvpLd7v%jhv)2yFBob{`jGV50>&Hk!x?2JKc-BAG0HL%h*4I}lqjoKn*CMX*f}vKS!Mz;$*P%>WYtQuzp5KMC&nzx zOdw`iHB+*zT50xIbz|qmSY(+A#3HL^N|9A7&Hk!x?3@@ES!M!pkzHnUG@GN@9L?rv zHb=6~H+D{pRhF4Rtg>}BNBXT-dmB3^=BAI>W^?4+dLwPKIhy@_G~Zm*>N$+T90hX} z%uz5$!5js16wFaDN5LEgbEJ<%rcA*c>7%i-G0pl3L=u@Y>sKp{m5rS-$T1U$Br+w) zsg=gc#?FZ`$}$s(Br+w+s+Gpd#?FZ`$ubj&Br+w*s+Gpd#?FZ`%Q6#)Br+w-s+Gpd z#?Fbc$TAa%Br>JQs+Gpd#?Faxk!2_oE@%}z8k(abm}Q>JKU zoYPpDXMIExnKJ8BD~*+nDd;B8#_~!ArMJqN|aG6jg^g^DajCsBr+w* zsFlXb#?F*w2t*Q@l4aCNV`XD!Dl!BjiA*UnYNfHVu`?|)1R`mP?moKv=8MV?_+1Qz~41q`@Q?iU&X{>DQOhtx3B#|jaMy)hfHg={(hCn1O*?ngBncZi0 zpV@uNu(2~$83M6p|L)K3Q=j!}Z(}E|+5P34WzFs{->ja~SlnN6f5rV3_gCCsaewwH zQ*nRxX@uE1iA(U#&D&Hg={YLm-mKlq928 z8Y>$+Q&Rdw8#*Mq@}pO;{J;JEAFqjKN&W5 z=Bl4qi@PiCPLK6!ZzHY6y%m4%%FRWsp3}6rpT+$w*B2^bUfj*%Zk$o(#oaigu`&mJ zL=u@2^r@A`%Elb^5=mrA)T>q+D;smtOC*sgNv~RItZd9#FOfv1WW8#ov9d82y+jh3 zQuL~o#>&RL=p~Yt#dlwP_r-T#eD}q7*UNU%Qy1TQ@vZG&tlM%cx8-JO%Z){?p3_u) z9T4}6o%vmpyM5biDYNfHVF&Di=5}8u;s+GpdMp*PM)qk5*-?#d{)%UHwZ}okv z|2FY6TJBn*9)(@7H`k=M)wyjg=7fkjRwS zt}SY%u@aIV5}A_psFlV_$a+X*O4g%R8Y`jbA(1IXk6LN0ghkKNe4FOmG~Y%K)pN7I zI#0FT%GGyZp?Xg9`f#SOP>ErEIFTtVR2nfli|a#~!a}9lkI7kbMq#1S?8odZJEO2r zY4&4rR-92-s5JX=ake<4uuy3i`_(^Vwa-HJoTknFZtixwk>~B9!b0^N!}d@L_SM2d z_1x4LokeGAVWE0%YD~_^6c#Ftn4OU+EL0k?I3rV7sI;tFc7qZdd0*B<$A|ETrBEB%3Y zeRIG1uix13z4?YdTpj!HWa`7G_C7p+rLT_;{kHcG{gqc=(O>nShaR3B`tt11Pahll zm0unD>mSYiZSP(C<3DriAO8H;^fx~<^v6Ci^dJ4~(BJ<>*~jkacfIHC{_-RtR zV88R)S-<K}OZef?M8`lkM0-};vRZ7;dAfBS1+(!cvV@997G_HXG=zHR8w{_yZZ&xc?0s($tB zzqUVe-^=^E?*GPq?agoKZ@=$Kf6wdh>>vHEuj|h}@#_Bg_dnF1{O8}>pZW23_K*DZ zzvxf@o5%ade(uTs+-E-6zx2D;`*+;`s_uU;^cP<__1D~ccfbD|zrKIlYwzvveC#d# z-H$)oKlZaP?w`GNcmK2Bzpwx0AHK4G^4|^pxla%M4}Np#fBnZpfBHT5^j~`Rb^ZBY zdsFX!_r-qgBWwTYe>&^`<%_rXzw9shs_*~Aw+=77|F8V{-}J{`e@B1E8(!SM>BpYw z-~8hr>eoK^Tm7lu_`Uv9&;L>X;2(dvzw%{Q{{H=M8(!P*8XoMg9NyKxb$EZjI{f>7 z|6O%X{~ura$^QAr zZ|@&}=}Z5=-~XcTv7dNff5#90LBIAddw>6b_)LHHKR(z0?dN{C|MKsA>4kTE;|Ff` z@4oTdFTCS}4?fucYUq6k^#9clUmE(Ce|>o2pYO}&>z_LJr|^Y8XJ57c=BNMRGbb0B dubTURXBXiYKm6YQqBs0Vzw_0f{c63#{{dI~y+8l} diff --git a/assets/voxygen/voxel/npc/mindflayer/torso_lower2.vox b/assets/voxygen/voxel/npc/mindflayer/torso_lower2.vox deleted file mode 100644 index 7ab02a59dcc17847ce40d2bec3ab560a8a28d4a1..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1996 zcmaizZD>|y7{{-3-}gD^dD+%%Z|jOks8z2tn`F01pmz`_p6UCfo@!5|UqKP6tajdoVLUd@DaK7Ol+g5b$WM6eX=q)d0%=K) zs9>0LNGO<8#0zVph{K+mDB>hdSduQ$)`o%!6AH3tFyV&XF*j^zJ)-F=S|?$`E-_<< zaTC@=5htOk*VJpqHT9Zt&G-{rqY*KwUsAwlaBvX!&Ip>$&tOsZU-&&c8`rM2+7vD| zfAT;w8*|anwHmP(H==y39ujjQy&=f>!;qO=WVQ9AkZsF9};AZ2y!n9 zR<(xFvM&?yBUw0k`4Ma$6ts;Bo}CmNy2;wM0u=X@V)0-F>ZTh}*q4pc;Q~}#C_&BF z%aGS4SbRiKbyl$csz9FP{DA;uGy^h~jT6h}VPZuNZf__AS{9-~1kL1o@(UR~D42Xx zaBV^`+`aQYCp)*}g)I$;Hwq563r6+`#`^`E$_2^pN728Tbq89oBx@deVx<^pD?@i# z8Dho7I9gqSi%pyGanly8D=EbKl_l8rSQ+-VuR(8%VCX4HX-?KuA+~fOnkyEgt8O{^ zHrJ!QA{RZY3NgHO38uTN5q~^_-e-1TaDOLG9exf2FU2u(tQXT0$1!{TJT}x-ArMMK zQEnD$%1cqVd@0tgEJtVC7VL?)V&v5#OeRb5!#5SU^KB*GdqXgNL2%=W;OAR{fu1tF zGgOP2OPhc{Z=&y1CWb%A#z!~vaR()H-oJaTr0#$2$6wL5ssJ7JMOd+S5Ucl}K;P6C z=>PmHyfX70j^DbA%0;>N@1G|tQ7nz9lrF55Lx{;+s4Fgb;QecBYjJwb7^-W=(Qx7@ z@`v*A(@ZaJck-R(%e$SaJYcq4&TS=W24yEa0Yu$ z9mo9cJp4BMGA_sSac04Sf6ceLwgU&zvFirj core::ops::Index for AllBodies &self.quadruped_small.body, NpcKind::Wolf => &self.quadruped_medium.body, NpcKind::Duck => &self.bird_medium.body, - NpcKind::Sardine => &self.fish_medium.body, + NpcKind::Clownfish => &self.fish_medium.body, NpcKind::Marlin => &self.fish_small.body, NpcKind::Ogre => &self.biped_large.body, NpcKind::StoneGolem => &self.golem.body, diff --git a/common/src/comp/body/fish_small.rs b/common/src/comp/body/fish_small.rs index b962d56ea4..90c7597436 100644 --- a/common/src/comp/body/fish_small.rs +++ b/common/src/comp/body/fish_small.rs @@ -34,7 +34,7 @@ make_case_elim!( #[derive(Copy, Clone, Debug, PartialEq, Eq, Hash, Serialize, Deserialize)] #[repr(u32)] pub enum Species { - Sardine = 0, + Clownfish = 0, } ); @@ -43,7 +43,7 @@ make_case_elim!( /// NOTE: Deliberately don't (yet?) implement serialize. #[derive(Clone, Debug, Deserialize)] pub struct AllSpecies { - pub sardine: SpeciesMeta, + pub clownfish: SpeciesMeta, } impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies { @@ -52,12 +52,12 @@ impl<'a, SpeciesMeta> core::ops::Index<&'a Species> for AllSpecies #[inline] fn index(&self, &index: &'a Species) -> &Self::Output { match index { - Species::Sardine => &self.sardine, + Species::Clownfish => &self.clownfish, } } } -pub const ALL_SPECIES: [Species; 1] = [Species::Sardine]; +pub const ALL_SPECIES: [Species; 1] = [Species::Clownfish]; impl<'a, SpeciesMeta: 'a> IntoIterator for &'a AllSpecies { type IntoIter = std::iter::Copied>; diff --git a/common/src/npc.rs b/common/src/npc.rs index ee997f4726..806a34d24f 100644 --- a/common/src/npc.rs +++ b/common/src/npc.rs @@ -13,7 +13,7 @@ pub enum NpcKind { Wolf, Pig, Duck, - Sardine, + Clownfish, Marlin, Ogre, Archaeos, @@ -27,7 +27,7 @@ pub const ALL_NPCS: [NpcKind; 11] = [ NpcKind::Wolf, NpcKind::Pig, NpcKind::Duck, - NpcKind::Sardine, + NpcKind::Clownfish, NpcKind::Marlin, NpcKind::Ogre, NpcKind::Archaeos, @@ -97,7 +97,7 @@ pub fn kind_to_body(kind: NpcKind) -> Body { NpcKind::Pig => comp::quadruped_small::Body::random().into(), NpcKind::Wolf => comp::quadruped_medium::Body::random().into(), NpcKind::Duck => comp::bird_medium::Body::random().into(), - NpcKind::Sardine => comp::fish_small::Body::random().into(), + NpcKind::Clownfish => comp::fish_small::Body::random().into(), NpcKind::Marlin => comp::fish_medium::Body::random().into(), NpcKind::Ogre => comp::biped_large::Body::random().into(), NpcKind::Archaeos => comp::theropod::Body::random().into(), @@ -204,7 +204,7 @@ impl NpcBody { .or_else(|| { parse( s, - NpcKind::Sardine, + NpcKind::Clownfish, &npc_names.fish_small, comp::fish_small::Body::random_with, ) diff --git a/voxygen/anim/src/fish_medium/idle.rs b/voxygen/anim/src/fish_medium/idle.rs index 3c8497f5e7..26c57a6d54 100644 --- a/voxygen/anim/src/fish_medium/idle.rs +++ b/voxygen/anim/src/fish_medium/idle.rs @@ -22,7 +22,6 @@ impl Animation for IdleAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let slower = (anim_time as f32 * 1.0 + PI).sin(); let slow = (anim_time as f32 * 3.5 + PI).sin(); let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); diff --git a/voxygen/anim/src/fish_small/idle.rs b/voxygen/anim/src/fish_small/idle.rs index 42a0fd663e..3622cf8b67 100644 --- a/voxygen/anim/src/fish_small/idle.rs +++ b/voxygen/anim/src/fish_small/idle.rs @@ -21,10 +21,7 @@ impl Animation for IdleAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.scale = Vec3::one() / 11.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; next.chest.orientation = Quaternion::rotation_x(0.0); diff --git a/voxygen/anim/src/fish_small/jump.rs b/voxygen/anim/src/fish_small/jump.rs index b02202ee0f..5b9511184d 100644 --- a/voxygen/anim/src/fish_small/jump.rs +++ b/voxygen/anim/src/fish_small/jump.rs @@ -21,10 +21,7 @@ impl Animation for JumpAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.scale = Vec3::one() / 11.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; next.chest.orientation = Quaternion::rotation_x(0.0); diff --git a/voxygen/anim/src/fish_small/mod.rs b/voxygen/anim/src/fish_small/mod.rs index a18c569e2f..dafa89e9f0 100644 --- a/voxygen/anim/src/fish_small/mod.rs +++ b/voxygen/anim/src/fish_small/mod.rs @@ -2,9 +2,13 @@ pub mod idle; pub mod jump; pub mod run; pub mod swim; +pub mod swimidle; // Reexports -pub use self::{idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation}; +pub use self::{ + idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation, + swimidle::SwimIdleAnimation, +}; use super::{make_bone, vek::*, FigureBoneData, Skeleton}; use common::comp::{self}; @@ -13,7 +17,6 @@ use core::convert::TryFrom; pub type Body = comp::fish_small::Body; skeleton_impls!(struct FishSmallSkeleton { - + head, + chest, + tail, + fin_l, @@ -24,7 +27,7 @@ impl Skeleton for FishSmallSkeleton { type Attr = SkeletonAttr; type Body = Body; - const BONE_COUNT: usize = 5; + const BONE_COUNT: usize = 4; #[cfg(feature = "use-dyn-lib")] const COMPUTE_FN: &'static [u8] = b"fish_small_compute_mats\0"; @@ -37,7 +40,6 @@ impl Skeleton for FishSmallSkeleton { let chest_mat = base_mat * Mat4::::from(self.chest); *(<&mut [_; Self::BONE_COUNT]>::try_from(&mut buf[0..Self::BONE_COUNT]).unwrap()) = [ - make_bone(chest_mat * Mat4::::from(self.head)), make_bone(chest_mat), make_bone(chest_mat * Mat4::::from(self.tail)), make_bone(chest_mat * Mat4::::from(self.fin_l)), @@ -48,7 +50,6 @@ impl Skeleton for FishSmallSkeleton { } pub struct SkeletonAttr { - head: (f32, f32), chest: (f32, f32), tail: (f32, f32), fin: (f32, f32, f32), @@ -68,7 +69,6 @@ impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { impl Default for SkeletonAttr { fn default() -> Self { Self { - head: (0.0, 0.0), chest: (0.0, 0.0), tail: (0.0, 0.0), fin: (0.0, 0.0, 0.0), @@ -80,17 +80,14 @@ impl<'a> From<&'a Body> for SkeletonAttr { fn from(body: &'a Body) -> Self { use comp::fish_small::Species::*; Self { - head: match (body.species, body.body_type) { - (Sardine, _) => (1.5, 2.0), - }, chest: match (body.species, body.body_type) { - (Sardine, _) => (0.0, 5.0), + (Clownfish, _) => (0.0, 5.0), }, tail: match (body.species, body.body_type) { - (Sardine, _) => (-6.0, 0.0), + (Clownfish, _) => (-7.5, -0.5), }, fin: match (body.species, body.body_type) { - (Sardine, _) => (3.5, 6.0, -1.0), + (Clownfish, _) => (2.0, 0.5, 1.0), }, } } diff --git a/voxygen/anim/src/fish_small/run.rs b/voxygen/anim/src/fish_small/run.rs index c3fa97be8e..2af8984b6d 100644 --- a/voxygen/anim/src/fish_small/run.rs +++ b/voxygen/anim/src/fish_small/run.rs @@ -21,10 +21,7 @@ impl Animation for RunAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.chest.scale = Vec3::one() / 11.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; next.chest.orientation = Quaternion::rotation_x(0.0); diff --git a/voxygen/src/anim/src/fish_medium/swim.rs b/voxygen/src/anim/src/fish_medium/swim.rs index dc4ebf2c55..97a1dc2629 100644 --- a/voxygen/src/anim/src/fish_medium/swim.rs +++ b/voxygen/src/anim/src/fish_medium/swim.rs @@ -19,15 +19,13 @@ impl Animation for SwimAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, + (velocity, orientation, last_ori, _global_time, avg_vel): Self::Dependency, anim_time: f64, - rate: &mut f32, + _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let slower = (anim_time as f32 * 1.0 + PI).sin(); - let slow = (anim_time as f32 * 3.5 + PI).sin(); let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); let fast = (anim_time as f32 * 5.5 + PI).sin(); let fastalt = (anim_time as f32 * 5.5 + PI + 0.2).sin(); @@ -48,8 +46,6 @@ impl Animation for SwimAnimation { let abstilt = tilt.abs(); let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); - let squash = if abstilt > 0.2 { 0.35 } else { 1.0 }; //condenses the body at strong turns - next.chest_front.scale = Vec3::one() / 11.0; next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); diff --git a/voxygen/src/anim/src/fish_medium/swimidle.rs b/voxygen/src/anim/src/fish_medium/swimidle.rs index 3abd898a32..049e3abc46 100644 --- a/voxygen/src/anim/src/fish_medium/swimidle.rs +++ b/voxygen/src/anim/src/fish_medium/swimidle.rs @@ -2,7 +2,7 @@ use super::{ super::{vek::*, Animation}, FishMediumSkeleton, SkeletonAttr, }; -use std::{f32::consts::PI, ops::Mul}; +use std::f32::consts::PI; pub struct SwimIdleAnimation; @@ -19,14 +19,13 @@ impl Animation for SwimIdleAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, + (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, anim_time: f64, - rate: &mut f32, + _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let slower = (anim_time as f32 * 1.0 + PI).sin(); let slow = (anim_time as f32 * 3.5 + PI).sin(); let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); diff --git a/voxygen/src/anim/src/fish_small/swim.rs b/voxygen/src/anim/src/fish_small/swim.rs index 774dc43316..9672c471e6 100644 --- a/voxygen/src/anim/src/fish_small/swim.rs +++ b/voxygen/src/anim/src/fish_small/swim.rs @@ -2,6 +2,7 @@ use super::{ super::{vek::*, Animation}, FishSmallSkeleton, SkeletonAttr, }; +use std::f32::consts::PI; pub struct SwimAnimation; @@ -18,29 +19,45 @@ impl Animation for SwimAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, global_time, avg_vel): Self::Dependency, - _anim_time: f64, + (velocity, orientation, last_ori, _global_time, avg_vel): Self::Dependency, + anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.head.scale = Vec3::one() / 11.0; + let fast = (anim_time as f32 * 7.0 + PI).sin(); - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + 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.8) + * last_ori.determine_side(Vec2::zero(), ori).signum() + } else { + 0.0 + } * 1.3; + let abstilt = tilt.abs(); + let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); + + next.chest.scale = Vec3::one() / 11.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; - next.chest.orientation = Quaternion::rotation_x(0.0); + next.chest.orientation = Quaternion::rotation_z(fast * -0.1) + + Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.tail.orientation = Quaternion::rotation_z(fast * 0.3 + tilt * 2.0); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); + next.fin_l.orientation = Quaternion::rotation_z(fast * 0.3 - 0.3 + tilt * -0.5); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); + next.fin_r.orientation = Quaternion::rotation_z(-fast * 0.3 + 0.3 + tilt * -0.5); next } } diff --git a/voxygen/src/anim/src/fish_small/swimidle.rs b/voxygen/src/anim/src/fish_small/swimidle.rs new file mode 100644 index 0000000000..551e7e8b0c --- /dev/null +++ b/voxygen/src/anim/src/fish_small/swimidle.rs @@ -0,0 +1,46 @@ +use super::{ + super::{vek::*, Animation}, + FishSmallSkeleton, SkeletonAttr, +}; +use std::f32::consts::PI; + +pub struct SwimIdleAnimation; + +type SwimIdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + +impl Animation for SwimIdleAnimation { + type Dependency = SwimIdleAnimationDependency; + type Skeleton = FishSmallSkeleton; + + #[cfg(feature = "use-dyn-lib")] + const UPDATE_FN: &'static [u8] = b"fish_small_swimidle\0"; + + #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_swimidle")] + + fn update_skeleton_inner( + skeleton: &Self::Skeleton, + (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, + anim_time: f64, + _rate: &mut f32, + s_a: &SkeletonAttr, + ) -> Self::Skeleton { + let mut next = (*skeleton).clone(); + + let slow = (anim_time as f32 * 3.5 + PI).sin(); + + next.chest.scale = Vec3::one() / 11.0; + + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.orientation = Quaternion::rotation_x(0.0); + + next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); + next.tail.orientation = Quaternion::rotation_z(slow * 0.1); + + next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); + + next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); + next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); + next + } +} diff --git a/voxygen/src/scene/figure/load.rs b/voxygen/src/scene/figure/load.rs index 12ef0b1ea9..c4b69a1134 100644 --- a/voxygen/src/scene/figure/load.rs +++ b/voxygen/src/scene/figure/load.rs @@ -2287,7 +2287,6 @@ struct FishSmallCentralSpec(HashMap<(FSSpecies, FSBodyType), SidedFSCentralVoxSp #[derive(Deserialize)] struct SidedFSCentralVoxSpec { - head: FishSmallCentralSubSpec, chest: FishSmallCentralSubSpec, tail: FishSmallCentralSubSpec, } @@ -2317,10 +2316,6 @@ make_vox_spec!( }, |FigureKey { body, .. }, spec| { [ - Some(spec.central.asset.mesh_head( - body.species, - body.body_type, - )), Some(spec.central.asset.mesh_chest( body.species, body.body_type, @@ -2348,27 +2343,12 @@ make_vox_spec!( None, None, None, + None, ] }, ); impl FishSmallCentralSpec { - fn mesh_head(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { - let spec = match self.0.get(&(species, body_type)) { - Some(spec) => spec, - None => { - error!( - "No head specification exists for the combination of {:?} and {:?}", - species, body_type - ); - return load_mesh("not_found", Vec3::new(-5.0, -5.0, -2.5)); - }, - }; - let central = graceful_load_segment(&spec.head.central.0); - - (central, Vec3::from(spec.head.offset)) - } - fn mesh_chest(&self, species: FSSpecies, body_type: FSBodyType) -> BoneMeshes { let spec = match self.0.get(&(species, body_type)) { Some(spec) => spec, diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index cd58b7d409..3eabc4eb58 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -2605,8 +2605,16 @@ impl FigureMgr { &mut state_animation_rate, skeleton_attr, ), + // Idle Water + (_, false, true) => anim::fish_small::SwimIdleAnimation::update_skeleton( + &FishSmallSkeleton::default(), + (vel.0, ori, state.last_ori, time, state.avg_vel), + state.state_time, + &mut state_animation_rate, + skeleton_attr, + ), // Swim - (_, _, true) => anim::fish_small::SwimAnimation::update_skeleton( + (_, true, true) => anim::fish_small::SwimAnimation::update_skeleton( &FishSmallSkeleton::default(), (vel.0, ori, state.last_ori, time, state.avg_vel), state.state_time, From 87e8c2189f45a68093508d46cb86bd0d2c3efad1 Mon Sep 17 00:00:00 2001 From: Snowram Date: Sun, 29 Nov 2020 22:22:43 +0100 Subject: [PATCH 3/5] Vacations are never over --- .../voxel/npc/roshwalr/female/head.vox | Bin 0 -> 9368 bytes .../quadruped_medium_central_manifest.ron | 2 +- world/src/layer/wildlife.rs | 45 ++++++++++++++---- 3 files changed, 36 insertions(+), 11 deletions(-) create mode 100644 assets/voxygen/voxel/npc/roshwalr/female/head.vox diff --git a/assets/voxygen/voxel/npc/roshwalr/female/head.vox b/assets/voxygen/voxel/npc/roshwalr/female/head.vox new file mode 100644 index 0000000000000000000000000000000000000000..515aa5548cdb2126efc1c22c48c3a6ca6a9b4de8 GIT binary patch literal 9368 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 literal 0 HcmV?d00001 diff --git a/assets/voxygen/voxel/quadruped_medium_central_manifest.ron b/assets/voxygen/voxel/quadruped_medium_central_manifest.ron index 05426d20e2..8c7f92632c 100644 --- a/assets/voxygen/voxel/quadruped_medium_central_manifest.ron +++ b/assets/voxygen/voxel/quadruped_medium_central_manifest.ron @@ -812,7 +812,7 @@ (Roshwalr, Female): ( head: ( offset: (-13.0, 0.0, -12.0), - central: ("npc.roshwalr.male.head"), + central: ("npc.roshwalr.female.head"), ), neck: ( offset: (-7.0, -2.0, -11.5), diff --git a/world/src/layer/wildlife.rs b/world/src/layer/wildlife.rs index 54c7d3970b..a53a0e6412 100644 --- a/world/src/layer/wildlife.rs +++ b/world/src/layer/wildlife.rs @@ -1,8 +1,8 @@ use crate::{column::ColumnSample, sim::SimChunk, IndexRef, CONFIG}; use common::{ comp::{ - biped_large, bird_medium, fish_medium, quadruped_low, quadruped_medium, quadruped_small, - theropod, Alignment, + biped_large, bird_medium, fish_medium, fish_small, quadruped_low, quadruped_medium, + quadruped_small, theropod, Alignment, }, generation::{ChunkSupplement, EntityInfo}, terrain::Block, @@ -50,10 +50,10 @@ pub fn apply_wildlife_supplement<'a, R: Rng>( 1 => { theropod::Body::random_with(rng, &theropod::Species::Snowraptor).into() }, - _ => quadruped_medium::Body::random_with( - rng, - &quadruped_medium::Species::Roshwalr, - ) + _ => quadruped_medium::Body { + species: quadruped_medium::Species::Roshwalr, + body_type: quadruped_medium::BodyType::Male, + } .into(), }) .with_alignment(Alignment::Enemy) @@ -697,7 +697,7 @@ pub fn apply_wildlife_supplement<'a, R: Rng>( * 0.2 }, }, - // Desert river solitary wild + // Desert river solitary enemy Entry { make_entity: |pos, rng| { EntityInfo::at(pos) @@ -718,6 +718,28 @@ pub fn apply_wildlife_supplement<'a, R: Rng>( } }, }, + // Desert secret solitary enemy + Entry { + make_entity: |pos, _rng| { + EntityInfo::at(pos) + .with_body( + quadruped_medium::Body { + species: quadruped_medium::Species::Roshwalr, + body_type: quadruped_medium::BodyType::Female, + } + .into(), + ) + .with_alignment(Alignment::Enemy) + }, + group_size: 1..3, + is_underwater: false, + get_density: |c, _col| { + close(c.temp, CONFIG.desert_temp + 0.2, 0.3) + * close(c.humidity, CONFIG.desert_hum, 0.5) + * BASE_DENSITY + * 0.01 + }, + }, // Desert solitary wild Entry { make_entity: |pos, rng| { @@ -765,9 +787,12 @@ pub fn apply_wildlife_supplement<'a, R: Rng>( Entry { make_entity: |pos, rng| { EntityInfo::at(pos) - .with_body( - fish_medium::Body::random_with(rng, &fish_medium::Species::Marlin).into(), - ) + .with_body(match rng.gen_range(0, 2) { + 0 => fish_medium::Body::random_with(rng, &fish_medium::Species::Marlin) + .into(), + _ => fish_small::Body::random_with(rng, &fish_small::Species::Clownfish) + .into(), + }) .with_alignment(Alignment::Wild) }, group_size: 3..5, From 22635559f0bd94a050f9b1657763694b36f5cc3f Mon Sep 17 00:00:00 2001 From: Snowram Date: Sat, 5 Dec 2020 14:44:43 +0100 Subject: [PATCH 4/5] Adds accumulated velocity for animation --- .../{src => }/anim/src/fish_medium/swim.rs | 27 +++++++++------ .../anim/src/fish_medium/swimidle.rs | 0 voxygen/anim/src/fish_small/idle.rs | 4 +-- voxygen/anim/src/fish_small/jump.rs | 4 +-- voxygen/anim/src/fish_small/run.rs | 4 +-- voxygen/{src => }/anim/src/fish_small/swim.rs | 21 ++++++------ .../{src => }/anim/src/fish_small/swimidle.rs | 4 +-- voxygen/src/scene/figure/mod.rs | 34 +++++++++++++++++-- 8 files changed, 67 insertions(+), 31 deletions(-) rename voxygen/{src => }/anim/src/fish_medium/swim.rs (70%) rename voxygen/{src => }/anim/src/fish_medium/swimidle.rs (100%) rename voxygen/{src => }/anim/src/fish_small/swim.rs (70%) rename voxygen/{src => }/anim/src/fish_small/swimidle.rs (95%) diff --git a/voxygen/src/anim/src/fish_medium/swim.rs b/voxygen/anim/src/fish_medium/swim.rs similarity index 70% rename from voxygen/src/anim/src/fish_medium/swim.rs rename to voxygen/anim/src/fish_medium/swim.rs index 97a1dc2629..33cdc485d4 100644 --- a/voxygen/src/anim/src/fish_medium/swim.rs +++ b/voxygen/anim/src/fish_medium/swim.rs @@ -6,7 +6,7 @@ use std::f32::consts::PI; pub struct SwimAnimation; -type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); +type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3, f32); impl Animation for SwimAnimation { type Dependency = SwimAnimationDependency; @@ -19,16 +19,16 @@ impl Animation for SwimAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, _global_time, avg_vel): Self::Dependency, + (velocity, orientation, last_ori, _global_time, avg_vel, acc_vel): Self::Dependency, anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); - let fast = (anim_time as f32 * 5.5 + PI).sin(); - let fastalt = (anim_time as f32 * 5.5 + PI + 0.2).sin(); + let slowalt = (anim_time as f32 * 2.5 + PI + 0.2).sin(); + let fast = (acc_vel * 4.0 + PI).sin(); + let fastalt = (acc_vel * 4.0 + PI + 0.2).sin(); let ori: Vec2 = Vec2::from(orientation); let last_ori = Vec2::from(last_ori); @@ -46,6 +46,8 @@ impl Animation for SwimAnimation { let abstilt = tilt.abs(); let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); + println!("{}", acc_vel); + next.chest_front.scale = Vec3::one() / 11.0; next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); @@ -56,19 +58,24 @@ impl Animation for SwimAnimation { next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; next.chest_front.orientation = - Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt); + Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt) + * Quaternion::rotation_z(fast * velocity.magnitude() * -0.02); next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); - next.chest_back.orientation = Quaternion::rotation_z(fastalt * 0.3 + tilt * 2.0); + next.chest_back.orientation = + Quaternion::rotation_z(fastalt * velocity.magnitude() * 0.1 + tilt * 2.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(fast * 0.3 + tilt * 2.0); + next.tail.orientation = + Quaternion::rotation_z(fast * velocity.magnitude() * 0.1 + tilt * 2.0); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_z(fast * 0.3 - 0.1 + tilt * -0.5); + next.fin_l.orientation = + Quaternion::rotation_z(fast * velocity.magnitude() * 0.1 - 0.1 + tilt * -0.5); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_z(-fast * 0.3 + 0.1 + tilt * -0.5); + next.fin_r.orientation = + Quaternion::rotation_z(fast * velocity.magnitude() * -0.1 + 0.1 + tilt * -0.5); next } } diff --git a/voxygen/src/anim/src/fish_medium/swimidle.rs b/voxygen/anim/src/fish_medium/swimidle.rs similarity index 100% rename from voxygen/src/anim/src/fish_medium/swimidle.rs rename to voxygen/anim/src/fish_medium/swimidle.rs diff --git a/voxygen/anim/src/fish_small/idle.rs b/voxygen/anim/src/fish_small/idle.rs index 3622cf8b67..60e6c8b9a9 100644 --- a/voxygen/anim/src/fish_small/idle.rs +++ b/voxygen/anim/src/fish_small/idle.rs @@ -21,9 +21,9 @@ impl Animation for IdleAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.chest.scale = Vec3::one() / 11.0; + next.chest.scale = Vec3::one() / 13.0; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; next.chest.orientation = Quaternion::rotation_x(0.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); diff --git a/voxygen/anim/src/fish_small/jump.rs b/voxygen/anim/src/fish_small/jump.rs index 5b9511184d..b4c6bd011b 100644 --- a/voxygen/anim/src/fish_small/jump.rs +++ b/voxygen/anim/src/fish_small/jump.rs @@ -21,9 +21,9 @@ impl Animation for JumpAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.chest.scale = Vec3::one() / 11.0; + next.chest.scale = Vec3::one() / 13.0; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; next.chest.orientation = Quaternion::rotation_x(0.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); diff --git a/voxygen/anim/src/fish_small/run.rs b/voxygen/anim/src/fish_small/run.rs index 2af8984b6d..b3ff4ba63b 100644 --- a/voxygen/anim/src/fish_small/run.rs +++ b/voxygen/anim/src/fish_small/run.rs @@ -21,9 +21,9 @@ impl Animation for RunAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - next.chest.scale = Vec3::one() / 11.0; + next.chest.scale = Vec3::one() / 13.0; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; next.chest.orientation = Quaternion::rotation_x(0.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); diff --git a/voxygen/src/anim/src/fish_small/swim.rs b/voxygen/anim/src/fish_small/swim.rs similarity index 70% rename from voxygen/src/anim/src/fish_small/swim.rs rename to voxygen/anim/src/fish_small/swim.rs index 9672c471e6..b1ff97b3f1 100644 --- a/voxygen/src/anim/src/fish_small/swim.rs +++ b/voxygen/anim/src/fish_small/swim.rs @@ -6,7 +6,7 @@ use std::f32::consts::PI; pub struct SwimAnimation; -type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); +type SwimAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3, f32); impl Animation for SwimAnimation { type Dependency = SwimAnimationDependency; @@ -19,14 +19,14 @@ impl Animation for SwimAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, - (velocity, orientation, last_ori, _global_time, avg_vel): Self::Dependency, - anim_time: f64, + (velocity, orientation, last_ori, _global_time, avg_vel, acc_vel): Self::Dependency, + _anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let fast = (anim_time as f32 * 7.0 + PI).sin(); + let fast = (acc_vel * 5.0 + PI).sin(); let ori: Vec2 = Vec2::from(orientation); let last_ori = Vec2::from(last_ori); @@ -44,20 +44,19 @@ impl Animation for SwimAnimation { let abstilt = tilt.abs(); let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); - next.chest.scale = Vec3::one() / 11.0; + next.chest.scale = Vec3::one() / 13.0; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; - next.chest.orientation = Quaternion::rotation_z(fast * -0.1) - + Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; + next.chest.orientation = Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt) * Quaternion::rotation_z(fast * -0.1); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(fast * 0.3 + tilt * 2.0); + next.tail.orientation = Quaternion::rotation_z(fast * -1.0 * velocity.magnitude() * 0.1 + tilt * 2.0); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_z(fast * 0.3 - 0.3 + tilt * -0.5); + next.fin_l.orientation = Quaternion::rotation_z(fast * 0.6 * velocity.magnitude() * 0.1 - 0.3 + tilt * -0.5); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_z(-fast * 0.3 + 0.3 + tilt * -0.5); + next.fin_r.orientation = Quaternion::rotation_z(fast * -0.6 * velocity.magnitude() * 0.1 + 0.3 + tilt * -0.5); next } } diff --git a/voxygen/src/anim/src/fish_small/swimidle.rs b/voxygen/anim/src/fish_small/swimidle.rs similarity index 95% rename from voxygen/src/anim/src/fish_small/swimidle.rs rename to voxygen/anim/src/fish_small/swimidle.rs index 551e7e8b0c..19c475a8df 100644 --- a/voxygen/src/anim/src/fish_small/swimidle.rs +++ b/voxygen/anim/src/fish_small/swimidle.rs @@ -28,9 +28,9 @@ impl Animation for SwimIdleAnimation { let slow = (anim_time as f32 * 3.5 + PI).sin(); - next.chest.scale = Vec3::one() / 11.0; + next.chest.scale = Vec3::one() / 13.0; - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 11.0; + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; next.chest.orientation = Quaternion::rotation_x(0.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index 3eabc4eb58..d22b6a6652 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -2170,6 +2170,13 @@ impl FigureMgr { _ => continue, }; + // Bad, can potentially overflow + if vel.0.magnitude_squared() != 0.0 { + state.acc_vel += vel.0.magnitude() * dt; + } else { + state.acc_vel = 0.0; + } + if !character.same_variant(&last_character.0) { state.state_time = 0.0; } @@ -2214,7 +2221,14 @@ impl FigureMgr { // Swim (_, true, true) => anim::fish_medium::SwimAnimation::update_skeleton( &FishMediumSkeleton::default(), - (vel.0, ori, state.last_ori, time, state.avg_vel), + ( + vel.0, + ori, + state.last_ori, + time, + state.avg_vel, + state.acc_vel, + ), state.state_time, &mut state_animation_rate, skeleton_attr, @@ -2572,6 +2586,13 @@ impl FigureMgr { _ => continue, }; + // Bad, can potentially overflow + if vel.0.magnitude_squared() != 0.0 { + state.acc_vel += vel.0.magnitude() * dt; + } else { + state.acc_vel = 0.0; + } + if !character.same_variant(&last_character.0) { state.state_time = 0.0; } @@ -2616,7 +2637,14 @@ impl FigureMgr { // Swim (_, true, true) => anim::fish_small::SwimAnimation::update_skeleton( &FishSmallSkeleton::default(), - (vel.0, ori, state.last_ori, time, state.avg_vel), + ( + vel.0, + ori, + state.last_ori, + time, + state.avg_vel, + state.acc_vel, + ), state.state_time, &mut state_animation_rate, skeleton_attr, @@ -3775,6 +3803,7 @@ pub struct FigureStateMeta { avg_vel: anim::vek::Vec3, last_light: f32, last_glow: f32, + acc_vel: f32, } impl FigureStateMeta { @@ -3821,6 +3850,7 @@ impl FigureState { avg_vel: anim::vek::Vec3::zero(), last_light: 1.0, last_glow: 0.0, + acc_vel: 0.0, }, skeleton, } From 856ce6cb1d1aa2fc77f7b645532591b7f2b5fb30 Mon Sep 17 00:00:00 2001 From: Snowram Date: Sun, 6 Dec 2020 01:02:56 +0100 Subject: [PATCH 5/5] Addressed comments --- common/src/comp/body.rs | 4 +- voxygen/anim/src/fish_medium/idle.rs | 15 +++-- voxygen/anim/src/fish_medium/jump.rs | 48 -------------- voxygen/anim/src/fish_medium/mod.rs | 18 ++++-- voxygen/anim/src/fish_medium/run.rs | 48 -------------- voxygen/anim/src/fish_medium/swim.rs | 31 ++++----- voxygen/anim/src/fish_medium/swimidle.rs | 56 ---------------- voxygen/anim/src/fish_small/idle.rs | 26 +++++--- voxygen/anim/src/fish_small/jump.rs | 39 ------------ voxygen/anim/src/fish_small/mod.rs | 18 ++++-- voxygen/anim/src/fish_small/run.rs | 39 ------------ voxygen/anim/src/fish_small/swim.rs | 14 ++-- voxygen/anim/src/fish_small/swimidle.rs | 46 -------------- voxygen/src/scene/figure/mod.rs | 81 ++++-------------------- 14 files changed, 82 insertions(+), 401 deletions(-) delete mode 100644 voxygen/anim/src/fish_medium/jump.rs delete mode 100644 voxygen/anim/src/fish_medium/run.rs delete mode 100644 voxygen/anim/src/fish_medium/swimidle.rs delete mode 100644 voxygen/anim/src/fish_small/jump.rs delete mode 100644 voxygen/anim/src/fish_small/run.rs delete mode 100644 voxygen/anim/src/fish_small/swimidle.rs diff --git a/common/src/comp/body.rs b/common/src/comp/body.rs index b528698b2d..8d49be6a83 100644 --- a/common/src/comp/body.rs +++ b/common/src/comp/body.rs @@ -87,8 +87,8 @@ impl core::ops::Index for AllBodies &self.quadruped_small.body, NpcKind::Wolf => &self.quadruped_medium.body, NpcKind::Duck => &self.bird_medium.body, - NpcKind::Clownfish => &self.fish_medium.body, - NpcKind::Marlin => &self.fish_small.body, + NpcKind::Marlin => &self.fish_medium.body, + NpcKind::Clownfish => &self.fish_small.body, NpcKind::Ogre => &self.biped_large.body, NpcKind::StoneGolem => &self.golem.body, NpcKind::Archaeos => &self.theropod.body, diff --git a/voxygen/anim/src/fish_medium/idle.rs b/voxygen/anim/src/fish_medium/idle.rs index 26c57a6d54..1086a8e285 100644 --- a/voxygen/anim/src/fish_medium/idle.rs +++ b/voxygen/anim/src/fish_medium/idle.rs @@ -1,21 +1,25 @@ -use super::{super::Animation, FishMediumSkeleton, SkeletonAttr}; -//use std::{f32::consts::PI, ops::Mul}; -use super::super::vek::*; +use super::{ + super::{vek::*, Animation}, + FishMediumSkeleton, SkeletonAttr, +}; use std::f32::consts::PI; pub struct IdleAnimation; +type IdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + impl Animation for IdleAnimation { - type Dependency = f64; + type Dependency = IdleAnimationDependency; type Skeleton = FishMediumSkeleton; #[cfg(feature = "use-dyn-lib")] const UPDATE_FN: &'static [u8] = b"fish_medium_idle\0"; #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_idle")] + fn update_skeleton_inner( skeleton: &Self::Skeleton, - _global_time: Self::Dependency, + (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, @@ -31,7 +35,6 @@ impl Animation for IdleAnimation { next.head.orientation = Quaternion::rotation_z(slowalt * -0.1); next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); - next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; next.chest_front.orientation = Quaternion::rotation_x(0.0); diff --git a/voxygen/anim/src/fish_medium/jump.rs b/voxygen/anim/src/fish_medium/jump.rs deleted file mode 100644 index c7b4162e2d..0000000000 --- a/voxygen/anim/src/fish_medium/jump.rs +++ /dev/null @@ -1,48 +0,0 @@ -use super::{super::Animation, FishMediumSkeleton, SkeletonAttr}; -//use std::f32::consts::PI; -use super::super::vek::*; - -pub struct JumpAnimation; - -impl Animation for JumpAnimation { - type Dependency = (f32, f64); - type Skeleton = FishMediumSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_medium_jump\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_jump")] - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - _global_time: Self::Dependency, - _anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - next.chest_front.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); - next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; - next.chest_front.orientation = Quaternion::rotation_x(0.0); - - next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); - next.chest_back.orientation = Quaternion::rotation_z(0.0); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); - next - } -} diff --git a/voxygen/anim/src/fish_medium/mod.rs b/voxygen/anim/src/fish_medium/mod.rs index 4448b4edad..2fd5d45f45 100644 --- a/voxygen/anim/src/fish_medium/mod.rs +++ b/voxygen/anim/src/fish_medium/mod.rs @@ -1,14 +1,8 @@ pub mod idle; -pub mod jump; -pub mod run; pub mod swim; -pub mod swimidle; // Reexports -pub use self::{ - idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation, - swimidle::SwimIdleAnimation, -}; +pub use self::{idle::IdleAnimation, swim::SwimAnimation}; use super::{make_bone, vek::*, FigureBoneData, Skeleton}; use common::comp::{self}; @@ -64,6 +58,8 @@ pub struct SkeletonAttr { chest_back: (f32, f32), tail: (f32, f32), fin: (f32, f32, f32), + tempo: f32, + amplitude: f32, } impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { @@ -86,6 +82,8 @@ impl Default for SkeletonAttr { chest_back: (0.0, 0.0), tail: (0.0, 0.0), fin: (0.0, 0.0, 0.0), + tempo: 0.0, + amplitude: 0.0, } } } @@ -112,6 +110,12 @@ impl<'a> From<&'a Body> for SkeletonAttr { fin: match (body.species, body.body_type) { (Marlin, _) => (2.5, 1.0, 3.5), }, + tempo: match (body.species, body.body_type) { + (Marlin, _) => 4.0, + }, + amplitude: match (body.species, body.body_type) { + (Marlin, _) => 4.0, + }, } } } diff --git a/voxygen/anim/src/fish_medium/run.rs b/voxygen/anim/src/fish_medium/run.rs deleted file mode 100644 index 81ed079734..0000000000 --- a/voxygen/anim/src/fish_medium/run.rs +++ /dev/null @@ -1,48 +0,0 @@ -use super::{super::Animation, FishMediumSkeleton, SkeletonAttr}; -//use std::f32::consts::PI; -use super::super::vek::*; - -pub struct RunAnimation; - -impl Animation for RunAnimation { - type Dependency = (f32, f64); - type Skeleton = FishMediumSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_medium_run\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_run")] - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - _global_time: Self::Dependency, - _anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - next.chest_front.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); - next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; - next.chest_front.orientation = Quaternion::rotation_x(0.0); - - next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); - next.chest_back.orientation = Quaternion::rotation_z(0.0); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); - next - } -} diff --git a/voxygen/anim/src/fish_medium/swim.rs b/voxygen/anim/src/fish_medium/swim.rs index 33cdc485d4..791bc5c26c 100644 --- a/voxygen/anim/src/fish_medium/swim.rs +++ b/voxygen/anim/src/fish_medium/swim.rs @@ -20,15 +20,15 @@ impl Animation for SwimAnimation { fn update_skeleton_inner( skeleton: &Self::Skeleton, (velocity, orientation, last_ori, _global_time, avg_vel, acc_vel): Self::Dependency, - anim_time: f64, + _anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let slowalt = (anim_time as f32 * 2.5 + PI + 0.2).sin(); - let fast = (acc_vel * 4.0 + PI).sin(); - let fastalt = (acc_vel * 4.0 + PI + 0.2).sin(); + let slowalt = (acc_vel as f32 * s_a.tempo / 1.5 + PI + 0.2).sin(); + let fast = (acc_vel * s_a.tempo + PI).sin(); + let fastalt = (acc_vel * s_a.tempo + PI + 0.2).sin(); let ori: Vec2 = Vec2::from(orientation); let last_ori = Vec2::from(last_ori); @@ -43,10 +43,9 @@ impl Animation for SwimAnimation { } else { 0.0 } * 1.3; - let abstilt = tilt.abs(); let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); - - println!("{}", acc_vel); + let vel = (velocity.magnitude()).min(s_a.amplitude); + let slowvel = vel * 0.1; next.chest_front.scale = Vec3::one() / 11.0; @@ -54,28 +53,22 @@ impl Animation for SwimAnimation { next.head.orientation = Quaternion::rotation_z(slowalt * -0.1 + tilt * -2.0); next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); - next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; - next.chest_front.orientation = - Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt) - * Quaternion::rotation_z(fast * velocity.magnitude() * -0.02); + next.chest_front.orientation = Quaternion::rotation_x(velocity.z.abs() * -0.005 + x_tilt) + * Quaternion::rotation_z(fast * vel * -0.02); next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); - next.chest_back.orientation = - Quaternion::rotation_z(fastalt * velocity.magnitude() * 0.1 + tilt * 2.0); + next.chest_back.orientation = Quaternion::rotation_z(fastalt * slowvel + tilt * 2.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = - Quaternion::rotation_z(fast * velocity.magnitude() * 0.1 + tilt * 2.0); + next.tail.orientation = Quaternion::rotation_z(fast * slowvel + tilt * 2.0); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = - Quaternion::rotation_z(fast * velocity.magnitude() * 0.1 - 0.1 + tilt * -0.5); + next.fin_l.orientation = Quaternion::rotation_z(fast * slowvel - 0.1 + tilt * -0.5); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = - Quaternion::rotation_z(fast * velocity.magnitude() * -0.1 + 0.1 + tilt * -0.5); + next.fin_r.orientation = Quaternion::rotation_z(fast * -slowvel + 0.1 + tilt * -0.5); next } } diff --git a/voxygen/anim/src/fish_medium/swimidle.rs b/voxygen/anim/src/fish_medium/swimidle.rs deleted file mode 100644 index 049e3abc46..0000000000 --- a/voxygen/anim/src/fish_medium/swimidle.rs +++ /dev/null @@ -1,56 +0,0 @@ -use super::{ - super::{vek::*, Animation}, - FishMediumSkeleton, SkeletonAttr, -}; -use std::f32::consts::PI; - -pub struct SwimIdleAnimation; - -type SwimIdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); - -impl Animation for SwimIdleAnimation { - type Dependency = SwimIdleAnimationDependency; - type Skeleton = FishMediumSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_medium_swimidle\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_medium_swimidle")] - - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, - anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - let slow = (anim_time as f32 * 3.5 + PI).sin(); - let slowalt = (anim_time as f32 * 3.5 + PI + 0.2).sin(); - - next.chest_front.scale = Vec3::one() / 11.0; - - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(slowalt * -0.1); - - next.jaw.position = Vec3::new(0.0, s_a.jaw.0, s_a.jaw.1); - next.jaw.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.chest_front.position = Vec3::new(0.0, s_a.chest_front.0, s_a.chest_front.1) / 11.0; - next.chest_front.orientation = Quaternion::rotation_x(0.0); - - next.chest_back.position = Vec3::new(0.0, s_a.chest_back.0, s_a.chest_back.1); - next.chest_back.orientation = Quaternion::rotation_z(slowalt * 0.1); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(slow * 0.1); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); - next - } -} diff --git a/voxygen/anim/src/fish_small/idle.rs b/voxygen/anim/src/fish_small/idle.rs index 60e6c8b9a9..c027c68165 100644 --- a/voxygen/anim/src/fish_small/idle.rs +++ b/voxygen/anim/src/fish_small/idle.rs @@ -1,39 +1,45 @@ -use super::{super::Animation, FishSmallSkeleton, SkeletonAttr}; -//use std::{f32::consts::PI, ops::Mul}; -use super::super::vek::*; +use super::{ + super::{vek::*, Animation}, + FishSmallSkeleton, SkeletonAttr, +}; +use std::f32::consts::PI; pub struct IdleAnimation; +type IdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); + impl Animation for IdleAnimation { - type Dependency = f64; + type Dependency = IdleAnimationDependency; type Skeleton = FishSmallSkeleton; #[cfg(feature = "use-dyn-lib")] const UPDATE_FN: &'static [u8] = b"fish_small_idle\0"; #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_idle")] + fn update_skeleton_inner( skeleton: &Self::Skeleton, - _global_time: Self::Dependency, - _anim_time: f64, + (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, + anim_time: f64, _rate: &mut f32, s_a: &SkeletonAttr, ) -> Self::Skeleton { let mut next = (*skeleton).clone(); + let slow = (anim_time as f32 * 3.5 + PI).sin(); + next.chest.scale = Vec3::one() / 13.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; - next.chest.orientation = Quaternion::rotation_x(0.0); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); + next.tail.orientation = Quaternion::rotation_z(slow * 0.1); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); + next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); + next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); next } } diff --git a/voxygen/anim/src/fish_small/jump.rs b/voxygen/anim/src/fish_small/jump.rs deleted file mode 100644 index b4c6bd011b..0000000000 --- a/voxygen/anim/src/fish_small/jump.rs +++ /dev/null @@ -1,39 +0,0 @@ -use super::{super::Animation, FishSmallSkeleton, SkeletonAttr}; -//use std::f32::consts::PI; -use super::super::vek::*; - -pub struct JumpAnimation; - -impl Animation for JumpAnimation { - type Dependency = (f32, f64); - type Skeleton = FishSmallSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_small_jump\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_jump")] - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - _global_time: Self::Dependency, - _anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - next.chest.scale = Vec3::one() / 13.0; - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; - next.chest.orientation = Quaternion::rotation_x(0.0); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); - next - } -} diff --git a/voxygen/anim/src/fish_small/mod.rs b/voxygen/anim/src/fish_small/mod.rs index dafa89e9f0..ccd2d5be42 100644 --- a/voxygen/anim/src/fish_small/mod.rs +++ b/voxygen/anim/src/fish_small/mod.rs @@ -1,14 +1,8 @@ pub mod idle; -pub mod jump; -pub mod run; pub mod swim; -pub mod swimidle; // Reexports -pub use self::{ - idle::IdleAnimation, jump::JumpAnimation, run::RunAnimation, swim::SwimAnimation, - swimidle::SwimIdleAnimation, -}; +pub use self::{idle::IdleAnimation, swim::SwimAnimation}; use super::{make_bone, vek::*, FigureBoneData, Skeleton}; use common::comp::{self}; @@ -53,6 +47,8 @@ pub struct SkeletonAttr { chest: (f32, f32), tail: (f32, f32), fin: (f32, f32, f32), + tempo: f32, + amplitude: f32, } impl<'a> std::convert::TryFrom<&'a comp::Body> for SkeletonAttr { @@ -72,6 +68,8 @@ impl Default for SkeletonAttr { chest: (0.0, 0.0), tail: (0.0, 0.0), fin: (0.0, 0.0, 0.0), + tempo: 0.0, + amplitude: 0.0, } } } @@ -89,6 +87,12 @@ impl<'a> From<&'a Body> for SkeletonAttr { fin: match (body.species, body.body_type) { (Clownfish, _) => (2.0, 0.5, 1.0), }, + tempo: match (body.species, body.body_type) { + (Clownfish, _) => 5.0, + }, + amplitude: match (body.species, body.body_type) { + (Clownfish, _) => 4.0, + }, } } } diff --git a/voxygen/anim/src/fish_small/run.rs b/voxygen/anim/src/fish_small/run.rs deleted file mode 100644 index b3ff4ba63b..0000000000 --- a/voxygen/anim/src/fish_small/run.rs +++ /dev/null @@ -1,39 +0,0 @@ -use super::{super::Animation, FishSmallSkeleton, SkeletonAttr}; -//use std::{f32::consts::PI, ops::Mul}; -use super::super::vek::*; - -pub struct RunAnimation; - -impl Animation for RunAnimation { - type Dependency = (f32, f64); - type Skeleton = FishSmallSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_small_run\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_run")] - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - (_velocity, _global_time): Self::Dependency, - _anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - next.chest.scale = Vec3::one() / 13.0; - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; - next.chest.orientation = Quaternion::rotation_x(0.0); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(0.0) * Quaternion::rotation_x(0.0); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_y(0.0); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_y(0.0); - next - } -} diff --git a/voxygen/anim/src/fish_small/swim.rs b/voxygen/anim/src/fish_small/swim.rs index b1ff97b3f1..fcc378d67a 100644 --- a/voxygen/anim/src/fish_small/swim.rs +++ b/voxygen/anim/src/fish_small/swim.rs @@ -26,7 +26,7 @@ impl Animation for SwimAnimation { ) -> Self::Skeleton { let mut next = (*skeleton).clone(); - let fast = (acc_vel * 5.0 + PI).sin(); + let fast = (acc_vel * s_a.tempo + PI).sin(); let ori: Vec2 = Vec2::from(orientation); let last_ori = Vec2::from(last_ori); @@ -41,22 +41,24 @@ impl Animation for SwimAnimation { } else { 0.0 } * 1.3; - let abstilt = tilt.abs(); let x_tilt = avg_vel.z.atan2(avg_vel.xy().magnitude()); + let vel = (velocity.magnitude()).min(s_a.amplitude); + let slowvel = vel * 0.1; next.chest.scale = Vec3::one() / 13.0; next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; - next.chest.orientation = Quaternion::rotation_x(velocity.z.abs() * -0.005 + abstilt * 1.0 + x_tilt) * Quaternion::rotation_z(fast * -0.1); + next.chest.orientation = Quaternion::rotation_x(velocity.z.abs() * -0.005 + x_tilt) + * Quaternion::rotation_z(fast * -0.1); next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(fast * -1.0 * velocity.magnitude() * 0.1 + tilt * 2.0); + next.tail.orientation = Quaternion::rotation_z(fast * -1.0 * slowvel + tilt * 2.0); next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_z(fast * 0.6 * velocity.magnitude() * 0.1 - 0.3 + tilt * -0.5); + next.fin_l.orientation = Quaternion::rotation_z(fast * 0.6 * slowvel - 0.3 + tilt * -0.5); next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_z(fast * -0.6 * velocity.magnitude() * 0.1 + 0.3 + tilt * -0.5); + next.fin_r.orientation = Quaternion::rotation_z(fast * -0.6 * slowvel + 0.3 + tilt * -0.5); next } } diff --git a/voxygen/anim/src/fish_small/swimidle.rs b/voxygen/anim/src/fish_small/swimidle.rs deleted file mode 100644 index 19c475a8df..0000000000 --- a/voxygen/anim/src/fish_small/swimidle.rs +++ /dev/null @@ -1,46 +0,0 @@ -use super::{ - super::{vek::*, Animation}, - FishSmallSkeleton, SkeletonAttr, -}; -use std::f32::consts::PI; - -pub struct SwimIdleAnimation; - -type SwimIdleAnimationDependency = (Vec3, Vec3, Vec3, f64, Vec3); - -impl Animation for SwimIdleAnimation { - type Dependency = SwimIdleAnimationDependency; - type Skeleton = FishSmallSkeleton; - - #[cfg(feature = "use-dyn-lib")] - const UPDATE_FN: &'static [u8] = b"fish_small_swimidle\0"; - - #[cfg_attr(feature = "be-dyn-lib", export_name = "fish_small_swimidle")] - - fn update_skeleton_inner( - skeleton: &Self::Skeleton, - (_velocity, _orientation, _last_ori, _global_time, _avg_vel): Self::Dependency, - anim_time: f64, - _rate: &mut f32, - s_a: &SkeletonAttr, - ) -> Self::Skeleton { - let mut next = (*skeleton).clone(); - - let slow = (anim_time as f32 * 3.5 + PI).sin(); - - next.chest.scale = Vec3::one() / 13.0; - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1) / 13.0; - next.chest.orientation = Quaternion::rotation_x(0.0); - - next.tail.position = Vec3::new(0.0, s_a.tail.0, s_a.tail.1); - next.tail.orientation = Quaternion::rotation_z(slow * 0.1); - - next.fin_l.position = Vec3::new(-s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_l.orientation = Quaternion::rotation_z(slow * 0.1 - 0.1); - - next.fin_r.position = Vec3::new(s_a.fin.0, s_a.fin.1, s_a.fin.2); - next.fin_r.orientation = Quaternion::rotation_z(-slow * 0.1 + 0.1); - next - } -} diff --git a/voxygen/src/scene/figure/mod.rs b/voxygen/src/scene/figure/mod.rs index d22b6a6652..f8083bd871 100644 --- a/voxygen/src/scene/figure/mod.rs +++ b/voxygen/src/scene/figure/mod.rs @@ -2170,13 +2170,6 @@ impl FigureMgr { _ => continue, }; - // Bad, can potentially overflow - if vel.0.magnitude_squared() != 0.0 { - state.acc_vel += vel.0.magnitude() * dt; - } else { - state.acc_vel = 0.0; - } - if !character.same_variant(&last_character.0) { state.state_time = 0.0; } @@ -2186,32 +2179,8 @@ impl FigureMgr { vel.0.magnitude_squared() > MOVING_THRESHOLD_SQR, // Moving physics.in_liquid.is_some(), // In water ) { - // Standing - (true, false, false) => anim::fish_medium::IdleAnimation::update_skeleton( - &FishMediumSkeleton::default(), - time, - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // Running - (true, true, false) => anim::fish_medium::RunAnimation::update_skeleton( - &FishMediumSkeleton::default(), - (vel.0.magnitude(), time), - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // In air - (false, _, false) => anim::fish_medium::JumpAnimation::update_skeleton( - &FishMediumSkeleton::default(), - (vel.0.magnitude(), time), - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // Idle Water - (_, false, true) => anim::fish_medium::SwimIdleAnimation::update_skeleton( + // Idle + (_, false, _) => anim::fish_medium::IdleAnimation::update_skeleton( &FishMediumSkeleton::default(), (vel.0, ori, state.last_ori, time, state.avg_vel), state.state_time, @@ -2219,7 +2188,7 @@ impl FigureMgr { skeleton_attr, ), // Swim - (_, true, true) => anim::fish_medium::SwimAnimation::update_skeleton( + (_, true, _) => anim::fish_medium::SwimAnimation::update_skeleton( &FishMediumSkeleton::default(), ( vel.0, @@ -2586,13 +2555,6 @@ impl FigureMgr { _ => continue, }; - // Bad, can potentially overflow - if vel.0.magnitude_squared() != 0.0 { - state.acc_vel += vel.0.magnitude() * dt; - } else { - state.acc_vel = 0.0; - } - if !character.same_variant(&last_character.0) { state.state_time = 0.0; } @@ -2602,32 +2564,8 @@ impl FigureMgr { vel.0.magnitude_squared() > MOVING_THRESHOLD_SQR, // Moving physics.in_liquid.is_some(), // In water ) { - // Standing - (true, false, false) => anim::fish_small::IdleAnimation::update_skeleton( - &FishSmallSkeleton::default(), - time, - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // Running - (true, true, false) => anim::fish_small::RunAnimation::update_skeleton( - &FishSmallSkeleton::default(), - (vel.0.magnitude(), time), - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // In air - (false, _, false) => anim::fish_small::JumpAnimation::update_skeleton( - &FishSmallSkeleton::default(), - (vel.0.magnitude(), time), - state.state_time, - &mut state_animation_rate, - skeleton_attr, - ), - // Idle Water - (_, false, true) => anim::fish_small::SwimIdleAnimation::update_skeleton( + // Idle + (_, false, _) => anim::fish_small::IdleAnimation::update_skeleton( &FishSmallSkeleton::default(), (vel.0, ori, state.last_ori, time, state.avg_vel), state.state_time, @@ -2635,7 +2573,7 @@ impl FigureMgr { skeleton_attr, ), // Swim - (_, true, true) => anim::fish_small::SwimAnimation::update_skeleton( + (_, true, _) => anim::fish_small::SwimAnimation::update_skeleton( &FishSmallSkeleton::default(), ( vel.0, @@ -3979,6 +3917,13 @@ impl FigureState { self.avg_vel = (1.0 - smoothing) * self.avg_vel + smoothing * (pos - last_pos) / dt; } self.last_pos = Some(pos); + + // Can potentially overflow + if self.avg_vel.magnitude_squared() != 0.0 { + self.acc_vel += self.avg_vel.magnitude() * dt; + } else { + self.acc_vel = 0.0; + } } pub fn locals(&self) -> &Consts { &self.locals }