给所以东西加上重力,给无司机的船加上浮力

This commit is contained in:
zaoqi 2017-01-26 15:31:05 +08:00
parent ec014e7280
commit dde25b0798
2 changed files with 228 additions and 257 deletions

56
api.lua
View File

@ -525,3 +525,59 @@ function vehicles.on_punch(self, puncher)
vehicles.explodinate(self, 5)
end
end
function vehicles.object_no_drive(entity, dtime, def)
--definition
local decell = def.decell or 0
local gravity = def.gravity or 1
local is_watercraft = def.is_watercraft or false
local stand_anim = def.stand_anim
--variables
local velo = entity.object:getvelocity()
local pos = entity.object:getpos()
local node = minetest.get_node(pos).name
--timer dependant variables
local vec_stop = {x=velo.x*decell,y=velo.y-gravity,z=velo.z*decell}
--respond to controls
--check for water
local function is_water(node)
return node == "default:river_water_source" or node == "default:water_source" or node == "default:river_water_flowing" or node == "default:water_flowing"
end
entity.on_water = is_water(node)
entity.in_water = is_water(minetest.get_node({x=pos.x, y=pos.y+1, z=pos.z}).name) or is_water(minetest.get_node({x=pos.x, y=pos.y+2, z=pos.z}).name)
--apply water effects
if is_watercraft and entity.in_water then
entity.object:setvelocity({x=velo.x*0.9, y=velo.y+5, z=velo.z*0.9})
elseif is_watercraft and entity.on_water == false then
entity.object:setvelocity({x=velo.x*decell,y=velo.y-1,z=velo.z*decell})
elseif entity.on_water and not is_watercraft then
entity.object:setvelocity({x=velo.x*0.9, y=-1, z=velo.z*0.9})
else
--stop
entity.object:setvelocity(vec_stop)
--animation
if moving_anim ~= nil and entity.moving and not hovering then
entity.object:set_animation(stand_anim, 20, 0)
entity.moving = false
end
end
end
function vehicles.on_step(self, dtime, def, have, no)
if self.driver then
vehicles.object_drive(self, dtime, def)
if have ~= nil then
have()
end
else
vehicles.object_no_drive(self, dtime, def)
if no ~= nil then
no()
end
end
return false
end

429
init.lua
View File

@ -297,8 +297,7 @@ minetest.register_entity("vehicles:tank", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 6,
decell = 0.5,
shoots = true,
@ -308,9 +307,6 @@ minetest.register_entity("vehicles:tank", {
stand_anim = {x=1, y=1},
shoot_anim = {x=1, y=1},
})
return false
end
return true
end,
})
@ -372,8 +368,7 @@ minetest.register_entity("vehicles:assaultsuit", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 6,
decell = 0.5,
shoots = true,
@ -390,16 +385,14 @@ minetest.register_entity("vehicles:assaultsuit", {
shoot_anim2 = {x=40, y=51},
shoot_y = 3.5,
shoot_y2 = 4,
})
self.standing = false
return false
else
if not standing then
self.object:set_animation({x=1, y=1}, 20, 0)
self.standing = true
end
end
return true
},
function() self.standing = false end,
function()
if not self.standing then
self.object:set_animation({x=1, y=1}, 20, 0)
self.standing = true
end
end)
end,
})
@ -424,8 +417,7 @@ minetest.register_entity("vehicles:firetruck", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 7,
decell = 0.5,
shoots = true,
@ -435,9 +427,6 @@ minetest.register_entity("vehicles:firetruck", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -474,11 +463,10 @@ minetest.register_entity("vehicles:geep", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.6,
boost = true,
@ -486,9 +474,10 @@ minetest.register_entity("vehicles:geep", {
boost_effect = "vehicles_nitro.png",
sound_duration = 11,
driving_sound = "engine"
})
},
function()
local pos = self.object:getpos()
minetest.add_particlespawner(
minetest.add_particlespawner(
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
@ -504,9 +493,7 @@ minetest.register_entity("vehicles:geep", {
false, --collisiondetection
"vehicles_dust.png" --texture
)
return false
end
return true
end)
end,
})
@ -544,29 +531,27 @@ minetest.register_entity("vehicles:ambulance", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 13,
decell = 0.6,
moving_anim = {x=1, y=3},
stand_anim = {x=1, y=1},
driving_sound = "engine",
sound_duration = 11,
})
if not self.siren_ready then
minetest.sound_play("ambulance",
{gain = 0.1, max_hear_distance = 3, loop = false})
self.siren_ready = true
minetest.after(4, function()
self.siren_ready = false
},
function()
if not self.siren_ready then
minetest.sound_play("ambulance",
{gain = 0.1, max_hear_distance = 3, loop = false})
self.siren_ready = true
minetest.after(4, function()
self.siren_ready = false
end)
end
end)
end
return false
end
return true
end,
})
@ -603,11 +588,10 @@ minetest.register_entity("vehicles:ute", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.6,
boost = true,
@ -615,27 +599,26 @@ minetest.register_entity("vehicles:ute", {
boost_effect = "vehicles_nitro.png",
driving_sound = "engine",
sound_duration = 11,
})
local pos = self.object:getpos()
},
function()
local pos = self.object:getpos()
minetest.add_particlespawner(
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.5, --minexptime
1, --maxexptime
10, --minsize
15, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
return false
end
return true
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.5, --minexptime
1, --maxexptime
10, --minsize
15, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
end)
end,
})
@ -675,8 +658,7 @@ minetest.register_entity("vehicles:ute2", {
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.6,
boost = true,
@ -685,9 +667,6 @@ minetest.register_entity("vehicles:ute2", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -721,8 +700,7 @@ minetest.register_entity("vehicles:astonmaaton", {
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.8,
boost = true,
@ -731,9 +709,6 @@ minetest.register_entity("vehicles:astonmaaton", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -764,11 +739,10 @@ minetest.register_entity("vehicles:nizzan", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.8,
boost = true,
@ -776,27 +750,26 @@ minetest.register_entity("vehicles:nizzan", {
boost_effect = "vehicles_nitro.png",
driving_sound = "engine",
sound_duration = 11,
})
local pos = self.object:getpos()
},
function()
local pos = self.object:getpos()
minetest.add_particlespawner(
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.5, --minexptime
1, --maxexptime
10, --minsize
15, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
return false
end
return true
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.5, --minexptime
1, --maxexptime
10, --minsize
15, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
end)
end,
})
@ -826,12 +799,11 @@ minetest.register_entity("vehicles:nizzan2", {
end
end,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.8,
boost = true,
@ -839,27 +811,26 @@ minetest.register_entity("vehicles:nizzan2", {
boost_effect = "vehicles_nitro.png",
driving_sound = "engine",
sound_duration = 11,
})
local pos = self.object:getpos()
},
function()
local pos = self.object:getpos()
minetest.add_particlespawner(
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.2, --minexptime
0.5, --maxexptime
20, --minsize
25, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
return false
end
return true
15, --amount
1, --time
{x=pos.x, y=pos.y, z=pos.z}, --minpos
{x=pos.x, y=pos.y, z=pos.z}, --maxpos
{x=0, y=0, z=0}, --minvel
{x=0, y=0, z=0}, --maxvel
{x=-0,y=-0,z=-0}, --minacc
{x=0,y=0,z=0}, --maxacc
0.2, --minexptime
0.5, --maxexptime
20, --minsize
25, --maxsize
false, --collisiondetection
"vehicles_dust.png" --texture
)
end)
end,
})
@ -890,11 +861,10 @@ minetest.register_entity("vehicles:lambogoni", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.8,
boost = true,
@ -903,9 +873,6 @@ minetest.register_entity("vehicles:lambogoni", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -936,11 +903,10 @@ minetest.register_entity("vehicles:lambogoni2", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.8,
boost = true,
@ -949,9 +915,6 @@ minetest.register_entity("vehicles:lambogoni2", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -982,11 +945,10 @@ minetest.register_entity("vehicles:masda", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.95,
boost = true,
@ -995,14 +957,53 @@ minetest.register_entity("vehicles:masda", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
vehicles.register_spawner("vehicles:masda", "Masda (pink)", "vehicles_masda_inv.png")
minetest.register_entity("vehicles:masda2", {
visual = "mesh",
mesh = "masda.b3d",
textures = {"vehicles_masda2.png"},
velocity = 15,
acceleration = -5,
stepheight = step,
hp_max = 200,
physical = true,
collisionbox = {-1, 0, -1, 1.3, 1, 1},
on_rightclick = function(self, clicker)
if self.driver and clicker == self.driver then
object_detach(self, clicker, {x=1, y=0, z=1})
elseif not self.driver then
vehicles.object_attach(self, clicker, {x=0, y=5, z=4}, false, {x=0, y=2, z=4})
minetest.sound_play("engine_start",
{gain = 4, max_hear_distance = 3, loop = false})
self.sound_ready = false
minetest.after(14, function()
self.sound_ready = true
end)
end
end,
on_activate = function(self)
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.85,
boost = true,
boost_duration = 4,
boost_effect = "vehicles_nitro.png",
driving_sound = "engine",
sound_duration = 11,
})
end,
})
vehicles.register_spawner("vehicles:masda2", "Masda (orange)", "vehicles_masda_inv2.png")
minetest.register_entity("vehicles:policecar", {
visual = "mesh",
mesh = "policecar.b3d",
@ -1027,12 +1028,11 @@ minetest.register_entity("vehicles:policecar", {
end
end,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 16,
decell = 0.95,
boost = true,
@ -1041,9 +1041,6 @@ minetest.register_entity("vehicles:policecar", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1073,12 +1070,11 @@ minetest.register_entity("vehicles:musting", {
end
end,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.85,
boost = true,
@ -1087,9 +1083,6 @@ minetest.register_entity("vehicles:musting", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1120,11 +1113,10 @@ minetest.register_entity("vehicles:musting2", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.85,
boost = true,
@ -1133,9 +1125,6 @@ minetest.register_entity("vehicles:musting2", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1177,11 +1166,10 @@ minetest.register_entity("vehicles:fewawi", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.95,
boost = true,
@ -1190,9 +1178,6 @@ minetest.register_entity("vehicles:fewawi", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1234,11 +1219,10 @@ minetest.register_entity("vehicles:fewawi2", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.95,
boost = true,
@ -1247,9 +1231,6 @@ minetest.register_entity("vehicles:fewawi2", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1279,12 +1260,11 @@ minetest.register_entity("vehicles:pooshe", {
end
end,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.95,
boost = true,
@ -1293,9 +1273,6 @@ minetest.register_entity("vehicles:pooshe", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
@ -1326,11 +1303,10 @@ minetest.register_entity("vehicles:pooshe2", {
end,
on_punch = vehicles.on_punch,
on_activate = function(self)
self.nitro = true
self.nitro = true
end,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 15,
decell = 0.95,
boost = true,
@ -1339,60 +1315,11 @@ minetest.register_entity("vehicles:pooshe2", {
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
vehicles.register_spawner("vehicles:pooshe2", "Pooshe (yellow)", "vehicles_pooshe_inv2.png")
minetest.register_entity("vehicles:masda2", {
visual = "mesh",
mesh = "masda.b3d",
textures = {"vehicles_masda2.png"},
velocity = 15,
acceleration = -5,
stepheight = step,
hp_max = 200,
physical = true,
collisionbox = {-1, 0, -1, 1.3, 1, 1},
on_rightclick = function(self, clicker)
if self.driver and clicker == self.driver then
object_detach(self, clicker, {x=1, y=0, z=1})
elseif not self.driver then
vehicles.object_attach(self, clicker, {x=0, y=5, z=4}, false, {x=0, y=2, z=4})
minetest.sound_play("engine_start",
{gain = 4, max_hear_distance = 3, loop = false})
self.sound_ready = false
minetest.after(14, function()
self.sound_ready = true
end)
end
end,
on_activate = function(self)
self.nitro = true
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
speed = 15,
decell = 0.85,
boost = true,
boost_duration = 4,
boost_effect = "vehicles_nitro.png",
driving_sound = "engine",
sound_duration = 11,
})
return false
end
return true
end,
})
vehicles.register_spawner("vehicles:masda2", "Masda (orange)", "vehicles_masda_inv2.png")
minetest.register_entity("vehicles:boat", {
visual = "mesh",
mesh = "boat.b3d",
@ -1412,18 +1339,12 @@ minetest.register_entity("vehicles:boat", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 10,
decell = 0.85,
is_watercraft = true,
gravity = 0,
})
return false
else
self.object:setvelocity({x=0, y=0, z=0})
end
return true
end,
})
@ -1452,8 +1373,7 @@ minetest.register_entity("vehicles:jet", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.driver then
vehicles.object_drive(self, dtime, {
return vehicles.on_step(self, dtime, {
speed = 14,
decell = 0.95,
shoots = true,
@ -1464,10 +1384,6 @@ minetest.register_entity("vehicles:jet", {
fly = true,
fly_mode = "rise",
})
return false
end
self.object:setvelocity({x=0, y=-1, z=0})
return true
end,
})
@ -1492,25 +1408,24 @@ minetest.register_entity("vehicles:plane", {
end,
on_punch = vehicles.on_punch,
on_step = function(self, dtime)
if self.anim and not self.driver then
self.object:set_animation({x=1, y=1}, 5, 0)
end
if self.driver then
vehicles.object_drive(self, dtime, {
if self.anim and not self.driver then
self.object:set_animation({x=1, y=1}, 5, 0)
end
return vehicles.on_step(self, dtime, {
speed = 10,
decell = 0.95,
fly = true,
fly_mode = "hold",
})
if not self.anim then
self.object:set_animation({x=1, y=9}, 20, 0)
self.anim = true
end
return false
else
self.anim = false
end
return true
},
function()
if not self.anim then
self.object:set_animation({x=1, y=9}, 20, 0)
self.anim = true
end
end,
function()
self.anim = false
end)
end,
})