mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2025-01-25 00:11:07 +01:00
Fireworks now fly in arches
This commit is contained in:
parent
8b0534437a
commit
e69bd1412e
1 changed files with 29 additions and 17 deletions
|
@ -3,6 +3,8 @@ local S = minetest.get_translator(minetest.get_current_modname())
|
||||||
local tt_help = S("Flight Duration:")
|
local tt_help = S("Flight Duration:")
|
||||||
local description = S("Firework Rocket")
|
local description = S("Firework Rocket")
|
||||||
|
|
||||||
|
local TAU = 2*math.pi
|
||||||
|
|
||||||
local function explode(self, pos)
|
local function explode(self, pos)
|
||||||
-- temp code
|
-- temp code
|
||||||
vl_fireworks.generic_particle_explosion(pos)
|
vl_fireworks.generic_particle_explosion(pos)
|
||||||
|
@ -45,11 +47,18 @@ local firework_entity = {
|
||||||
vl_projectile.has_tracer,
|
vl_projectile.has_tracer,
|
||||||
|
|
||||||
function(self, dtime)
|
function(self, dtime)
|
||||||
self.object:add_velocity(vector.new(0, 5*dtime, 0)) -- TODO var. accel. TODO max speed?
|
|
||||||
if self._vl_projectile.extra then
|
if self._vl_projectile.extra then
|
||||||
self._vl_projectile.maximum_time = self._vl_projectile.extra
|
local e = self._vl_projectile.extra
|
||||||
|
self._force = e.force/10 + 5
|
||||||
|
self._vl_projectile.maximum_time = e.dur
|
||||||
|
self._rot_axis = e.rot_axis
|
||||||
|
self._dir = self.object:get_velocity():normalize()
|
||||||
self._vl_projectile.extra = nil
|
self._vl_projectile.extra = nil
|
||||||
end
|
end
|
||||||
|
if not self._dir then return end
|
||||||
|
self._dir = self._dir:rotate_around_axis(self._rot_axis, dtime/3)
|
||||||
|
local obj = self.object
|
||||||
|
obj:set_velocity((obj:get_velocity():length() + self._force*dtime) * self._dir)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
vl_projectile.collides_with_solids,
|
vl_projectile.collides_with_solids,
|
||||||
|
@ -111,6 +120,22 @@ local firework_entity = {
|
||||||
|
|
||||||
vl_projectile.register("vl_fireworks:rocket", firework_entity)
|
vl_projectile.register("vl_fireworks:rocket", firework_entity)
|
||||||
|
|
||||||
|
function vl_fireworks.shoot_firework(itemstack, pos)
|
||||||
|
local meta = itemstack:get_meta()
|
||||||
|
local rot_axis = vector.new(1,0,0)
|
||||||
|
rot_axis = rot_axis:rotate_around_axis(vector.new(0,1,0), math.random()*TAU)
|
||||||
|
vl_projectile.create("vl_fireworks:rocket", {
|
||||||
|
pos = pos,
|
||||||
|
dir = vector.new(0,1,0),
|
||||||
|
velocity = 1 + meta:get_int("vl_fireworks:force")/10,
|
||||||
|
extra = {
|
||||||
|
dur = meta:get_float("vl_fireworks:duration"),
|
||||||
|
force = meta:get_float("vl_fireworks:force"),
|
||||||
|
rot_axis = rot_axis
|
||||||
|
}
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_craftitem("vl_fireworks:rocket", { -- TODO use metadata
|
minetest.register_craftitem("vl_fireworks:rocket", { -- TODO use metadata
|
||||||
description = description,
|
description = description,
|
||||||
inventory_image = "vl_fireworks_rocket.png",
|
inventory_image = "vl_fireworks_rocket.png",
|
||||||
|
@ -128,23 +153,10 @@ minetest.register_craftitem("vl_fireworks:rocket", { -- TODO use metadata
|
||||||
end,
|
end,
|
||||||
on_place = function(itemstack, user, pointed_thing)
|
on_place = function(itemstack, user, pointed_thing)
|
||||||
local pos = pointed_thing.above
|
local pos = pointed_thing.above
|
||||||
local meta = itemstack:get_meta()
|
vl_fireworks.shoot_firework(itemstack, pos)
|
||||||
-- pos.y = pos.y + 1
|
|
||||||
vl_projectile.create("vl_fireworks:rocket", {
|
|
||||||
pos = pos,
|
|
||||||
dir = vector.new(0,1,0),
|
|
||||||
velocity = 1 + meta:get_int("vl_fireworks:force")/10,
|
|
||||||
extra = meta:get_float("vl_fireworks:duration")
|
|
||||||
})
|
|
||||||
end,
|
end,
|
||||||
_on_dispense = function(dropitem, pos, droppos, dropnode, dropdir)
|
_on_dispense = function(dropitem, pos, droppos, dropnode, dropdir)
|
||||||
local meta = itemstack:get_meta()
|
vl_fireworks.shoot_firework(dropitem, pos)
|
||||||
vl_projectile.create("vl_fireworks:rocket", {
|
|
||||||
pos = pos,
|
|
||||||
dir = vector.new(0,1,0),
|
|
||||||
velocity = 1 + meta:get_int("vl_fireworks:force")/10,
|
|
||||||
extra = meta:get_float("vl_fireworks:duration")
|
|
||||||
})
|
|
||||||
end,
|
end,
|
||||||
_vl_fireworks_std_durs_forces = { {2.2, 10}, {4.5, 20}, {6, 30} },
|
_vl_fireworks_std_durs_forces = { {2.2, 10}, {4.5, 20}, {6, 30} },
|
||||||
_vl_fireworks_tt = function(duration)
|
_vl_fireworks_tt = function(duration)
|
||||||
|
|
Loading…
Reference in a new issue