From 021f7478f53d9132c485840279862f82604f31dd Mon Sep 17 00:00:00 2001 From: jshipsey Date: Sat, 24 Oct 2020 14:54:36 -0400 Subject: [PATCH] setup for staff, more anim conversions --- assets/voxygen/item_image_manifest.ron | 14 +-- .../voxel/weapon/sceptre/ore-nature.vox | Bin 1680 -> 1680 bytes .../voxel/weapon/sceptre/wood-nature.vox | Bin 1448 -> 1448 bytes .../voxel/weapon/sceptre/wood-simple.vox | Bin 1376 -> 1376 bytes .../voxel/weapon/staff/firestaff_amethyst.vox | Bin 27535 -> 1380 bytes .../voxel/weapon/staff/firestaff_bone.vox | Bin 27451 -> 1296 bytes .../voxel/weapon/staff/firestaff_cultist.vox | Bin 1464 -> 1464 bytes .../voxel/weapon/staff/firestaff_ogre.vox | Bin 2040 -> 2040 bytes .../voxel/weapon/staff/firestaff_saurok.vox | Bin 1508 -> 1508 bytes .../voxel/weapon/staff/firestaff_starter.vox | Bin 1464 -> 1464 bytes .../voxel/weapon/staff/wood-simple.vox | Bin 1448 -> 1448 bytes common/src/comp/inventory/item/tool.rs | 4 +- voxygen/src/anim/src/character/alpha.rs | 62 +--------- voxygen/src/anim/src/character/beta.rs | 50 +++----- voxygen/src/anim/src/character/charge.rs | 27 +++-- voxygen/src/anim/src/character/chargeswing.rs | 112 ++++++++--------- voxygen/src/anim/src/character/climb.rs | 47 -------- voxygen/src/anim/src/character/dance.rs | 2 - voxygen/src/anim/src/character/equip.rs | 113 +++--------------- voxygen/src/anim/src/character/glidewield.rs | 36 ------ voxygen/src/anim/src/character/gliding.rs | 21 ---- voxygen/src/anim/src/character/jump.rs | 4 + voxygen/src/anim/src/character/mod.rs | 15 +++ voxygen/src/anim/src/character/roll.rs | 38 ------ voxygen/src/anim/src/character/run.rs | 7 +- voxygen/src/anim/src/character/shoot.rs | 26 ++-- voxygen/src/anim/src/character/spin.rs | 45 +++---- voxygen/src/anim/src/character/stand.rs | 4 + voxygen/src/anim/src/character/swim.rs | 4 + voxygen/src/anim/src/character/swimwield.rs | 2 - voxygen/src/anim/src/character/wield.rs | 36 +++--- voxygen/src/anim/src/fish_medium/idle.rs | 5 - voxygen/src/anim/src/fish_medium/jump.rs | 5 - voxygen/src/anim/src/fish_medium/run.rs | 5 - 34 files changed, 194 insertions(+), 490 deletions(-) diff --git a/assets/voxygen/item_image_manifest.ron b/assets/voxygen/item_image_manifest.ron index 06677412cc..b7c0aa25ce 100644 --- a/assets/voxygen/item_image_manifest.ron +++ b/assets/voxygen/item_image_manifest.ron @@ -491,32 +491,32 @@ // Staffs Tool(Staff("BasicStaff")): VoxTrans( "voxel.weapon.staff.firestaff_starter", - (1.0, 0.0, 0.0), (-310., 90.0, 0.0), 1.2, + (1.0, 0.0, 0.0), (-130., 90.0, 0.0), 1.2, ), Tool(Staff("BoneStaff")): VoxTrans( "voxel.weapon.staff.firestaff_bone", - (1.0, 0.0, 0.0), (-310., 90.0, 0.0), 1.2, + (1.0, 0.0, 0.0), (-130., 90.0, 0.0), 1.2, ), Tool(Staff("AmethystStaff")): VoxTrans( "voxel.weapon.staff.firestaff_amethyst", - (1.0, 0.0, 0.0), (-310., 90.0, 0.0), 1.2, + (1.0, 0.0, 0.0), (-130., 90.0, 0.0), 1.2, ), Tool(Staff("CultistStaff")): VoxTrans( "voxel.weapon.staff.firestaff_cultist", - (1.0, 0.0, 0.0), (-310., 90.0, 0.0), 1.2, + (1.0, 0.0, 0.0), (-130., 90.0, 0.0), 1.2, ), // Healing staff Tool(Sceptre("Sceptre")): VoxTrans( "voxel.weapon.sceptre.wood-nature", - (1.0, -1.0, 0.0), (-310., 90.0, 0.0), 1.2, + (1.0, -1.0, 0.0), (-130., 90.0, 0.0), 1.2, ), Tool(Sceptre("StarterSceptre")): VoxTrans( "voxel.weapon.sceptre.wood-simple", - (0.0, -0.0, 0.0), (-310., 90.0, 0.0), 1.25, + (0.0, -0.0, 0.0), (-130., 90.0, 0.0), 1.25, ), Tool(Sceptre("SceptreVelorite")): VoxTrans( "voxel.weapon.sceptre.ore-nature", - (1.0, -1.0, 0.0), (-310., 90.0, 0.0), 1.15, + (1.0, -1.0, 0.0), (-130., 90.0, 0.0), 1.15, ), // Shields Tool(Shield("BasicShield")): VoxTrans( diff --git a/assets/voxygen/voxel/weapon/sceptre/ore-nature.vox b/assets/voxygen/voxel/weapon/sceptre/ore-nature.vox index 892591cdf942ba3996cf743d855bea5f0c563ea4..176b8bdb4b13dc321bebeb109b99f5295ef0fc13 100644 GIT binary patch delta 597 zcmWm9OH#r>6ouhFoqKN{3W|u)#K%sYyBCpSNTJ2R4X_1YAWYq$e+FNjKb?kx?PxpN zK5ib4as=}IQ3VW+K#2;v<2?$Ls8A!_@(zBxRLwR>J!i0fnUTC-$@_I?Q_#rKuT}O- zZE7wyNZmn#b*tpvtGruf@7@$07dyV3cMZ}F_uw~61!}q(&aMy2s8A2x9#pi4WURHv z%qDO7AvBwU^JtHoJVc2K#TA#YKI90L!}IJ@KI56SOBw;2e#xi&8`dsp1Z+Z2z7?#U zf6EcDGa3OK|H#LDcD(tKjd(!7PU+K~g0+*K906^t1s$9ZTk1uYp5=)2_nt@g4^4e& AcK`qY delta 597 zcmWm9OH$iF6ouhFt#hwh3MQCGAcUBmFwb5vl!q>$JYWOfLU`NLY%sqDU!7mAw#(km zwzKWcrtB3+RPEKl2qbzmsPY~idNd3u9q$m`N&`Ehm^0X`iV|Kc{7~7FG-~=my;s@{ zTpUqiC&95U5s!*k*N7)&a54CD-i;{9Jw&dQ80c|2>vyVX7^ZGJb!}J7y6r1lqVYp$ zwj}4-_M19IkA`mG^6*!IL_a-`FN%?8*57C(eDJC`;NP&G(Mb4^K73QM{{E&w!bda` zp1&*Re0IKhmydZs!YA~}hm!T_hXM(o(Py7Z);~TKNcfyS|5CEPpf70FKfe@6_>#W7 zSF-+fuRy|A^q;GxlJM`P0*P*MSG-uti`&YUpixnhPR^(87kBdYtpa)d@43$WA0

A^#A|> diff --git a/assets/voxygen/voxel/weapon/sceptre/wood-nature.vox b/assets/voxygen/voxel/weapon/sceptre/wood-nature.vox index 7a414f822f1b107803febfb13faa6c5c9e352b22..90fee6750ff2c81381ce946a61d988306a5f5913 100644 GIT binary patch delta 363 zcmWlVO;*A{5QJ-{yJrG1pa@Y32{-W$F0=9({(SP|5x9bTFTmbaK+&UFEWX#Bu1?j= z9MVJj@wo52!0--pM7B`fK*Ji=X<*74-e9(dUP#y{4T9T2g?oMn^ZX}rPLy-GX!O(G z9GcCbSERpyWpfyNASSn4Dn4C2ThS51Q>3Wy-`@h0BEB`ZU|hA19^E4cRp>|G5gdNh;8i>j%t$?Wc3 zxhp^Jx7{cF?j0YC;Ttx1#rkW!JH-d8{TKXpjh*PJ?@cMj8*He((FPyspBv4EX`W7+ z{H!&{+B57*G#7Y#j;nXgy`y?P#l+S+3TkS(Tw&)+tg*n()YqP|Tw(Q!P*g-=m(ng| zCOzppsn%?Q*H^eSmqt3^0YuM@pS7))Bd!4n|EfZ|X{g&L21-T~kU)a?NHlwT411xaxJTT&j M67aF4pC`Alf4&zzh5!Hn literal 27535 zcmdVjdt8&(83*u_Kmb9l7eqm;sh29+VFHQZwV+bPyJ)RaH3kwwBo~$hs+PGat<^eP zr%vsrRSV8mr&R{7wd<^N&bc|~tn0dU&bhAZ?(4R$>#k3q=Om!uWq<7R`}D)nr}6dow%+O*YP&4Q@z2M+@Ru;c|W$?3k1#$@LII_9d<*))7hIlErK>TWx`PQ|F{g04Ir; z)MCs2jDkhQ8L|^ga?Hfp5peq5Qm{x1H%3Y2O;OhNQPRhoqO#jZNsn%d%4r`Jf2$~4 z`zY!4O_sfVl+4UcQKQ;NCEhA3SE7oiOe|2+Ax?RDc~o0lOV_q2n!5W84NCox-cL=X zQ>SK1C><_prdiW1Q* zqPg1?l^#*F@*fwMdMB? zQuDd}RY|0_btTo9N*jiDrvsK=ba{MVqG|WgHoo1CbAE&KJDj(zP;_LgqEiPHojbC371zaP_)^_^)-qnWhz>lr>JJKqMckn*Oo!v!hy7E?l9W!&ZgQ2 zb7_0UBs#VJA$oVemqrXqqjA{-X!`xb$h{z!DyJ!`TcT)BMA6Bo6^-hjK}Ev{)8bKC z6q-Dm77R}#udOd_nlgl%mX4&taaNlBz-TI&Q$Ur=X3?r(32lD7l9~>zqf4iEQ`4@+ zbn5x#l#-G{eR_5$v)N46%z-p2>s}g@ok^P?>qkfS4x~5F4W}y?M$j&9vuVGg^RFm+ z`*lUDyu)Z`T@IZ&Jc-_WYaWF*cB4%%q|&jA>2!q#=>E$1*FF64j6WwQhx}Q)X{2=@ zjoq-8((BUc>~o4PbAJvE8%CL#nN(xlPcx=AlB!!pPmHzD@g31?xH^OHo&No))^?O8 zjNL-6jq7OZL>paraR?nRNvAD5SMBFt;>21s?>vPnh*s`6Ky~#^^i<<%dgirDWUtyl z6V~pb>Cc{|c}Fi%ettgfS0_m&@ft=SP~0U&S6`0y?<(J4a{L;vaJM_okDz|eZnu?# zw>u{FcRHrwJD<;AC+E+Y&WI#gQ)F4tYiDF-m0P}0I$YlJ^6Ic#79B?@Sna8h1<#UY zl}Lv-7>X8iWU+L(q|%aQvERtb5dbUg0$3pdtjsBZm8$|^7(I<5e!?6VQVn# zBN%oChFytaS7F#kF>Eb{{S<~>jbT5HVLyXm*I?MS7`6_>K89f*$FS=#>=PJvJ%-(Y zVV}gX8!_x>G3+J``xJ(K8pCeJu%E-QTQKZa47&}(ejdYa$FMsv>`n~(42JyzhW#Rj z-GyOyW7uag>>doe7sKwuu+L%GdJNluVfSO$FJagN81{J#`vQhNh+z+5*e_$)!x;7m zhJ6vk9>uW7Fl-}+{R)O{!m!O4_Be+9Du#Ut!@i7RPhi+rFznYb?5h~|>lpSVhJ6jg zp2D!-z_6z=>^Cv&84UX^40{&CejCG{!?54Mu;0b7=P~T}Fzf{k`+W?15ySof!(PI$ zuVdKD81{!4_6-dCBMkc{hW#;y{RxJB3&Z{t!(PF#Kf|zBG3?JV>@^Jg3k>@g{$0U)jnrPYV1k6rpy_MxT6*Nba%iV@~o7A9BF3|??^Io zZf!@#;cy3PbcH|YioUR1!o3p9DS>m_aBrYo42L(4|FmS~>Oy4-7qabkb1chg4rjpQ zbIZwgi`j0`iZkSPN~8Rm-dtVb@`fv=j}~b(mvz3CpwVR)aYXm+n(bNuOu6M5o?r z)e|{6)>k>RwXga%DGz!aEt45_Zh8H5rKff5x4auP>~jagdZ#KBT(0BwWS0kPgs|E5 z-Ri7zha%M>cXS}x(HpkZ=XALp0ez0{TC_sn!Fmuams0rFLFk=wug|Y{+$*Yr0z|J? zjW^n3eaKnn4qrdyar))LWM^f|O|p=8B}t$Tmd99MnNnXc=+`6gdsjp+W%QDT%bdRG z)1eXPn{zLIi|)y%*2$z^VzPXer=Nd+_I zABD6eIYCFr+9+e-8#%0%@?cqYID>0=CDX}#(~geQYv7&Z^yorPm$y1BgKly31eAxW z!;xx#wBBa5Wm|3f7UAbho-CU^*7}VdmyvYHj?0SCAv-S5S%>Vn+)Ev@Ui_9rH=q-lR|m` diff --git a/assets/voxygen/voxel/weapon/staff/firestaff_bone.vox b/assets/voxygen/voxel/weapon/staff/firestaff_bone.vox index edf5deece856f868a9b64fde72d9368d3abe7ea2..4a9ed2160fac56d7c829a91279fd43aa3bf05d90 100644 GIT binary patch delta 232 zcmWm6xeWp_6olb7&*oZ|YY!HPD1au25CM=O8h~)u9nb%G6YCE4+CT0TT%x8Cj<`PqB6x-J|rcd#TgZZc#^DhI8eu&hkE$&!=}Q1TzyxQkk} zXrP5tEovA-?nQGC&4b38xU&GA(3nOv4A|&^Bc=Wsnp~hgw##CvO&}=*2#;4R2t`^75vZ0|5V2M$V2Z6(DIy|@h!ktJA|lrMwrX4J^Xq(blZ7Odo>R~Ncrq~D znYrKn&Ew9!B*0k~&Rt~LE`%s6DxD(_Vr-od6{VFWw{b|||MX!*_)Jw+69M9#1pfD$d zOy-2J*_;qG#mQ{y-73tzTTSNP`^|ie<8tDDlev$~ePvFP`8JvR$=qM&+clFpxyEE3 zAdds(agaQw$o9c9r^-A;=AkmD?KhdyrJXLl^j0$;+ zaC-T?WTPlL+W2VZbJDoG{T$ah@!B!LWsd8Jbwv|o&1$h)Y&pS-8S_#&Kqijo)M0aZ zcG2SUbS|_fKF9aN6?6wQu2{K;8>6_fTa>M96pyi6l)Y;dkEmNzPS>dTn?*UgM)9b- zSXS|oTtGUeyzQ&UqDUEL~Z#;(&eD&<{zD6V!XnXB6I=SHidgFkP#*a#+$@Y;n>)vssEzG03 znSz>^3EC4CbmDPAxg*l4G;1_1&CMpgxPaD8oIu;AI%xCsG1Rtv0#(i{qPi7xs42XJ zHm&wjW2ln0JW@w(2iMcZQ@bcBDT#&-8bB6{g>0D_l$(7QO|)lH$z&VNy{~|_tQ$^; z_h!(mXS3+?`SJ9W?6d8FpmQ$@y7sc5M&CHv*_=bC4^5*tU#lQ}Q!;ISI)#p2NTbU% z@AX?wt`M=;1LfbkC%%(6m)Ev`66dM(ka9S5m-e;Yk^>=Zru(nWHHH_|<8_t31}C#d4cMJg;Tq^t4`CK6?) zcPQ?npervJ{ zRai@u6_>|XQ&S(&_@(30L-pQTe&JcOZ5-+Hg><8u!!Jvhha0WgR_Bc@p8>GkFMwqd z!19^`SiUO&mVfU6u)LoDY#$8U7sDoDSpH%Zu(tg$Y<~=UJBH;iXaQ?G0K*Q%u!Arx ze_;<;+rbz%6~hj}utPCy8iwU>;Q%{?jO7 z8pDpkuy;w#J#jrLE%YUp6*a!wEE{2_lVdrDmatvF6VHaT7`!Vc74Eq3vU4&s5 zW7tXzy9C27#jwjT>~ak2!mukatQ*5tVc2R6>%p)ZhONP{UJP4{VSO0(K@3}mVf`33 zfMJ6eHiTir81|zWR>!ar3>(F;^%%AR!#;#zS7O*z7`73^ehkAlVc3sj*wq;JVGR2T z47&!yuEns;7lO;z_3qa*e_z(XE5xSFzg`=dl4~ahHb;J&tcf(81^d| z_IV8Z0*3u6hJ6vkehtHZ9m9SD!=AvfFJah|81|bO_7sNw7KS~IVZV)G&tTZ^VA!)5 z_PZGNdl>c{hW$Qq8%NX|O81@Q={RM`-ieZ0=VXtA>Ut!qSG3>7~>>C*NHyHM}81{D<_V*a}4;c23 z81_#X_RkphO$_@N4Et9M`!@{x7KVKr!@h%I|Bhkb#jyXtu>Zuc|H82U#<2gvu>Zxd zgkkxUYU3r{OJ>*q_CdA!+^I8{N`@12F|xO;xT-?+!Rk&QgDZO$_C9zbQ8l^@fary4xINF9&S z%AMxP0w8t%uzs>JEW%RtMV%|?2gu^$fy~`xpD?V4qOrm4ZI^kqI}gqs4XF9*?o}?2u_}&OLtS4P?{HddRtGPRY7h9d&Vk%; z(*`oc!@24GQ;pu( z+;6%Y6ztc65mgB5p$ApGTI`xo0}~FX+O6)erbp{_&6tSY*sxW8w?}gY)ir8pMuXbH zY7!l{lKI#qRH4S_52%8+G8|&SxLXZAW5nu|yIPA}Kjn1?_{P|??Yv1A$s#8XRKffh zt2mG?Tr)8PNGK&{-w_DeeT zttP5@yv9UT&#{Y?^N`OIZU202wMxs{6^>FD^D3!=SNGj8{+OcfVkGRY_660Auw7@3 zJ8!kC5c$l9{ciPYQo~)_-VvXSb!1>#G%B$hmQCH#*dWyAQ8k{}^;(tJRo$uPRy8#q zbtm~6n??Rm7guY3KL^rHk3u>UU!WrR-N^6tmBJ%m-C(Ge%@BPMs^Gtf=!1;~Q zBL~jUS&tkz@1-6&aDFIza7c;iV3@Q#I=f~_mat=qZf#(O> zkX0<0{e?x(qG!>sDi&Br>u4Pf3v9od?^g#E3#_HJw3dcd=I4w16FmO7KfpcQo!xJt zVZMQD_E(qLeaA~`UQ+X5eO9r+Dq2OWXjov87HN@&1tyyKP|>i&-uYPL2aIlXtTKoE S`Ehs;G5lZKwtaouul@ik#$eX~ delta 395 zcmW-cSx&=15Cx~-8|(zLFJ3TbL4qItxlpdaUHFN_Ng{=KE`m%AmP*yG9$WUl+jpNY zyL3>Bk`yI_a+F9a0z(Ss&>`a_m5>gS8sp4;GJ7-Q$jspCWX`)t<{ZutnddVt7grm0 zI%CnWXjn9hs}0f8T3SoPhS)5j%_4BMA-1$FZA-(h^Z7~Y;NnNRge$l{N;h!JdO`5EE_ULnj*c#Quqoo%w;8KGU)5{9HcX Q-(FKr|JS;%U*GZTKOBNzDF6Tf diff --git a/assets/voxygen/voxel/weapon/staff/firestaff_ogre.vox b/assets/voxygen/voxel/weapon/staff/firestaff_ogre.vox index d87b3d7a9294d4ed32234e1a16c844ea7cdd6906..aeac9efa2006d9ea9024adb0f1f0467795e2db4d 100644 GIT binary patch delta 960 zcmWmCOLp2&5QJg%eF?A)w!u%pHrUAuGS1f6LeNTbP9_<8KiPnX`R?FXbyb&ibp&6l zuhp-gr|(m$Xc&>dO{rjp;bThaV~R|XyT0SOl<*vhVia5%TQ|_Ahdil}GMMcLc$r&D%`%GCWi(`aVINRhkFut3_mdFSCf4=^KRsC?a>6U`{y zHy*j^js3o@{#JjhYeufylj2qpQ&SmV)Iu>J@**Q$)SwFVE2~?PFYGCzF8GB# zZ3_p?9Wdu9qR#AR`V>(|e&lHzr&HACh9;n`DO3ft>QfaDD15Oi(@?TcoaI?=uGxRa z+_HZ5b<8E{B%P#VuIW59GZJ#wkuRYaKNQ2E;gIkfhtD0#mM#3QcB2_l2c1Da{P~x! F%72oWs4D;f delta 960 zcmWmCNp{*$6og^D=01V2jScR51M&(o&eqsM&`NSnCK-A^*?@=nH277w>X!6$1mElL z^{=1DZpwj%9wkk=Vu3DCIp--AiZW{|Q_4kNrZQ_+rl!`EH}&0H_}OTA0p zT(7+Bl??65y+@aR4mMNQHo}eK=9K!4oR6)1E8ohu@~xbYYY)AaQ=}eoBfF7Nq#kkW zWo~7((YVvO<0;ZH?iKC@_k#OViU_^`LXmIp~<F8D-XR<)454 HmGk-^-Ib-? diff --git a/assets/voxygen/voxel/weapon/staff/firestaff_saurok.vox b/assets/voxygen/voxel/weapon/staff/firestaff_saurok.vox index 54a30e86c441e93254e1f414b19b9ed3c8c2e01c..45d797cf8bd5871af7ef06f0175490ce2394b652 100644 GIT binary patch delta 424 zcmW;G%XPyb5Jq7!Gx#OTFWHtQfs;zonks;#hAh2Qc4;IHxR6}D_|6RQ1M{q(_1DKF zNz7$YmsBg1D$t}>7(8pARTo%d#d=NMP-|?_kSlgsZU3ouz>)q$ZP`DQDK5C8!!7Hi zJYYm_@?3Xnd$ZCCanT*v-ffjG;e$qac9bb^*fjDgu~CDYwRCGvq=X4 delta 424 zcmW;G%Xz~f5QR}OcaSa1^7}2nDoJau0FoNA^itWSku=~!^5ez%W`GOKt9`X!ACGG? zzh%=cNq3Zb#U;s$GkVs2mQFb0zV4U^P zh^9s)RED{rd|GpP#N{!4lS~amPS9e?=N-8&o6j((Utoz9*)=xUVuw8#+7G;Uq@Kw2 zyc5$y#zz*DQLPMPqpZL%!IOuW{e7mvgOl??@~6oMGygW}DTDNDCFh7S2P-^R=BYBV h=P7a?rKHMvo4q$X(*!;ej45l@6_<>#|NMo{{{bR)M!5h0 diff --git a/assets/voxygen/voxel/weapon/staff/firestaff_starter.vox b/assets/voxygen/voxel/weapon/staff/firestaff_starter.vox index a4e74130729e06011c2f5e2b90e91d4c91c0db38..380399c3f691f6617367f6f69688002ea5b46430 100644 GIT binary patch delta 395 zcmXAlOHRZv5JbDH?eNJk158XN90mzCY!NrG?~rVB1@6LTBrd{|iy(LmkxFs5%l*ne z_Q(G1Vcj;@RdsFn@2Y8K50~Jb81^vwJrieWS0_xrsh|GCbYv z36K7~Q&afjaaKJpn}^Uj%GKBCSR{18W}v>>$;`oEP;8q8pvVj$XlxkP%{tY4Y61p9 zgTS#Pr~?HgKmsH{0wg$sBRGO1ICxjr_~kZMx4Y(cXr{8525whKK5*;8?WlDRWc>7u wH{;C*f)s)bizmEkAY?(*fj99QF%g~@4PGru73<{9 delta 395 zcmXAlOHRZv5JX+ob_U2W{1PA>1_?H7N8G@^L$b{kxC@(+xCl!wg5WVkD#hI{_bdC* zANse)b=&0gD)0FBHCeM4_)C3HI z27#j|=mZpy0U3}18Ia)^j^P-N;ox26_)?0hl$(-Ua#@l)ZdXX&aqGhEsGWesrwZPJ tx0oP>Al;&jH+O_Ah&u3QUL!*PXFKj=lw(9@e7h4G~oaM diff --git a/assets/voxygen/voxel/weapon/staff/wood-simple.vox b/assets/voxygen/voxel/weapon/staff/wood-simple.vox index e0510d6f81a315cad85694261329bd43ceec4fa3..9923ff016449f973b80e3a47bedf1777a575cf50 100644 GIT binary patch delta 257 zcmWlTJ#NBK5QN{%SmMX-o znSGRx^6TSew1>hCg2fBSE2IlFYEh&N#N7XGKEv`14LT54z@kqWkKl9*P7Yu?LH4qj zxk}G*3;wHYq2yiPqqZNK4ZHq*Jz(8Ib=&VYuSIO2r5m2yVDZ@vGpEm;zOX7c%$;nn q*|z^)y%kkMrc5Qz*ibQ(W~%&mYJe&S^I#s#gL&|NQ2M!JTKoaGp(C>Z delta 257 zcmWlT!D_-#6hz-m5Wbp|R)>xEJv!T;*k>v4s-Q{z|j%54bG!=eq24G2G#B z@65gD_x$s)sn6ic2e^{jE3CbN&sVS>koX9MIQ_1VE`0|dN7(8HNTw4Duds(6wz$Cj z8z@hCinG#O4zPb!1L(D@dt~yBSTj!hHnnU7vtc@|w@K*0R1HvrWKIopr58${Nu?SJ tCChW(Pv1|wr0mRmGuO#GUpX{m&PQ (anim_time as f32, 0.0, 0.0), + Some(StageSection::Buildup) => ((anim_time as f32).powf(0.25), 0.0, 0.0), Some(StageSection::Swing) => (1.0, anim_time as f32, 0.0), - Some(StageSection::Recover) => (1.0, 1.0, anim_time as f32), + Some(StageSection::Recover) => (1.0, 1.0, (anim_time as f32).powf(4.0)), _ => (0.0, 0.0, 0.0), }; @@ -56,10 +56,6 @@ impl Animation for AlphaAnimation { / (0.4 + 4.6 * ((anim_time as f32 * lab as f32 * 9.0).sin()).powf(2.0 as f32))) .sqrt()) * ((anim_time as f32 * lab as f32 * 9.0).sin()); - let quick = (((5.0) - / (0.4 + 4.6 * ((anim_time as f32 * lab as f32 * 18.0).sin()).powf(2.0 as f32))) - .sqrt()) - * ((anim_time as f32 * lab as f32 * 18.0).sin()); let axe = (((1.0) / (0.05 + 0.95 * ((anim_time as f32 * lab as f32 * 8.0).sin()).powf(2.0 as f32))) .sqrt()) @@ -74,7 +70,6 @@ impl Animation for AlphaAnimation { * ((anim_time as f32 * lab as f32 * 4.0).sin()); match active_tool_kind { - //TODO: Inventory Some(ToolKind::Sword(_)) => { next.main.position = Vec3::new(0.0, 0.0, 0.0); next.main.orientation = Quaternion::rotation_x(0.0); @@ -101,67 +96,16 @@ impl Animation for AlphaAnimation { movement1 * 1.5 + (movement2 * 1.75).sin() * -3.0 + movement3 * 0.5, ); - next.head.position = Vec3::new(0.0, s_a.head.0 + 0.0, s_a.head.1); + next.head.position = Vec3::new(0.0 + movement2 * 2.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_z( movement1 * -0.9 + (movement2 * 1.75).sin() * 2.5 + movement3 * -0.5, ); }, Some(ToolKind::Dagger(_)) => { - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); - next.head.orientation = Quaternion::rotation_z(slow * -0.25) - * Quaternion::rotation_x(0.0 + slow * 0.15) - * Quaternion::rotation_y(slow * -0.15); - - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1); - next.chest.orientation = Quaternion::rotation_z(slow * 0.4) - * Quaternion::rotation_x(0.0 + slow * -0.2) - * Quaternion::rotation_y(slow * 0.2); - - next.belt.position = Vec3::new(0.0, s_a.belt.0, s_a.belt.1); - next.belt.orientation = next.chest.orientation * -0.3; - - next.shorts.position = Vec3::new(0.0, s_a.shorts.0, s_a.shorts.1); - next.shorts.orientation = next.chest.orientation * -0.45; - - next.hand_l.position = Vec3::new(0.0, 0.0, 0.0); - next.hand_l.orientation = Quaternion::rotation_x(0.0); - - next.main.position = Vec3::new(0.0, 0.0, 0.0); - next.main.orientation = Quaternion::rotation_x(0.0); - next.control_l.position = Vec3::new(-10.0 + push * 5.0, 6.0 + push * 5.0, 2.0); next.control_l.orientation = Quaternion::rotation_x(-1.4 + slow * 0.4) * Quaternion::rotation_y(slow * -1.3) * Quaternion::rotation_z(1.4 + slow * -0.5); - - next.hand_r.position = Vec3::new(0.0, 0.0, 0.0); - next.hand_r.orientation = Quaternion::rotation_x(0.0); - next.hand_r.scale = Vec3::one() * 1.04; - - next.second.position = Vec3::new(0.0, 0.0, 0.0); - next.second.orientation = Quaternion::rotation_x(0.0); - - next.control_r.position = Vec3::new(8.0, 0.0, 0.0); - next.control_r.orientation = Quaternion::rotation_x(0.0); - - next.foot_l.position = - Vec3::new(-s_a.foot.0, slow * -3.0 + quick * 3.0 - 4.0, s_a.foot.2); - next.foot_l.orientation = Quaternion::rotation_x(slow * 0.6) - * Quaternion::rotation_y((slow * -0.2).max(0.0)); - - next.foot_r.position = - Vec3::new(s_a.foot.0, slow * 3.0 + quick * -3.0 + 5.0, s_a.foot.2); - next.foot_r.orientation = Quaternion::rotation_x(slow * -0.6) - * Quaternion::rotation_y((slow * 0.2).min(0.0)); - - next.lantern.orientation = - Quaternion::rotation_x(slow * -0.7 + 0.4) * Quaternion::rotation_y(slow * 0.4); - - next.torso.position = Vec3::new(0.0, 0.0, 0.1) * s_a.scaler; - next.torso.orientation = Quaternion::rotation_z(0.0) - * Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(0.0); - next.torso.scale = Vec3::one() / 11.0 * s_a.scaler; }, Some(ToolKind::Axe(_)) => { next.head.position = Vec3::new(0.0, 0.0 + s_a.head.0, s_a.head.1); diff --git a/voxygen/src/anim/src/character/beta.rs b/voxygen/src/anim/src/character/beta.rs index 54308d30ae..7ae0dae5cb 100644 --- a/voxygen/src/anim/src/character/beta.rs +++ b/voxygen/src/anim/src/character/beta.rs @@ -34,9 +34,9 @@ impl Animation for BetaAnimation { let mut next = (*skeleton).clone(); let (movement1, movement2, movement3) = match stage_section { - Some(StageSection::Buildup) => (anim_time as f32, 0.0, 0.0), - Some(StageSection::Cast) => (1.0, anim_time as f32, 0.0), - Some(StageSection::Recover) => (1.0, 1.0, anim_time as f32), + Some(StageSection::Buildup) => ((anim_time as f32).powf(0.25), 0.0, 0.0), + Some(StageSection::Swing) => (1.0, anim_time as f32, 0.0), + Some(StageSection::Recover) => (1.0, 1.0, (anim_time as f32).powf(4.0)), _ => (0.0, 0.0, 0.0), }; @@ -53,41 +53,29 @@ impl Animation for BetaAnimation { Quaternion::rotation_x(s_a.shr.3) * Quaternion::rotation_y(s_a.shr.4); next.control.position = Vec3::new( - s_a.sc.0 - + movement1 * -5.0 - + (movement2 as f32 * 2.5).sin() * 30.0 - + movement3 * -5.0, - s_a.sc.1 - (movement1 as f32 * 8.0).sin() * 0.8 - + movement1 * 2.0 - + movement3 * 2.0, - s_a.sc.2 - (movement1 as f32 * 8.0).sin() * 0.4, + s_a.sc.0 + (-1.4 + movement1 * -3.0 + movement2 * -2.0) * (1.0 - movement3), + s_a.sc.1 + (-1.4 + movement1 * 3.0 + movement2 * 3.0) * (1.0 - movement3), + s_a.sc.2 + (-1.9 + movement1 * 2.5 * (1.0 - movement3)), ); - next.control.orientation = Quaternion::rotation_x(-1.57 + s_a.sc.3) - * Quaternion::rotation_y( - s_a.sc.4 + movement1 * 1.5 + (movement2 as f32 * 2.5).sin() * 0.5, - ) - * Quaternion::rotation_z(1.0 + s_a.sc.5 + (movement2 as f32 * 2.5).sin() * 1.0); - next.chest.orientation = Quaternion::rotation_y(-0.1) + next.control.orientation = + Quaternion::rotation_x(s_a.sc.3 + (-1.7) * (1.0 - movement3)) + * Quaternion::rotation_y( + s_a.sc.4 + + (0.4 + movement1 * 1.5 + movement2 * -2.5) * (1.0 - movement3), + ) + * Quaternion::rotation_z( + s_a.sc.5 + (1.67 + movement2 * 1.57) * (1.0 - movement3), + ); + next.chest.orientation = Quaternion::rotation_x(0.15) + * Quaternion::rotation_y((-0.1) * (1.0 - movement3)) * Quaternion::rotation_z( - 0.4 + movement1 * 1.5 - + (movement2 as f32 * 2.5).sin() * -0.5 - + movement3 * 1.0, - ); - next.head.orientation = Quaternion::rotation_y(0.1) - * Quaternion::rotation_z( - -0.1 + movement1 * -1.1 + (movement2 as f32 * 2.5).sin() * -0.5, + (0.4 + movement1 * 1.5 + movement2 * -2.5) * (1.0 - movement3), ); + next.head.orientation = Quaternion::rotation_z((-0.4) * (1.0 - movement3)); }, _ => {}, } - next.glider.position = Vec3::new(0.0, 0.0, 10.0); - next.glider.scale = Vec3::one() * 0.0; - - next.lantern.orientation = Quaternion::rotation_x(0.4); - next.lantern.scale = Vec3::one() * 0.65; - next.hold.scale = Vec3::one() * 0.0; - next.second.scale = match ( active_tool_kind.map(|tk| tk.hands()), second_tool_kind.map(|tk| tk.hands()), diff --git a/voxygen/src/anim/src/character/charge.rs b/voxygen/src/anim/src/character/charge.rs index b97b55aa85..394bc38678 100644 --- a/voxygen/src/anim/src/character/charge.rs +++ b/voxygen/src/anim/src/character/charge.rs @@ -94,23 +94,24 @@ impl Animation for ChargeAnimation { match active_tool_kind { //TODO: Inventory Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { - next.hand_l.position = Vec3::new(11.0, 5.0, -4.0); - next.hand_l.orientation = Quaternion::rotation_x(1.27); - next.hand_r.position = Vec3::new(12.0, 5.5, 2.0); + next.hand_l.position = Vec3::new(s_a.sthl.0, s_a.sthl.1, s_a.sthl.2); + next.hand_l.orientation = Quaternion::rotation_x(s_a.sthl.3); + + next.hand_r.position = Vec3::new(s_a.sthr.0, s_a.sthr.1, s_a.sthr.2); next.hand_r.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(0.2); - next.main.position = Vec3::new(12.0, 8.5, 13.2); - next.main.orientation = Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(3.14) - * Quaternion::rotation_z(0.0); + Quaternion::rotation_x(s_a.sthr.3) * Quaternion::rotation_y(s_a.sthr.4); + + next.main.position = Vec3::new(0.0, 0.0, 0.0); + next.main.orientation = Quaternion::rotation_y(0.0); next.control.position = Vec3::new( - -7.0 + quick * 3.5 * (1.0 / (stopa + 0.1)), - 0.0 + quicka * 3.5 * (1.0 / (stopa + 0.1)), - 8.0 - stop * 3.0, + s_a.stc.0 + quick * 3.5 * (1.0 / (stopa + 0.1)), + s_a.stc.1, + s_a.stc.2 - stop * 3.0, ); - next.control.orientation = - Quaternion::rotation_x(stop * -0.2) * Quaternion::rotation_z(stop * 0.2); + next.control.orientation = Quaternion::rotation_x(s_a.stc.3 + stop * -0.2) + * Quaternion::rotation_y(s_a.stc.4) + * Quaternion::rotation_z(s_a.stc.5 + stop * 0.2); }, Some(ToolKind::Bow(_)) => { next.hand_l.position = Vec3::new(1.0, -2.0 + stop * -1.0, 0.0); diff --git a/voxygen/src/anim/src/character/chargeswing.rs b/voxygen/src/anim/src/character/chargeswing.rs index b35fe26bc4..dd9e3b6a56 100644 --- a/voxygen/src/anim/src/character/chargeswing.rs +++ b/voxygen/src/anim/src/character/chargeswing.rs @@ -44,7 +44,6 @@ impl Animation for ChargeswingAnimation { // end spin stuff let movement = anim_time as f32 * 1.0; - let fire = (anim_time as f32 * 18.0 * lab as f32).sin(); let foothoril = (anim_time as f32 * 8.0 * lab as f32 + PI * 1.45).sin(); let foothorir = (anim_time as f32 * 8.0 * lab as f32 + PI * (0.45)).sin(); @@ -64,53 +63,60 @@ impl Animation for ChargeswingAnimation { * ((anim_time as f32 * 8.0 * lab as f32 + PI * 0.4).sin()).powf(2.0 as f32))) .sqrt()) * ((anim_time as f32 * 8.0 * lab as f32 + PI * 0.4).sin()); - if let Some(ToolKind::Hammer(_)) = active_tool_kind { - next.hand_l.position = Vec3::new(-12.0, 0.0, 0.0); - next.hand_l.orientation = Quaternion::rotation_x(-0.0) * Quaternion::rotation_y(0.0); - next.hand_r.position = Vec3::new(2.0, 0.0, 0.0); - next.hand_r.orientation = Quaternion::rotation_x(0.0) * Quaternion::rotation_y(0.0); - next.main.position = Vec3::new(0.0, 0.0, 0.0); - next.main.orientation = Quaternion::rotation_y(-1.57) * Quaternion::rotation_z(1.57); - next.control.position = Vec3::new(6.0, 7.0, 1.0); - next.control.orientation = Quaternion::rotation_x(0.3) - * Quaternion::rotation_y(0.0) - * Quaternion::rotation_z(0.0); + let (movement1, movement2, movement3, tension) = match stage_section { + Some(StageSection::Charge) => ( + (anim_time as f32).min(1.0), + 0.0, + 0.0, + (anim_time as f32 * 18.0 * lab as f32).sin(), + ), + Some(StageSection::Swing) => (1.0, anim_time as f32, 0.0, 0.0), + Some(StageSection::Recover) => (1.0, 1.0, (anim_time as f32).powf(4.0), 0.0), + _ => (0.0, 0.0, 0.0, 0.0), + }; + if let Some(ToolKind::Hammer(_)) = active_tool_kind { + next.main.position = Vec3::new(0.0, 0.0, 0.0); + next.main.orientation = Quaternion::rotation_x(0.0); + next.hand_l.position = Vec3::new( + s_a.hhl.0, + s_a.hhl.1, + s_a.hhl.2 + (movement2 * -8.0) * (1.0 - movement3), + ); + next.hand_l.orientation = + Quaternion::rotation_x(s_a.hhl.3) * Quaternion::rotation_y(s_a.hhl.4); + next.hand_r.position = Vec3::new(s_a.hhr.0, s_a.hhr.1, s_a.hhr.2); + next.hand_r.orientation = + Quaternion::rotation_x(s_a.hhr.3) * Quaternion::rotation_y(s_a.hhr.4); + + next.control.position = Vec3::new( + s_a.hc.0 + (movement1 * -2.0 + movement2 * -3.0) * (1.0 - movement3), + s_a.hc.1 + (movement1 * 2.0 + movement2 * 3.0) * (1.0 - movement3), + s_a.hc.2 + (movement1 * 2.0 + movement2 * 4.0) * (1.0 - movement3), + ); + next.control.orientation = Quaternion::rotation_x(s_a.hc.3+(movement2*4.0)*(1.0-movement3)) + * Quaternion::rotation_y(s_a.hc.4+(tension*0.08+movement1 * 0.7+movement2*-3.5)*(1.0-movement3))//+fire * 0.1 + * Quaternion::rotation_z(s_a.hc.5+(movement1 * 0.2+movement2*-0.5)*(1.0-movement3)); + next.chest.orientation = Quaternion::rotation_z( + short * 0.04 + (movement1 * 2.0 + movement2 * -2.5) * (1.0 - movement3), + ); + next.belt.orientation = + Quaternion::rotation_z(short * 0.08 + (movement1 * -1.0) * (1.0 - movement3)); + next.shorts.orientation = + Quaternion::rotation_z(short * 0.15 + (movement1 * -1.0) * (1.0 - movement3)); + next.head.position = Vec3::new( + 0.0 + (movement1 * -1.0 + movement2 * 2.0) * (1.0 - movement3), + s_a.head.0 + (movement1 * 1.0) * (1.0 - movement3), + s_a.head.1, + ); + next.head.orientation = + Quaternion::rotation_z((movement1 * -1.5 + movement2 * 2.2) * (1.0 - movement3)); + next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1); if let Some(stage_section) = stage_section { match stage_section { StageSection::Charge => { - next.control.position = Vec3::new( - 6.0 + (movement * -4.0).max(-8.0), - 7.0 + (movement * 2.0).min(2.0), - 1.0, - ); - next.control.orientation = Quaternion::rotation_x(0.3) - * Quaternion::rotation_y( - 0.0 + (movement * 0.7).min(0.7) - + fire * 0.1 * (anim_time as f32).min(2.0), - ) - * Quaternion::rotation_z(0.0 + (movement * 0.2).min(0.5)); - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1); - next.chest.orientation = - Quaternion::rotation_z((movement * 2.0).min(PI / 2.0)); - next.belt.orientation = - Quaternion::rotation_z((short * 0.08 + movement * -1.0).max(-PI / 5.0)); - next.shorts.orientation = - Quaternion::rotation_z((short * 0.15 + movement * -1.0).max(-PI / 4.0)); - - next.head.position = Vec3::new( - 0.0, - s_a.head.0 - 2.0 + (movement * 2.0).min(2.0), - s_a.head.1, - ); - - next.head.orientation = - Quaternion::rotation_z((movement * -1.8).max(PI / -2.0)); - next.belt.orientation = Quaternion::rotation_z(short * 0.05); - - next.shorts.orientation = Quaternion::rotation_z(short * 0.15); - if speed > 0.5 { + /*if speed > 0.5 { next.foot_l.position = Vec3::new( -s_a.foot.0, s_a.foot.1 + foothoril * -2.5 - 3.5, @@ -143,25 +149,7 @@ impl Animation for ChargeswingAnimation { next.foot_r.orientation = Quaternion::rotation_x(0.2) * Quaternion::rotation_z(0.5); }; - }, - - StageSection::Swing => { - next.chest.orientation = Quaternion::rotation_z(-0.5); - next.control.position = Vec3::new(6.0, 7.0, 1.0 + 3.0); - next.control.orientation = Quaternion::rotation_x(PI / 2.0) - * Quaternion::rotation_y(-1.6) - * Quaternion::rotation_z(0.3 - movement * 2.5); - next.head.orientation = Quaternion::rotation_z(0.8); - next.hand_l.position = Vec3::new(-3.0, 0.0, 0.0); - }, - StageSection::Recover => { - next.chest.orientation = Quaternion::rotation_z(-0.5 + movement * 0.5); - next.control.position = Vec3::new(6.0, 7.0, 1.0 + 3.0 + movement * -3.0); - next.control.orientation = Quaternion::rotation_x(PI / 2.0) - * Quaternion::rotation_y(-1.6 + movement * 1.6) - * Quaternion::rotation_z(-2.2 + movement * 2.2); - next.head.orientation = Quaternion::rotation_z(0.8 + movement * -0.8); - next.hand_l.position = Vec3::new(-3.0 + movement * -9.0, 0.0, 0.0); + */ }, _ => {}, } diff --git a/voxygen/src/anim/src/character/climb.rs b/voxygen/src/anim/src/character/climb.rs index d64a24b0fd..828a5489e3 100644 --- a/voxygen/src/anim/src/character/climb.rs +++ b/voxygen/src/anim/src/character/climb.rs @@ -97,40 +97,6 @@ impl Animation for ClimbAnimation { ); next.hand_r.orientation = Quaternion::rotation_x(2.2 - quicka * 0.5); - match active_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.main.position = Vec3::new(-4.0, -5.0, 7.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.main.position = Vec3::new(-0.0, -5.0, 3.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - _ => { - next.main.position = Vec3::new(-7.0, -5.0, 15.0); - next.main.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } - match second_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.second.position = Vec3::new(4.0, -6.0, 7.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.second.position = Vec3::new(0.0, -4.0, 3.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - _ => { - next.second.position = Vec3::new(-7.0, -5.0, 15.0); - next.second.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } next.foot_l.position = Vec3::new(-s_a.foot.0, 5.0 + s_a.foot.1, s_a.foot.2 + quick * 2.5); next.foot_l.orientation = Quaternion::rotation_x(0.2 - quicka * 0.5); @@ -143,16 +109,6 @@ impl Animation for ClimbAnimation { next.shoulder_r.orientation = Quaternion::rotation_x(smooth * 0.15); - next.glider.position = Vec3::new(0.0, 0.0, 10.0); - next.glider.scale = Vec3::one() * 0.0; - - next.main.position = Vec3::new(-7.0, -5.0, 18.0); - next.main.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57 + smootha * 0.25); - - next.second.position = Vec3::new(0.0, 0.0, 0.0); - next.second.orientation = Quaternion::rotation_y(0.0); - next.lantern.orientation = Quaternion::rotation_x(smooth * -0.3) * Quaternion::rotation_y(smooth * -0.3); @@ -211,9 +167,6 @@ impl Animation for ClimbAnimation { next.glider.position = Vec3::new(0.0, 0.0, 10.0); next.glider.scale = Vec3::one() * 0.0; - next.main.position = Vec3::new(-7.0, -5.0, 18.0); - next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - next.torso.position = Vec3::new(0.0, -0.2, 0.4) * s_a.scaler; }; diff --git a/voxygen/src/anim/src/character/dance.rs b/voxygen/src/anim/src/character/dance.rs index 8b17dd085d..ec63d74e00 100644 --- a/voxygen/src/anim/src/character/dance.rs +++ b/voxygen/src/anim/src/character/dance.rs @@ -168,8 +168,6 @@ impl Animation for DanceAnimation { next.control.position = Vec3::new(0.0, 0.0, 0.0); next.control.orientation = Quaternion::rotation_x(0.0); - - next.second.scale = match ( active_tool_kind.map(|tk| tk.hands()), second_tool_kind.map(|tk| tk.hands()), diff --git a/voxygen/src/anim/src/character/equip.rs b/voxygen/src/anim/src/character/equip.rs index efe71f4328..ab254de95e 100644 --- a/voxygen/src/anim/src/character/equip.rs +++ b/voxygen/src/anim/src/character/equip.rs @@ -21,122 +21,45 @@ impl Animation for EquipAnimation { (active_tool_kind, second_tool_kind, velocity, _global_time): Self::Dependency, anim_time: f64, rate: &mut f32, - s_a: &SkeletonAttr, + _s_a: &SkeletonAttr, ) -> Self::Skeleton { *rate = 1.0; let mut next = (*skeleton).clone(); let lab = 1.0; - let short = (((5.0) - / (1.5 + 3.5 * ((anim_time as f32 * lab as f32 * 16.0).sin()).powf(2.0 as f32))) - .sqrt()) - * ((anim_time as f32 * lab as f32 * 16.0).sin()); - let equip_slow = 1.0 + (anim_time as f32 * 12.0 + PI).cos(); let equip_slowa = 1.0 + (anim_time as f32 * 12.0 + PI / 4.0).cos(); + next.hand_l.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(-2.3) + * Quaternion::rotation_z(-1.57); + next.hand_r.orientation = Quaternion::rotation_x(0.0) + * Quaternion::rotation_y(-2.3) + * Quaternion::rotation_z(1.57); + next.control.position = Vec3::new(equip_slowa * -1.5, 0.0, equip_slow * 1.5); match active_tool_kind { Some(ToolKind::Sword(_)) => { - next.hand_l.position = Vec3::new(-0.75, -1.0, -2.5); - next.hand_l.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(-0.2); - next.hand_r.position = Vec3::new(0.75, -1.5, -5.5); - next.hand_r.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(0.3); - next.main.position = Vec3::new(0.0, 0.0, -6.0); - next.main.orientation = Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(0.0) - * Quaternion::rotation_z(0.0); - next.control.position = - Vec3::new(-3.0 + equip_slowa * -1.5, -5.0, 12.0 + equip_slow * 1.5); - next.control.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); + next.hand_l.position = Vec3::new(-8.0, -5.0, 17.0); + next.hand_r.position = Vec3::new(-6.0, -4.5, 14.0); }, Some(ToolKind::Axe(_)) => { - next.hand_l.position = Vec3::new(-4.0, 3.0, 6.0); - next.hand_l.orientation = Quaternion::rotation_x(-0.3) - * Quaternion::rotation_z(3.14 - 0.3) - * Quaternion::rotation_y(-0.8); - next.hand_r.position = Vec3::new(-2.5, 9.0, 4.0); - next.hand_r.orientation = Quaternion::rotation_x(-0.3) - * Quaternion::rotation_z(3.14 - 0.3) - * Quaternion::rotation_y(-0.8); - next.main.position = Vec3::new(-6.0, 10.0, -1.0); - next.main.orientation = Quaternion::rotation_x(1.27) - * Quaternion::rotation_y(-0.3) - * Quaternion::rotation_z(-0.8); - - next.control.position = Vec3::new(0.0, 0.0, 0.0); - next.control.orientation = - Quaternion::rotation_x(0.2) * Quaternion::rotation_y(-0.3); + next.hand_l.position = Vec3::new(-7.0, -5.0, 17.0); + next.hand_r.position = Vec3::new(-5.0, -4.5, 14.0); }, Some(ToolKind::Hammer(_)) => { - next.hand_l.position = Vec3::new(-7.0, 5.5, 3.5); - next.hand_l.orientation = - Quaternion::rotation_x(0.0) * Quaternion::rotation_y(0.32); - next.hand_r.position = Vec3::new(8.0, 7.75, 0.0); - next.hand_r.orientation = - Quaternion::rotation_x(0.0) * Quaternion::rotation_y(0.22); - next.main.position = Vec3::new(6.0, 7.0, 0.0); - next.main.orientation = - Quaternion::rotation_y(-1.35) * Quaternion::rotation_z(1.57); - - next.control.position = - Vec3::new(-3.0 + equip_slowa * -1.5, -12.0, 12.0 + equip_slow * 1.5); - next.control.orientation = - Quaternion::rotation_x(0.0) * Quaternion::rotation_y(1.35 + 2.5); + next.hand_l.position = Vec3::new(-5.0, -5.0, 13.0); + next.hand_r.position = Vec3::new(-3.0, -4.5, 10.0); }, Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { - next.hand_l.position = Vec3::new(0.0, 0.0, -4.0); - next.hand_l.orientation = - Quaternion::rotation_x(1.27) * Quaternion::rotation_y(0.0); - next.hand_r.position = Vec3::new(0.0, 0.0, 2.0); - next.hand_r.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(0.2); - next.main.position = Vec3::new(0.0, 0.0, 13.2); - next.main.orientation = Quaternion::rotation_y(3.14); - - next.control.position = Vec3::new(-4.0, 7.0, 4.0); - next.control.orientation = Quaternion::rotation_x(-0.3) - * Quaternion::rotation_y(0.15) - * Quaternion::rotation_z(0.0); + next.hand_l.position = Vec3::new(-3.0, -5.0, 8.0); + next.hand_r.position = Vec3::new(-1.75, -4.5, 5.0); }, Some(ToolKind::Bow(_)) => { - next.hand_l.position = Vec3::new(2.0, 1.5, 0.0); - next.hand_l.orientation = Quaternion::rotation_x(1.20) - * Quaternion::rotation_y(-0.6) - * Quaternion::rotation_z(-0.3); - next.hand_l.scale = Vec3::one() * 1.04; - next.hand_r.position = Vec3::new(5.9, 4.5, -5.0); - next.hand_r.orientation = Quaternion::rotation_x(1.20) - * Quaternion::rotation_y(-0.6) - * Quaternion::rotation_z(-0.3); - next.hand_r.scale = Vec3::one() * 1.04; - next.main.position = Vec3::new(3.0, 2.0, -13.0); - next.main.orientation = Quaternion::rotation_x(-0.3) - * Quaternion::rotation_y(0.3) - * Quaternion::rotation_z(-0.6); - - next.control.position = Vec3::new(-7.0, 6.0, 6.0); - next.control.orientation = Quaternion::rotation_x(0.0) - * Quaternion::rotation_y(0.0) - * Quaternion::rotation_z(0.0); + next.hand_l.position = Vec3::new(-3.0, -5.0, 9.0); + next.hand_r.position = Vec3::new(-1.75, -4.5, 7.0); }, _ => {}, } - next.hold.scale = Vec3::one() * 0.0; - - if velocity > 0.5 { - next.torso.orientation = Quaternion::rotation_x(-0.2); - } else { - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1 + short * 0.2); - - next.foot_l.position = Vec3::new(-s_a.foot.0, s_a.foot.1, s_a.foot.2); - next.foot_l.orientation = Quaternion::rotation_x(0.0); - - next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2); - next.foot_r.orientation = Quaternion::rotation_x(0.0); - } next.second.scale = match ( active_tool_kind.map(|tk| tk.hands()), diff --git a/voxygen/src/anim/src/character/glidewield.rs b/voxygen/src/anim/src/character/glidewield.rs index f27ba0a94e..81d8876c32 100644 --- a/voxygen/src/anim/src/character/glidewield.rs +++ b/voxygen/src/anim/src/character/glidewield.rs @@ -77,42 +77,6 @@ impl Animation for GlideWieldAnimation { next.glider.orientation = Quaternion::rotation_x(0.35); next.glider.position = Vec3::new(0.0, -9.0, 17.0); next.glider.scale = Vec3::one() * 1.0; - - match active_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.main.position = Vec3::new(-4.0, -5.0, 7.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.main.position = Vec3::new(-0.0, -5.0, 3.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - _ => { - next.main.position = Vec3::new(-7.0, -5.0, 15.0); - next.main.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } - - match second_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.second.position = Vec3::new(4.0, -6.0, 7.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.second.position = Vec3::new(0.0, -4.0, 3.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - _ => { - next.second.position = Vec3::new(-7.0, -5.0, 15.0); - next.second.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } } next.second.scale = match ( diff --git a/voxygen/src/anim/src/character/gliding.rs b/voxygen/src/anim/src/character/gliding.rs index 2b1ca1b02e..38efa414dc 100644 --- a/voxygen/src/anim/src/character/gliding.rs +++ b/voxygen/src/anim/src/character/gliding.rs @@ -76,17 +76,13 @@ impl Animation for GlidingAnimation { anim_time as f32 }; - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); next.head.orientation = Quaternion::rotation_x(0.35 - slow * 0.10 + head_look.y) * Quaternion::rotation_z(head_look.x + slowa * 0.15); - next.chest.position = Vec3::new(0.0, s_a.chest.0, s_a.chest.1); next.chest.orientation = Quaternion::rotation_z(slowa * 0.02); - next.belt.position = Vec3::new(0.0, 0.0, -2.0); next.belt.orientation = Quaternion::rotation_z(slowa * 0.1 + tilt * tiltcancel * 12.0); - next.shorts.position = Vec3::new(0.0, s_a.shorts.0, s_a.shorts.1); next.shorts.orientation = Quaternion::rotation_z(slowa * 0.12 + tilt * tiltcancel * 16.0); next.hand_l.position = Vec3::new(-9.5, -3.0, 10.0); @@ -118,23 +114,6 @@ impl Animation for GlidingAnimation { Quaternion::rotation_x(0.8) * Quaternion::rotation_y(slowa * 0.04); next.glider.scale = Vec3::one(); - match active_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.main.position = Vec3::new(-4.0, -5.0, 7.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.main.position = Vec3::new(-0.0, -5.0, 3.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - _ => { - next.main.position = Vec3::new(-7.0, -5.0, 15.0); - next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } - next.torso.position = Vec3::new(0.0, -4.0, 10.0) / 11.0 * s_a.scaler; next.torso.orientation = Quaternion::rotation_x(-0.06 * speed.max(12.0) + slow * 0.04) * Quaternion::rotation_y(tilt * tiltcancel * 32.0); diff --git a/voxygen/src/anim/src/character/jump.rs b/voxygen/src/anim/src/character/jump.rs index f2494d61ac..c49c62008b 100644 --- a/voxygen/src/anim/src/character/jump.rs +++ b/voxygen/src/anim/src/character/jump.rs @@ -136,6 +136,10 @@ impl Animation for JumpAnimation { next.main.orientation = Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); }, + Some(ToolKind::Staff(_)) => { + next.main.position = Vec3::new(2.0, -5.0, -1.0); + next.main.orientation = Quaternion::rotation_y(-0.5) * Quaternion::rotation_z(1.57); + }, _ => { next.main.position = Vec3::new(-7.0, -5.0, 15.0); next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); diff --git a/voxygen/src/anim/src/character/mod.rs b/voxygen/src/anim/src/character/mod.rs index dc340c0849..5d7015a681 100644 --- a/voxygen/src/anim/src/character/mod.rs +++ b/voxygen/src/anim/src/character/mod.rs @@ -136,6 +136,9 @@ pub struct SkeletonAttr { hhl: (f32, f32, f32, f32, f32, f32), hhr: (f32, f32, f32, f32, f32, f32), hc: (f32, f32, f32, f32, f32, f32), + sthl: (f32, f32, f32, f32, f32, f32), + sthr: (f32, f32, f32, f32, f32, f32), + stc: (f32, f32, f32, f32, f32, f32), } impl Default for SkeletonAttr { @@ -158,6 +161,9 @@ impl Default for SkeletonAttr { hhl: (0.0, 0.0, 10.0, 0.0, 0.0, 0.0), hhr: (0.0, 0.0, 0.0, 0.0, 0.0, 0.0), hc: (0.0, 0.0, 0.0, 0.0, 0.0, 0.0), + sthl: (0.0, 0.0, 10.0, 0.0, 0.0, 0.0), + sthr: (0.0, 0.0, 0.0, 0.0, 0.0, 0.0), + stc: (0.0, 0.0, 0.0, 0.0, 0.0, 0.0), } } } @@ -249,6 +255,15 @@ impl<'a> From<&'a Body> for SkeletonAttr { hc: match (body.species, body.body_type) { (_, _) => (6.0, 7.0, 1.0, -0.3, -1.57, 0.5), }, + sthl: match (body.species, body.body_type) { + (_, _) => (0.0, 0.0, 1.0, 1.27, 0.0, 0.0), + }, + sthr: match (body.species, body.body_type) { + (_, _) => (0.0, 0.0, 7.0, 1.57, 0.2, 0.0), + }, + stc: match (body.species, body.body_type) { + (_, _) => (-5.0, 5.0, -1.0, -0.3, 0.15, 0.0), + }, } } } diff --git a/voxygen/src/anim/src/character/roll.rs b/voxygen/src/anim/src/character/roll.rs index c067ecefb4..4029f9abfa 100644 --- a/voxygen/src/anim/src/character/roll.rs +++ b/voxygen/src/anim/src/character/roll.rs @@ -75,46 +75,8 @@ impl Animation for RollAnimation { next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1 + 5.5, s_a.foot.2 - 5.0); next.foot_r.orientation = Quaternion::rotation_x(0.9); - next.glider.position = Vec3::new(0.0, 0.0, 10.0); - - match active_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.main.position = Vec3::new(-4.0, -5.0, 7.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.main.position = Vec3::new(-0.0, -5.0, 3.0); - next.main.orientation = - Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - _ => { - next.main.position = Vec3::new(-7.0, -5.0, 15.0); - next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } - - match second_tool_kind { - Some(ToolKind::Dagger(_)) => { - next.second.position = Vec3::new(4.0, -6.0, 7.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); - }, - Some(ToolKind::Shield(_)) => { - next.second.position = Vec3::new(0.0, -4.0, 3.0); - next.second.orientation = - Quaternion::rotation_y(-0.25 * PI) * Quaternion::rotation_z(1.5 * PI); - }, - _ => { - next.second.position = Vec3::new(-7.0, -5.0, 15.0); - next.second.orientation = - Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); - }, - } - next.lantern.orientation = Quaternion::rotation_x(0.1) * Quaternion::rotation_y(0.1); next.lantern.scale = Vec3::one() * 0.65; - next.hold.scale = Vec3::one() * 0.0; next.torso.position = Vec3::new(0.0, 0.0, 8.0) / 11.0 * s_a.scaler; next.torso.orientation = diff --git a/voxygen/src/anim/src/character/run.rs b/voxygen/src/anim/src/character/run.rs index 7a294f0252..60d962a76d 100644 --- a/voxygen/src/anim/src/character/run.rs +++ b/voxygen/src/anim/src/character/run.rs @@ -197,9 +197,14 @@ impl Animation for RunAnimation { next.main.orientation = Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); }, + Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { + next.main.position = Vec3::new(2.0, -5.0, -1.0); + next.main.orientation = Quaternion::rotation_y(-0.5) * Quaternion::rotation_z(1.57); + }, _ => { next.main.position = Vec3::new(-7.0, -5.0, 15.0); - next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); + next.main.orientation = + Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57 + shorte * -0.2); }, } diff --git a/voxygen/src/anim/src/character/shoot.rs b/voxygen/src/anim/src/character/shoot.rs index 5b91f768c5..72345ea941 100644 --- a/voxygen/src/anim/src/character/shoot.rs +++ b/voxygen/src/anim/src/character/shoot.rs @@ -56,20 +56,22 @@ impl Animation for ShootAnimation { next.shorts.orientation = next.chest.orientation * -0.08; match active_tool_kind { - //TODO: Inventory Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { - next.hand_l.position = Vec3::new(11.0, 5.0, -4.0); - next.hand_l.orientation = - Quaternion::rotation_x(1.27) * Quaternion::rotation_y(0.0); - next.hand_r.position = Vec3::new(12.0, 5.5, 2.0); - next.hand_r.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(0.2); - next.main.position = Vec3::new(12.0, 8.5, 13.2); - next.main.orientation = Quaternion::rotation_y(3.14); + next.hand_l.position = Vec3::new(s_a.sthl.0, s_a.sthl.1, s_a.sthl.2); + next.hand_l.orientation = Quaternion::rotation_x(s_a.sthl.3); - next.control.position = Vec3::new(-7.0, 6.0, 6.0 - exp * 5.0); - next.control.orientation = - Quaternion::rotation_x(exp * 1.3) * Quaternion::rotation_z(exp * 1.5); + next.hand_r.position = Vec3::new(s_a.sthr.0, s_a.sthr.1, s_a.sthr.2); + next.hand_r.orientation = + Quaternion::rotation_x(s_a.sthr.3) * Quaternion::rotation_y(s_a.sthr.4); + + next.main.position = Vec3::new(0.0, 0.0, 0.0); + next.main.orientation = Quaternion::rotation_y(0.0); + + next.control.position = + Vec3::new(s_a.stc.0, s_a.stc.1 + exp * 5.0, s_a.stc.2 - exp * 5.0); + next.control.orientation = Quaternion::rotation_x(s_a.stc.3 + exp * 0.4) + * Quaternion::rotation_y(s_a.stc.4) + * Quaternion::rotation_z(s_a.stc.5 + exp * 1.5); }, Some(ToolKind::Bow(_)) => { next.hand_l.position = diff --git a/voxygen/src/anim/src/character/spin.rs b/voxygen/src/anim/src/character/spin.rs index dbbd6e7932..e4cf7fb82b 100644 --- a/voxygen/src/anim/src/character/spin.rs +++ b/voxygen/src/anim/src/character/spin.rs @@ -39,9 +39,9 @@ impl Animation for SpinAnimation { let lab = 1.0; let (movement1, movement2, movement3) = match stage_section { - Some(StageSection::Buildup) => (anim_time as f32, 0.0, 0.0), - Some(StageSection::Swing) => (1.0, anim_time as f32, 0.0), - Some(StageSection::Recover) => (1.0, 1.0, anim_time as f32), + Some(StageSection::Buildup) => ((anim_time as f32).powf(0.25), 0.0, 0.0), + Some(StageSection::Swing) => (1.0, (anim_time as f32).powf(1.8), 0.0), + Some(StageSection::Recover) => (1.0, 1.0, (anim_time as f32).powf(4.0)), _ => (0.0, 0.0, 0.0), }; @@ -55,8 +55,6 @@ impl Animation for SpinAnimation { let spin = (anim_time as f32 * 2.8 * lab as f32).sin(); let spinhalf = (anim_time as f32 * 1.4 * lab as f32).sin(); - fn slow(x: f32) -> f32 { (x * 8.0).sin() } - next.head.position = Vec3::new(0.0, s_a.head.0, s_a.head.1); if let Some(ToolKind::Sword(_)) = active_tool_kind { @@ -71,32 +69,21 @@ impl Animation for SpinAnimation { Quaternion::rotation_x(s_a.shr.3) * Quaternion::rotation_y(s_a.shr.4); next.control.position = Vec3::new( - s_a.sc.0 + movement1 * 2.0 + movement2 * -8.0 + movement3 * -7.0, - s_a.sc.1 - + 8.0 - + slow(movement1) * 0.6 - + slow(movement2) * 3.0 - + slow(movement3) * -0.8 - + movement3 * -10.0, - s_a.sc.2 - + 1.0 - + slow(movement1) * 0.6 - + slow(movement2) * 3.5 - + movement2 * 3.0 - + slow(movement3) * -0.4 - + movement3 * -4.0, + s_a.sc.0 + movement1 * 2.0 + movement2 * -4.0 + movement3 * -7.0, + s_a.sc.1 + 8.0 + movement1 * 0.6 + movement3 * -10.0, + s_a.sc.2 + 1.0 + movement1 * 0.6 + movement2 * 1.5 + movement3 * -4.0, ); - next.control.orientation = Quaternion::rotation_x( - -0.5 + s_a.sc.4 + movement1 * -1.57 + movement2 * -0.6 + slow(movement2) * -0.25, - ) * Quaternion::rotation_y( - s_a.sc.4 - 0.6 + movement1 * 2.0 + movement2 * -2.0, - ) * Quaternion::rotation_z( - s_a.sc.5 + 0.1 + movement1 + movement2, + next.control.orientation = Quaternion::rotation_x(-0.5 + s_a.sc.3 + movement1 * -1.2) + * Quaternion::rotation_y(s_a.sc.4 - 0.6 + movement1 * 1.0) + * Quaternion::rotation_z(s_a.sc.5 + 0.1 + movement1 * 1.57); + next.head.position = Vec3::new( + 0.0 + 2.0 + movement2 * -2.0, + 2.0 + movement2 * -2.0 + s_a.head.0, + s_a.head.1, ); + next.head.orientation = Quaternion::rotation_z(movement2 * -0.4); - next.head.orientation = Quaternion::rotation_z(slow(movement2) * -0.8); - - next.chest.orientation = Quaternion::rotation_x(slow(movement2) * 0.15) + next.chest.orientation = Quaternion::rotation_x(movement2 * 0.15) * Quaternion::rotation_y(movement1 * -0.1 + movement2 * 0.3 + movement3 * -0.1) * Quaternion::rotation_z( -1.0 + movement1 * -0.6 + movement2 * 1.5 + movement3 * 0.5, @@ -111,7 +98,7 @@ impl Animation for SpinAnimation { next.head.orientation = Quaternion::rotation_y(movement1 * 0.1 - movement2 * -0.1) * Quaternion::rotation_z(1.07 + movement1 * 0.4 + movement2 * -1.5); - next.torso.orientation = Quaternion::rotation_z((movement2).sin() * 7.2); + next.torso.orientation = Quaternion::rotation_z(movement2 * 6.28); } if let Some(ToolKind::Axe(_) | ToolKind::Hammer(_) | ToolKind::Dagger(_)) = active_tool_kind diff --git a/voxygen/src/anim/src/character/stand.rs b/voxygen/src/anim/src/character/stand.rs index 0bda28e05a..6f9c53feff 100644 --- a/voxygen/src/anim/src/character/stand.rs +++ b/voxygen/src/anim/src/character/stand.rs @@ -109,6 +109,10 @@ impl Animation for StandAnimation { next.main.orientation = Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); }, + Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { + next.main.position = Vec3::new(2.0, -5.0, -1.0); + next.main.orientation = Quaternion::rotation_y(-0.5) * Quaternion::rotation_z(1.57); + }, _ => { next.main.position = Vec3::new(-7.0, -5.0, 15.0); next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); diff --git a/voxygen/src/anim/src/character/swim.rs b/voxygen/src/anim/src/character/swim.rs index 75fc42c783..e3411a190d 100644 --- a/voxygen/src/anim/src/character/swim.rs +++ b/voxygen/src/anim/src/character/swim.rs @@ -178,6 +178,10 @@ impl Animation for SwimAnimation { next.main.orientation = Quaternion::rotation_y(0.25 * PI) * Quaternion::rotation_z(-1.5 * PI); }, + Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { + next.main.position = Vec3::new(2.0, -5.0, -1.0); + next.main.orientation = Quaternion::rotation_y(-0.5) * Quaternion::rotation_z(1.57); + }, _ => { next.main.position = Vec3::new(-7.0, -5.0, 15.0); next.main.orientation = Quaternion::rotation_y(2.5) * Quaternion::rotation_z(1.57); diff --git a/voxygen/src/anim/src/character/swimwield.rs b/voxygen/src/anim/src/character/swimwield.rs index f875421bcf..b75b6af8d9 100644 --- a/voxygen/src/anim/src/character/swimwield.rs +++ b/voxygen/src/anim/src/character/swimwield.rs @@ -359,8 +359,6 @@ impl Animation for SwimWieldAnimation { _ => {}, } - - next.second.scale = match ( active_tool_kind.map(|tk| tk.hands()), second_tool_kind.map(|tk| tk.hands()), diff --git a/voxygen/src/anim/src/character/wield.rs b/voxygen/src/anim/src/character/wield.rs index 42b7281807..cac4429812 100644 --- a/voxygen/src/anim/src/character/wield.rs +++ b/voxygen/src/anim/src/character/wield.rs @@ -50,8 +50,8 @@ impl Animation for WieldAnimation { let foothoril = (anim_time as f32 * 16.0 * lab as f32 + PI * 1.45).sin(); let slowalt = (anim_time as f32 * 6.0 + PI).cos(); - let u_slow = (anim_time as f32 * 1.0 + PI).sin(); - let slow = (anim_time as f32 * 3.0 + PI).sin(); + let u_slow = (anim_time as f32 * 2.5 + PI).sin(); + let slow = (anim_time as f32 * 5.0 + PI).sin(); let u_slowalt = (anim_time as f32 * 3.0 + PI).cos(); let short = (((5.0) @@ -182,37 +182,37 @@ impl Animation for WieldAnimation { next.hand_r.orientation = Quaternion::rotation_x(s_a.hhr.3) * Quaternion::rotation_y(s_a.hhr.4); - next.control.position = Vec3::new(s_a.hc.0, s_a.hc.1, s_a.hc.2); + next.control.position = + Vec3::new(s_a.hc.0, s_a.hc.1 + speed * 0.2, s_a.hc.2 + speed * 0.8); next.control.orientation = Quaternion::rotation_x(s_a.hc.3 + u_slow * 0.15) - * Quaternion::rotation_y(s_a.hc.4) - * Quaternion::rotation_z(s_a.hc.5 + u_slowalt * 0.08); + * Quaternion::rotation_y(s_a.hc.4 + speed * -0.04) + * Quaternion::rotation_z(s_a.hc.5 + u_slowalt * 0.07); }, Some(ToolKind::Staff(_)) | Some(ToolKind::Sceptre(_)) => { if speed > 0.5 && velocity.z == 0.0 { next.hand_r.position = Vec3::new( 4.0 + s_a.hand.0 + foothoril * 1.3, - -2.0 + s_a.hand.1 + foothoril * -6.5, - -2.0 + s_a.hand.2 - foothoril * 7.0, + s_a.hand.1 + foothoril * -6.5, + 5.0 + s_a.hand.2 - foothoril * 7.0, ); next.hand_r.orientation = Quaternion::rotation_x(0.6 + footrotl * -1.2) * Quaternion::rotation_y(footrotl * -0.4); } else { - next.hand_r.position = Vec3::new(0.0, 0.0, 2.0); + next.hand_r.position = Vec3::new(s_a.sthr.0, s_a.sthr.1, s_a.sthr.2); next.hand_r.orientation = - Quaternion::rotation_x(1.57) * Quaternion::rotation_y(0.2); + Quaternion::rotation_x(s_a.sthr.3) * Quaternion::rotation_y(s_a.sthr.4); }; - next.control.position = Vec3::new(-4.0, 7.0, 4.0); + next.main.position = Vec3::new(0.0, 0.0, 0.0); + next.main.orientation = Quaternion::rotation_y(0.0); - next.hand_l.position = Vec3::new(0.0, 0.0, -4.0); - next.hand_l.orientation = - Quaternion::rotation_x(1.27) * Quaternion::rotation_y(0.0); + next.control.position = Vec3::new(s_a.stc.0, s_a.stc.1, s_a.stc.2); - next.main.position = Vec3::new(0.0, 0.0, 13.2); - next.main.orientation = Quaternion::rotation_y(3.14); + next.hand_l.position = Vec3::new(s_a.sthl.0, s_a.sthl.1, s_a.sthl.2); + next.hand_l.orientation = Quaternion::rotation_x(s_a.sthl.3); - next.control.orientation = Quaternion::rotation_x(-0.3 + u_slow * 0.1) - * Quaternion::rotation_y(0.15) - * Quaternion::rotation_z(u_slowalt * 0.1); + next.control.orientation = Quaternion::rotation_x(s_a.stc.3 + u_slow * 0.1) + * Quaternion::rotation_y(s_a.stc.4) + * Quaternion::rotation_z(s_a.stc.5 + u_slowalt * 0.1); }, Some(ToolKind::Shield(_)) => { next.control.position = Vec3::new(0.0, 0.0, 0.0); diff --git a/voxygen/src/anim/src/fish_medium/idle.rs b/voxygen/src/anim/src/fish_medium/idle.rs index d3d08d0986..09b0c820e6 100644 --- a/voxygen/src/anim/src/fish_medium/idle.rs +++ b/voxygen/src/anim/src/fish_medium/idle.rs @@ -31,23 +31,18 @@ impl Animation for IdleAnimation { 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.torso.position = Vec3::new(0.0, 4.5, 2.0); next.torso.orientation = 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.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.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; 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.orientation = Quaternion::rotation_y(0.0); next diff --git a/voxygen/src/anim/src/fish_medium/jump.rs b/voxygen/src/anim/src/fish_medium/jump.rs index 7fadebb750..7b54e4f476 100644 --- a/voxygen/src/anim/src/fish_medium/jump.rs +++ b/voxygen/src/anim/src/fish_medium/jump.rs @@ -31,23 +31,18 @@ impl Animation for JumpAnimation { 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.torso.position = Vec3::new(0.0, 4.5, 2.0); next.torso.orientation = 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.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.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; 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.orientation = Quaternion::rotation_y(0.0); next diff --git a/voxygen/src/anim/src/fish_medium/run.rs b/voxygen/src/anim/src/fish_medium/run.rs index 89f05d9d5d..ec875b0441 100644 --- a/voxygen/src/anim/src/fish_medium/run.rs +++ b/voxygen/src/anim/src/fish_medium/run.rs @@ -31,23 +31,18 @@ impl Animation for RunAnimation { 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.torso.position = Vec3::new(0.0, 4.5, 2.0); next.torso.orientation = 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.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.fin_l.position = Vec3::new(0.0, -11.7, 11.0) / 11.0; 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.orientation = Quaternion::rotation_y(0.0); next