From 912238ccd984c1fed1e41b03ce82d2e516282829 Mon Sep 17 00:00:00 2001 From: epCode Date: Wed, 24 Mar 2021 16:25:39 -0700 Subject: [PATCH] Artic fox and tweaks --- fox.lua | 35 +++++++++++++++++------------- textures/extra_mobs_artic_fox.png | Bin 0 -> 984 bytes 2 files changed, 20 insertions(+), 15 deletions(-) create mode 100644 textures/extra_mobs_artic_fox.png diff --git a/fox.lua b/fox.lua index fe50a64..8089561 100644 --- a/fox.lua +++ b/fox.lua @@ -12,19 +12,12 @@ local atan = function(x) end end - local S = minetest.get_translator("extra_mobs") --################### --################### fox --################### -local dir_to_pitch = function(dir) - local dir2 = vector.normalize(dir) - local xz = math.abs(dir.x) + math.abs(dir.z) - return -math.atan2(-dir.y, xz) -end - local fox = { type = "monster", passive = false, @@ -68,6 +61,12 @@ local fox = { lay_end = 34, }, runaway = true, + on_spawn = function(self) + if minetest.find_node_near(self.object:get_pos(), 4, "mcl_core:snow") ~= nil or minetest.find_node_near(self.object:get_pos(), 4, "mcl_core:dirt_with_grass_snow") ~= nil then + minetest.chat_send_all("true") + self.object:set_properties({textures={"extra_mobs_artic_fox.png"}}) + end + end, do_custom = function(self) if self.state ~= "attack" and math.random(1, 5000) == 1 then self.state = "lay" @@ -79,17 +78,20 @@ local fox = { end) end for _,object in pairs(minetest.get_objects_inside_radius(self.object:get_pos(), 8)) do + if not object:is_player() and object:get_luaentity().name == "extra_mobs:fox" and self.state ~= "attack" and math.random(1, 500) == 1 then + self.horny = true + end + local lp = object:get_pos() + local s = self.object:get_pos() + local vec = { + x = lp.x - s.x, + y = lp.y - s.y, + z = lp.z - s.z + } if object:is_player() and not object:get_player_control().sneak then - local lp = object:get_pos() - local s = self.object:get_pos() - local vec = { - x = lp.x - s.x, - y = lp.y - s.y, - z = lp.z - s.z - } self.state = "runaway" self.object:set_rotation({x=0,y=(atan(vec.z / vec.x) + 3 * pi / 2) - self.rotate,z=0}) - if self.reach > vector.distance(self.object:get_pos(), object:get_pos()) and self.timer > .9 then + if self.reach > vector.distance(self.object:get_pos(), object:get_pos()) and self.timer > .9 and minetest.is_creative_enabled() == false then self.timer = 0 object:punch(self.object, 1.0, { full_punch_interval = 1.0, @@ -112,5 +114,8 @@ mobs:register_mob("extra_mobs:fox", fox) -- Regular spawning in the Nether mobs:spawn_specific("extra_mobs:fox", {"mcl_core:dirt_with_grass"}, {"air"}, 0, minetest.LIGHT_MAX+1, 30, 6000, 3, 0, 500) +mobs:spawn_specific("extra_mobs:fox", {"mcl_core:dirt_with_grass_snow"}, {"air"}, 0, minetest.LIGHT_MAX+1, 30, 6000, 3, 0, 500) +mobs:spawn_specific("extra_mobs:artic_fox", {"mcl_core:snow"}, {"air"}, 0, minetest.LIGHT_MAX+1, 30, 6000, 3, 0, 500) + -- spawn eggs mobs:register_egg("extra_mobs:fox", S("Fox"), "extra_mobs_spawn_icon_fox.png", 0) diff --git a/textures/extra_mobs_artic_fox.png b/textures/extra_mobs_artic_fox.png new file mode 100644 index 0000000000000000000000000000000000000000..3ed9aa2c5b0ea6b6cb0556481a537f6e2170ae2c GIT binary patch literal 984 zcmV;}11J26P) zK~z}7)mTq!+b|UW*|q23D#j%pCCO;nA*F1GG6uWu+w3duy4}iPj2;$7a~La2LRdnK zqnNmE>KztovMf7tl6KvL5Lxf(`Tc)SHt>ibj^i}*yj*7Rp6eR&8B3FQDm@#TxO)dv zNBB675y!Dgp)%a#P+&|c0HE8wz?f40W4Lbjg0Dr~LxJ(X=YX-s`nhn3!Vs?K@#ord zp**|TtKpCkLtEHv7;FvYxT^(ynYNxjJj=e;g1>(t^~8bs03RV zdFG!eAOj1bGD~mcg>_+5NdYn50brISnGo7FR1v;PBf~67GGR1Jl5J&O0@xD;pCt)y z7+=%m?^|0&$CRebsl*fe>b za0UKYY>2aym>O@sWE)Q85sCtNM$!2jmxs7Y>~nrEJWY(s^OE>ko!d^(1+aWO%D&D%{z1 zQ=W~2fC49K+904fAp6;~D`D%ljYt?K>$Y7yPG4U2(#xw}x@s8drZn<=^!?|E@BO&` zrle&wMd34=Ot?qPhpZTKf}R|oY12kw$OSLWft5u80PR*&{7jPe2Sc2nb_^XFRTx$2 z)V@!Y6E4e#(PRSG^NKxiK=v~X`h%g8MvQS4%_jE=S!j8j7kQiO80_-;*lso9`$Wt7 z?N+n2G9EP=6%>rJ&kQ0?vt$zc@DE=}>w1j~G0000