Compare commits
5 Commits
a45f8f5984
...
3231e8d80d
Author | SHA1 | Date |
---|---|---|
Zemtzov7 | 3231e8d80d | |
zmv7 | cb0cac1572 | |
zmv7 | 4f7f38a16e | |
zmv7 | 4364aa2ee8 | |
zmv7 | 65830b66fa |
94
init.lua
94
init.lua
|
@ -1,63 +1,75 @@
|
||||||
minetest.register_on_mods_loaded(function()
|
core.register_on_mods_loaded(function()
|
||||||
minetest.override_item("default:snow", {
|
core.override_item("default:snow", {
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
if not minetest.check_player_privs(user:get_player_name(), {creative = true}) then itemstack:take_item()
|
local name = user:get_player_name()
|
||||||
end
|
if not name then return end
|
||||||
local pos = user:getpos()
|
if not core.check_player_privs(name, {creative = true}) then
|
||||||
local dir = user:get_look_dir()
|
itemstack:take_item()
|
||||||
local yaw = user:get_look_yaw()
|
|
||||||
if pos and dir then
|
|
||||||
pos.y = pos.y + 1.5
|
|
||||||
local obj = minetest.add_entity(pos, "snowball:ball")
|
|
||||||
if obj then
|
|
||||||
obj:setvelocity({x=dir.x * 20, y=dir.y * 20, z=dir.z * 20})
|
|
||||||
obj:setacceleration({x=dir.x * -3, y=-10, z=dir.z * -3})
|
|
||||||
obj:setyaw(yaw)
|
|
||||||
end
|
end
|
||||||
end
|
local pos = user:get_pos()
|
||||||
return itemstack
|
local dir = user:get_look_dir()
|
||||||
end,
|
local yaw = user:get_look_horizontal()
|
||||||
})
|
if pos and dir then
|
||||||
|
pos.y = pos.y + 1.5
|
||||||
|
local obj = core.add_entity(pos, "snowball:snowball", name)
|
||||||
|
if obj then
|
||||||
|
obj:set_velocity({x=dir.x * 20, y=dir.y * 20, z=dir.z * 20})
|
||||||
|
obj:set_acceleration({x=dir.x * -3, y=-10, z=dir.z * -3})
|
||||||
|
obj:set_yaw(yaw)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end})
|
||||||
end)
|
end)
|
||||||
local SNOWBALL = {
|
local snowball = {
|
||||||
physical = false,
|
physical = true,
|
||||||
timer = 0,
|
timer = 0,
|
||||||
visual = "sprite",
|
visual = "sprite",
|
||||||
visual_size = {x=0.5, y=0.5,},
|
visual_size = {x=0.5, y=0.5,},
|
||||||
textures = {'default_snowball.png'},
|
textures = {'default_snowball.png'},
|
||||||
lastpos= {},
|
collisionbox = {-0.25,-0.25,-0.25,0.25,0.25,0.25},
|
||||||
collisionbox = {0, 0, 0, 0, 0, 0},
|
pointable = false,
|
||||||
|
collide_with_objects = false,
|
||||||
}
|
}
|
||||||
SNOWBALL.on_step = function(self, dtime)
|
|
||||||
|
snowball.on_activate = function(self, staticdata)
|
||||||
|
local thrower = core.get_player_by_name(staticdata)
|
||||||
|
if thrower then
|
||||||
|
self["thrower"] = thrower
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
snowball.on_step = function(self, dtime, moveresult)
|
||||||
self.timer = self.timer + dtime
|
self.timer = self.timer + dtime
|
||||||
local pos = self.object:getpos()
|
local pos = self.object:get_pos()
|
||||||
local node = minetest.get_node(pos)
|
local yaw = self.object:get_yaw()
|
||||||
|
|
||||||
if self.timer > 0.2 then
|
if self.timer > 0.2 then
|
||||||
local objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y, z = pos.z}, 1)
|
local objs = core.get_objects_inside_radius({x = pos.x, y = pos.y-1, z = pos.z}, 1)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() == nil or obj:get_luaentity().name ~= "snowball:ball" then
|
if not obj then goto nodes end
|
||||||
obj:punch(self.object, 1.0, {
|
local prop = obj:get_properties()
|
||||||
|
if not prop then goto nodes end
|
||||||
|
if obj:is_player() or prop.collide_with_objects == true then
|
||||||
|
local thrower = self["thrower"] or self.object
|
||||||
|
obj:punch(thrower, 1.0, {
|
||||||
full_punch_interval = 1.0,
|
full_punch_interval = 1.0,
|
||||||
damage_groups= {fleshy = 1},
|
damage_groups= {fleshy = 1},
|
||||||
}, nil)
|
}, nil)
|
||||||
minetest.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8})
|
core.sound_play("default_dig_cracky", {pos = pos, gain = 0.8})
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
::nodes::
|
||||||
if self.lastpos.x ~= nil then
|
if moveresult.collides then
|
||||||
if minetest.registered_nodes[node.name].walkable then
|
if not core.is_protected(pos,"") then
|
||||||
if not minetest.is_protected(self.lastpos,"") then
|
core.add_node(pos, {name="default:snow",param2=0})
|
||||||
minetest.add_node(self.lastpos, {name="default:snow",param2=0})
|
core.check_for_falling(pos)
|
||||||
minetest.check_for_falling(self.lastpos)
|
|
||||||
end
|
|
||||||
minetest.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8})
|
|
||||||
self.object:remove()
|
|
||||||
end
|
end
|
||||||
|
core.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8})
|
||||||
|
self.object:remove()
|
||||||
end
|
end
|
||||||
self.lastpos= {x = pos.x, y = pos.y, z = pos.z}
|
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_entity("snowball:ball", SNOWBALL)
|
core.register_entity("snowball:snowball", snowball)
|
||||||
|
|
Loading…
Reference in New Issue