From aa2693795d6ba8610f8807526e4d003d0c2dcb04 Mon Sep 17 00:00:00 2001 From: epCode <64379263+epCode@users.noreply.github.com> Date: Mon, 10 Oct 2022 13:42:01 -0700 Subject: [PATCH] Add Spider Jockey --- mods/ENTITIES/mcl_mobs/api.lua | 13 ++++++++++++ .../mobs_mc/models/mobs_mc_skeleton.b3d | Bin 184408 -> 184760 bytes .../mobs_mc/models/mobs_mc_spider.b3d | Bin 52909 -> 52909 bytes mods/ENTITIES/mobs_mc/skeleton+stray.lua | 20 +++++++++++++++++- mods/ENTITIES/mobs_mc/spider.lua | 13 ++++++++++-- 5 files changed, 43 insertions(+), 3 deletions(-) diff --git a/mods/ENTITIES/mcl_mobs/api.lua b/mods/ENTITIES/mcl_mobs/api.lua index d0972d050c..d09a9adfed 100644 --- a/mods/ENTITIES/mcl_mobs/api.lua +++ b/mods/ENTITIES/mcl_mobs/api.lua @@ -467,6 +467,10 @@ local set_animation = function(self, anim, fixed_frame) return end + if self.jockey then + anim = "jockey" + end + if flight_check(self) and self.fly and anim == "walk" then anim = "fly" end self._current_animation = self._current_animation or "" @@ -3459,6 +3463,11 @@ end local mob_detach_child = function(self, child) + if self.detach_child then + if self.detach_child(self, child) then + return + end + end if self.driver == child then self.driver = nil end @@ -3807,6 +3816,9 @@ local mob_step = function(self, dtime) _locked_object_eye_height = self._locked_object:get_properties().eye_height end local self_rot = self.object:get_rotation() + if self.object:get_attach() then + self_rot = self.object:get_attach():get_rotation() + end local player_pos = self._locked_object:get_pos() local direction_player = vector.direction(vector.add(self.object:get_pos(), vector.new(0, self.head_eye_height*.7, 0)), vector.add(player_pos, vector.new(0, _locked_object_eye_height, 0))) local mob_yaw = math.deg(-(-(self_rot.y)-(-minetest.dir_to_yaw(direction_player))))+self.head_yaw_offset @@ -4094,6 +4106,7 @@ minetest.register_entity(name, { on_die = def.on_die, spawn_small_alternative = def.spawn_small_alternative, do_custom = def.do_custom, + detach_child = def.detach_child, jump_height = def.jump_height or 4, -- was 6 rotate = math.rad(def.rotate or 0), -- 0=front, 90=side, 180=back, 270=side2 lifetimer = def.lifetimer or 57.73, diff --git a/mods/ENTITIES/mobs_mc/models/mobs_mc_skeleton.b3d b/mods/ENTITIES/mobs_mc/models/mobs_mc_skeleton.b3d index f4ff18e25d0c956410b2c5831f383d2616a6f7dc..b390fb310adba6fb892b959bcab17afd1a12bdfa 100644 GIT binary patch delta 3765 zcma)83sh5A7Jc_ZA|UcnAz&);-?1P<5{f3kd;X^M=Vy(|_^BWtJ1#%99ko)?7X{a7 zYg-lcs>@cM*#aw=ai-?1B->yNq>5Xx1uADe`?rXT}EGVuwMQCW!q5z z|E1sBrdRXw1?77mKScam;ViyVc|v#XYPh~NrJubVuou!;Q&rGZA=z@;`oP5tI56=w zV<+)%XJ66PWhwMa%0}A%3|Pm2Pnv|((ZV}#|7djq4hLcbHf#CzAbXdt`oS$-YJPHY z#?>*TqIkx+SOxa!n0d?93D73i8bLAw2X3n|)cYmze#{j?)aFWhpa?438ddbcp<|`o2Qz>T5N_I1|sw zV^CX>!37+XP8JzDAj~0_sUqsYk+OLfYfB`W2tIiNh_GUIoCJt7a4KnX$|H>wskgQF1sZV@!l0T3Rw6cI45~Iup+Z$t9Tn<^FSZlkY-0EH^GA~1&&5AY_wzHXek`GqsQc|KFErc*vtzYiaww~+g#O;j2{yKY zX|}55Q$pGKN^&~z+rIaWmz^R%gITIzB`ju_s$jpSR0TH}S6>G`kSjcHyVI!Y7Wp;K zK@Ck&Cm=DmIaK+TF&fP8rjKs;tIb&(%C=QOWaaisV`rDht4fj^{>hrENrqzTvkpUl zw^vH8AuA#j{ZS`oIthK)2F1?%#bghk5G**VFV*z8*o~7UOmx2k9OYfQ>i7D4P{G0S zB14zUuH7Ne?GJO|ui1;mowdvd+wF2`i)C!s6JSevc*VyO@9Y6T7Q0KvVzKb||0c}b z*l8YR9tYm-20sCoz0^XQA1P`nh}!MCsQvIEsv*DT=x)Ftdm4b){SRT~=0T&}4UnvWyb9_Yb7D{x#77>Nsfh`U^8wWU4aUaLYp_$ZgWKsL%WyRnudXSMjoj7S9#L;$p&uH~?@|#um!hdF4f-p$oux&dl#c>;-#?8)RZUc>ZUF_aaUKtpCxo zT0Du6*P8^cXfLmvgvdK(FrH1m#J(ACk~6Lc?0rZWPb*)ncdMZI-s%eEgz>a`#U}}0 z-ogNxn6a!=ME!iP3Kb1!V-z%s-R~wreN2h*jYjiFEW}A-LPlZk5XJ;HT^YL` zMF)$fhm5HF-RD};j?MD7{lo8w1(&7ws|&8DVXhsHY%P+a@`$aFu^#eYFB!;d2MC8) z6ut|vb-l6dSQJ$y-UC;8ZQO~sr(?*8p{(j8T^oz)!cp&lzK!)#{IR2Ye8Fu^pGpYAh z#@bNf8rGdhCxgJkB6?iyCuk{~zK9NInvJv%HFNkfG{}^Q%7LP0xJA$rq>MQ?(pWaV zjVj|!I?@m&pciHEN`dO*1hnHaL@D6$%n!iod)Ug^fkiZSS36Zw&Vm7k;d&7ZX&k9= zyWH3A4yme;rr_P+ry4p>(IT!h_^}NZs%C#M(_qEjnDs_~Hsd&?zRye($kXf#GtE$R zj`}erfR)x!jg)SoS%hUt)L(HSyQO+5tG3eNftbhV@LJ5yTLFKWj7k~Ew%1ZkU?yie zI5)GUdNo^E3!b8Dd+Swfs2Kt}Y9ZivWK=^GyKDs{a=_riShz%E$xfCk(L(q+A;G+x zx`alJd!96|jxLW>nyNW&tZtW?4ndKXN>dHT&9uOKOo&%!q%+kZ1f(XPdZZ2lsWHlv t$jos~?g+tNrNQ9l3&s@&j|sj~W_GEKj#6^43#k?3qwI0*ZrL&De*x0&n3Dhi delta 3166 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 delta 7021 zcmb7|du&ui6vjsjwNL~qAVspcq7;j0&RIs5{!yn zF1Xx+?VusK0E;lDS<%pN24khe_+q)V>^Cl$?MNK4P{+iWYe1I^H@$zoH(~cNPdxdW z)~$nKMDxL!-jW9@eL4Qjf{zF)e)*||2>VQL*F`Xl;(b228^z<>ehL{AHk+)!H%!=C zV2W>A)8rq$aids&XL*jXYGl**-Q}~fE#rDW^+UU662%dS%q6Zr*oX~NOK0eYeX-$* zJ`=Iw{3q@T851t%(l#HIWJ9qFF1zfF?|=cBJv0o%Sn0uv+xI1iX^fxG_=WF&_8{Yj&eVpC2^Z5^St9;!b`@sa`8|li8O5hm_r#1> zj7)`$2^Vu|T`m~6q_NB17;<9Fo|zm5c+{uaoZWv+79ZNq&~zop=*O%5 zLzVq7l4Wzx=JFXgZK=da_H;WEGA3NirF|thgR!qH?)xJx0Pa7%)#+Q7=HT~n z%Qe|T#t*Bx$nJgS>yPspkGXvuiWgtosP8-7W1CUNww5BUUpOUzr~2=jS-E_~^7w}h z0ld{seJ6*I2^VvTH{CiN8_qvoskPvY;?2+AgZ=hw_`N-Uja@9%N>MC!xnS89x@B(+ zF)?NjO)-@othn7zf>?2TI}+O#(mi$!=yGAQYy8}i>oCqa^@H`9&`vuD?5EOxTPvK4xht}FGt#AJ7ux`lyPK29MHAN;ZLVyOf$Dugn8o zEUN8~Uz(5K0Wnykc*Xu+_@(I_b0}m?xR^`pa>3=6URaV1xH06!m_0S+RC=)Dc0=wbQ*6pQL@^ej(ps1KRq&pb@ecgL{Jg^ahoO7DE; zuNMjt+f2tP^`B0*m@=N)NKfkplh*1(s`W?lOP12py2V=&GA3NirTuvYz5Sm&@|D(t zGm5|dc|#!K9zTBn_7E}wFv?tFmkTbp?2REN#)^i9zyBzw(t{PZ8-iGIdppwF4pPRh z0ZSK=ihs1b!P~rewa2a)>NA$shon7V!FzSSVS(rf*^FOXU<>^r23o_?9@H78u%E33 z7Km?lH{=4T4|xC^HWeU<4NH4a=wdLSsSCs*XsFr0X;{R^e!xI$SlTOQk_rh%#V!|I zZrK~dA`G`PL&Go(2egL?q_7(r7tD4fwk=F!L)U;V7rMHncj>^@UgIG6&nsVFN96%K z)hg?J1AVVt|KL<>o!{|yZJ;OC|A>LuFoku7jncyqGg@H2ce+dFfbGP7@Oy$7Xpu<< zP+?&K7O|*UPmK*9!%a5nO?=oS2U^2$J12vFrq1^y*3>q3|q8rn}u$>v2;db^g zzye|S18pEeXKoIyA!yqVIguEqHp9@y`AxFj2Fxn2Zl1Q|hK3&hc+6ka4u0l8*~Nor zR>=SR=^x!jd-{{BY3{5W-rSkJPzRp0wk&yVX7*Lx6VK2+dEab#^4e7PqL|`L-(md| zPuL@-QPk0%$!k;D%9!Fza2^w09MdQ|VejO%scfH^;>?_yT4mN%GoMwqHzf zCOtg)gacw4MJK#8d2K2?Fs3-O_dF&X6w@d=;bqBdQ`x~W#Tj*Vat~86jiM6{NnV@E zULI4N8C9En!Yg7LMJF7Zyf&4+GNw3l_&g>Y7Skv?VNLSdRCahwai(oV|M5wG6V%2u L${roD{jL81m3aa; diff --git a/mods/ENTITIES/mobs_mc/skeleton+stray.lua b/mods/ENTITIES/mobs_mc/skeleton+stray.lua index ce80a680b6..3954edf685 100644 --- a/mods/ENTITIES/mobs_mc/skeleton+stray.lua +++ b/mods/ENTITIES/mobs_mc/skeleton+stray.lua @@ -34,7 +34,6 @@ local skeleton = { "mcl_bows_bow_0.png", -- bow "mobs_mc_skeleton.png", -- skeleton } }, - visual_size = {x=1, y=1}, makes_footstep_sound = true, textures = { { @@ -81,11 +80,27 @@ local skeleton = { run_speed = 30, shoot_start = 70, shoot_end = 90, + jockey_start = 172, + jockey_end = 172, die_start = 160, die_end = 170, die_speed = 15, die_loop = false, }, + jock = "mobs_mc:spider", + on_spawn = function(self) + self.jockey = false + if math.random(100) == 1 then -- 1% like from MCwiki + self.jockey = true + local jock = minetest.add_entity(self.object:get_pos(), "mobs_mc:spider") + jock:get_luaentity().docile_by_day = false + self.object:set_attach(jock, "", vector.new(0,0,0), vector.new(0,0,0)) + end + return true + end, + on_detach=function(self, parent) + self.jockey = false + end, ignited_by_sunlight = true, view_range = 16, fear_height = 4, @@ -93,6 +108,9 @@ local skeleton = { arrow = "mcl_bows:arrow_entity", shoot_arrow = function(self, pos, dir) if mod_bows then + if self.attack then + self.object:set_yaw(minetest.dir_to_yaw(vector.direction(self.object:get_pos(), self.attack:get_pos()))) + end -- 2-4 damage per arrow local dmg = math.max(4, math.random(2, 8)) mcl_bows.shoot_arrow("mcl_bows:arrow", pos, dir, self.object:get_yaw(), self.object, nil, dmg) diff --git a/mods/ENTITIES/mobs_mc/spider.lua b/mods/ENTITIES/mobs_mc/spider.lua index 9a0f49395f..e94f804d65 100644 --- a/mods/ENTITIES/mobs_mc/spider.lua +++ b/mods/ENTITIES/mobs_mc/spider.lua @@ -14,7 +14,7 @@ local S = minetest.get_translator("mobs_mc") minetest.register_entity("mobs_mc:spider_eyes", { visual = "mesh", mesh = "mobs_mc_spider.b3d", - visual_size = {x=1.01, y=1.01}, + visual_size = {x=1.01/3, y=1.01/3}, textures = { "mobs_mc_spider_eyes.png", }, @@ -44,6 +44,7 @@ local spider = { xp_max = 5, armor = {fleshy = 100, arthropod = 100}, on_spawn = function(self) + self.object:set_properties({visual_size={x=1,y=1}}) local spider_eyes=false for n = 1, #self.object:get_children() do local obj = self.object:get_children()[n] @@ -55,6 +56,14 @@ local spider = { minetest.add_entity(self.object:get_pos(), "mobs_mc:spider_eyes"):set_attach(self.object, "body.head", vector.new(0,-0.98,2), vector.new(90,180,180)) end end, + on_die=function(self) + if self.object:get_children() and self.object:get_children()[1] then + self.object:get_children()[1]:set_detach() + end + end, + detach_child=function(self, child) + child:get_luaentity().jockey = false + end, head_swivel = "Head_Control", bone_eye_height = 1, curiosity = 10, @@ -65,7 +74,7 @@ local spider = { textures = { {"mobs_mc_spider.png"}, }, - visual_size = {x=3, y=3}, + visual_size = {x=1, y=1}, makes_footstep_sound = false, sounds = { random = "mobs_mc_spider_random",