Compare commits

...

11 Commits

Author SHA1 Message Date
David Leal
5b95630b4e
Remove non-free textures
Some checks failed
luacheck / luacheck (push) Has been cancelled
I really can't believe I missed the textures as well.
2024-02-14 22:26:46 -06:00
David Leal
c62f4ae73f
Remove non-free models
These non-free vehicles were removed in the past, but for some reason I forgot to remove the models, too.
2024-02-14 18:56:34 -06:00
David Leal
7ec209abd9
Use a faster and newer LuaCheck 2023-09-11 19:59:30 -06:00
David Leal
8ace6437bc
Add Spanish translation (#19) 2023-09-06 15:49:43 -06:00
David Leal
cbeb67ba8f
Update known issues section 2023-05-23 10:13:59 -06:00
David Leal
daa5845666
Cleanup and use vector.new where possible (#16) 2023-04-04 12:24:09 -06:00
David Leal
6b3141fd69
Complete multiple passenger support (#14) 2023-01-19 13:46:49 -06:00
David Leal
dbd0d395c6
Version 2.4.0 (#12)
- Added new API support for `lib_mount`.
- Customizable HP/Armor for all vehicles. Players will be affected.
- Short and tweak the code.
- Cars can now be killed by players.
- Support for 3+ passengers (beta).
2022-12-18 16:22:44 -06:00
David Leal
906402e763
Merge branch 'master' of https://github.com/minetest-mods/vehicle_mash 2022-11-30 10:49:48 -06:00
David Leal
c05f94c1a4
Add extra links in LICENSE.md 2022-11-30 10:49:33 -06:00
Lazerbeak12345
f14cf378ba
Fix incorrect passenger ordering (#11)
This actually also fixes a bug where an infinite number of passengers could be mounted to the last passenger seat.
2022-11-30 10:23:08 -06:00
49 changed files with 279 additions and 11633 deletions

View File

@ -1,11 +0,0 @@
on: [push, pull_request]
name: build
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- name: lint
uses: Roang-zero1/factorio-mod-luacheck@master
with:
luacheckrc_url: ""

10
.github/workflows/luacheck.yml vendored Normal file
View File

@ -0,0 +1,10 @@
name: luacheck
on: [push, pull_request]
jobs:
luacheck:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Luacheck
uses: lunarmodules/luacheck@master

View File

@ -11,5 +11,5 @@ read_globals = {
table = {fields = {"copy", "getn"}}, table = {fields = {"copy", "getn"}},
"minetest", "lib_mount", "minetest", "lib_mount",
"core", "core", "vector"
} }

View File

@ -7,20 +7,22 @@ Copyright (C) 2019-2022 Panquesito7 (halfpacho@gmail.com) and contributors
- <https://forum.minetest.net/viewtopic.php?f=13&t=7407> - <https://forum.minetest.net/viewtopic.php?f=13&t=7407>
- License: - License:
- No info given in that mod but I am going to assume the credit for the original model goes to: - No info given in that mod but I am going to assume the credit for the original model goes to:
- Melcor and his CAR01 model - Melcor and his CAR01 model (MELKAR)
- <https://forum.minetest.net/viewtopic.php?f=9&t=6512> - <https://forum.minetest.net/viewtopic.php?f=9&t=6512>
- License: CC-BY-NC-SA - License: [CC BY-NC-SA 3.0](https://creativecommons.org/licenses/by-nc-sa/3.0/)
- MeseCars from: "Mesecars" by paramat - MeseCars from: "Mesecars" by paramat
- <https://forum.minetest.net/viewtopic.php?f=11&t=7967> - <https://forum.minetest.net/viewtopic.php?f=11&t=7967>
- Licenses: Code WTFPL, textures CC BY-SA - Licenses: Code WTFPL, textures CC BY-SA
- Boats from "Boats" by PilzAdam - Boats from "Boats" by PilzAdam
- <https://github.com/PilzAdam/boats>
- textures: Zeg9 - textures: Zeg9
- model: thetoon and Zeg9, modified by PavelS(SokolovPavel) - model: thetoon and Zeg9, modified by PavelS(SokolovPavel)
- License: WTFPL - License: [WTFPL](http://www.wtfpl.net/)
- Hovercraft from "Hovercraft" by Stuart Jones - Hovercraft from "Hovercraft" by Stuart Jones
- <https://github.com/stujones11/hovercraft>
- Licenses: - Licenses:
- textures: CC-BY-SA - textures: CC-BY-SA
- sounds: freesound.org - sounds: freesound.org

View File

@ -1,6 +1,6 @@
# Vehicle Mash [![Build status](https://github.com/minetest-mods/vehicle_mash/workflows/build/badge.svg)](https://github.com/minetest-mods/vehicle_mash/actions) [![ContentDB](https://content.minetest.net/packages/Panquesito7/vehicle_mash/shields/downloads/)](https://content.minetest.net/packages/Panquesito7/vehicle_mash/) # Vehicle Mash [![LuaCheck status](https://github.com/minetest-mods/vehicle_mash/workflows/luacheck/badge.svg)](https://github.com/minetest-mods/vehicle_mash/actions) [![ContentDB](https://content.minetest.net/packages/Panquesito7/vehicle_mash/shields/downloads/)](https://content.minetest.net/packages/Panquesito7/vehicle_mash/)
- Current version: 2.3.0 - Current version: 2.4.0
- By [blert2112](https://github.com/blert2112), and handed over to [Panquesito7](https://github.com/Panquesito7). - By [blert2112](https://github.com/blert2112), and handed over to [Panquesito7](https://github.com/Panquesito7).
![Screenshot](https://raw.githubusercontent.com/minetest-mods/vehicle_mash/master/screenshot.png) ![Screenshot](https://raw.githubusercontent.com/minetest-mods/vehicle_mash/master/screenshot.png)
@ -39,14 +39,14 @@ For further information or help, see:\
## Known issues ## Known issues
- Attachments incorrectly ordered. - None as of now.
## License ## License
Copyright (C) 2015-2016 blert2112 and contributors\ Copyright (C) 2015-2016 blert2112 and contributors\
Copyright (C) 2019-2022 Panquesito7 (halfpacho@gmail.com) and contributors Copyright (C) 2019-2022 Panquesito7 (halfpacho@gmail.com) and contributors
All licenses of previous works, of course, apply. (see credits below) All licenses of previous works, of course, apply (see credits below).
As far as the work I did... It's really just a fork of a fork of a fork of a fork, tossed it all into a blender and spun it on puree for a bit. Baked it for a while and set it on the counter to cool. What I mean is, make what you will of it, it matters not to me. As far as the work I did... It's really just a fork of a fork of a fork of a fork, tossed it all into a blender and spun it on puree for a bit. Baked it for a while and set it on the counter to cool. What I mean is, make what you will of it, it matters not to me.
See [`LICENSE.md`](LICENSE.md) for more information. See [`LICENSE.md`](LICENSE.md) for more information.
@ -67,6 +67,14 @@ There are no pending tasks to do yet.
## Changelog ## Changelog
v2.4.0 1/12/2022
- Added new API support for `lib_mount`.
- Customizable HP/Armor for all vehicles. Players will be affected.
- Short and tweak the code.
- Cars can now be killed by players.
- Support for 3+ passengers (beta).
v2.3.0 2/12/2021 v2.3.0 2/12/2021
- Improved formatting in `README.md`. - Improved formatting in `README.md`.
@ -149,35 +157,3 @@ v1.0 4/24/2015
Report bugs or suggest ideas by [creating an issue](https://github.com/minetest-mods/vehicle_mash/issues/new).\ Report bugs or suggest ideas by [creating an issue](https://github.com/minetest-mods/vehicle_mash/issues/new).\
If you know how to fix an issue, consider opening a [pull request](https://github.com/minetest-mods/vehicle_mash/compare). If you know how to fix an issue, consider opening a [pull request](https://github.com/minetest-mods/vehicle_mash/compare).
## Credit where credit is due
- Black, Blue, Brown, Cyan, Dark Green, Dark Grey, Green, Grey, Magenta, Orange, Pink, Red, Violet, White, Yellow, Hot Rod, Nyan Ride, Oerkki Bliss, and Road Master from: "Car" by Esteban
- <https://forum.minetest.net/viewtopic.php?f=13&t=7407>
- License:
- No info given in that mod but I am going to assume the credit for the original model goes to:
- Melcor and his CAR01 model
- <https://forum.minetest.net/viewtopic.php?f=9&t=6512>
- License: CC-BY-NC-SA
- MeseCars from: "Mesecars" by paramat
- <https://forum.minetest.net/viewtopic.php?f=11&t=7967>
- Licenses: Code WTFPL, textures CC BY-SA
- Boats from "Boats" by PilzAdam
- textures: Zeg9
- model: thetoon and Zeg9, modified by PavelS(SokolovPavel)
- License: WTFPL
- Hovercraft from "Hovercraft" by Stuart Jones
- Licenses:
- textures: CC-BY-SA
- sounds: freesound.org
- Rocket Boost Engine Loop by qubodup - CC0
- CARTOON-BING-LOW by kantouth - CC-BY-3.0
- All other sounds: Copyright Stuart Jones - CC-BY-SA
I am sure many others deserve mention.\
If you feel left out let me know and I will add you in.
Enjoy!

View File

@ -1,9 +1,8 @@
local name = "boat" local name = "boat"
local definition = ... local definition = ...
local craft_check = minetest.settings:get_bool("vehicle_mash.enable_crafts") local craft_check = minetest.settings:get_bool("vehicle_mash.enable_crafts")
definition.description = "BoatA" definition.description = vehicle_mash.S("BoatA")
definition.inventory_image = "boat_inventory.png" definition.inventory_image = "boat_inventory.png"
definition.wield_image = "boat_wield.png" definition.wield_image = "boat_wield.png"
definition.mesh = "boats_boat.obj" definition.mesh = "boats_boat.obj"

View File

@ -1,9 +1,8 @@
local name = "rowboat" local name = "rowboat"
local definition = ... local definition = ...
local craft_check = minetest.settings:get_bool("vehicle_mash.enable_crafts") local craft_check = minetest.settings:get_bool("vehicle_mash.enable_crafts")
definition.description = "Rowboat" definition.description = vehicle_mash.S("Rowboat")
definition.inventory_image = "rowboat_inventory.png" definition.inventory_image = "rowboat_inventory.png"
definition.wield_image = "rowboat_wield.png" definition.wield_image = "rowboat_wield.png"
definition.mesh = "rowboat.x" definition.mesh = "rowboat.x"

View File

@ -1,8 +1,7 @@
local name = "car_black" local name = "car_black"
local definition = ... local definition = ...
definition.description = "Black car" definition.description = vehicle_mash.S("Black car")
definition.inventory_image = "inv_car_black.png" definition.inventory_image = "inv_car_black.png"
definition.wield_image = "inv_car_black.png" definition.wield_image = "inv_car_black.png"
definition.textures = {"car_black.png"} definition.textures = {"car_black.png"}

View File

@ -1,8 +1,7 @@
local name = "car_blue" local name = "car_blue"
local definition = ... local definition = ...
definition.description = "Blue car" definition.description = vehicle_mash.S("Blue car")
definition.inventory_image = "inv_car_blue.png" definition.inventory_image = "inv_car_blue.png"
definition.wield_image = "inv_car_blue.png" definition.wield_image = "inv_car_blue.png"
definition.textures = {"car_blue.png"} definition.textures = {"car_blue.png"}

View File

@ -1,8 +1,7 @@
local name = "car_brown" local name = "car_brown"
local definition = ... local definition = ...
definition.description = "Brown car" definition.description = vehicle_mash.S("Brown car")
definition.inventory_image = "inv_car_brown.png" definition.inventory_image = "inv_car_brown.png"
definition.wield_image = "inv_car_brown.png" definition.wield_image = "inv_car_brown.png"
definition.textures = {"car_brown.png"} definition.textures = {"car_brown.png"}

View File

@ -1,8 +1,7 @@
local name = "car_cyan" local name = "car_cyan"
local definition = ... local definition = ...
definition.description = "Cyan car" definition.description = vehicle_mash.S("Cyan car")
definition.inventory_image = "inv_car_cyan.png" definition.inventory_image = "inv_car_cyan.png"
definition.wield_image = "inv_car_cyan.png" definition.wield_image = "inv_car_cyan.png"
definition.textures = {"car_cyan.png"} definition.textures = {"car_cyan.png"}

View File

@ -1,8 +1,7 @@
local name = "car_dark_green" local name = "car_dark_green"
local definition = ... local definition = ...
definition.description = "Dark green car" definition.description = vehicle_mash.S("Dark green car")
definition.inventory_image = "inv_car_dark_green.png" definition.inventory_image = "inv_car_dark_green.png"
definition.wield_image = "inv_car_dark_green.png" definition.wield_image = "inv_car_dark_green.png"
definition.textures = {"car_dark_green.png"} definition.textures = {"car_dark_green.png"}

View File

@ -1,8 +1,7 @@
local name = "car_dark_grey" local name = "car_dark_grey"
local definition = ... local definition = ...
definition.description = "Dark grey car" definition.description = vehicle_mash.S("Dark grey car")
definition.inventory_image = "inv_car_dark_grey.png" definition.inventory_image = "inv_car_dark_grey.png"
definition.wield_image = "inv_car_dark_grey.png" definition.wield_image = "inv_car_dark_grey.png"
definition.textures = {"car_dark_grey.png"} definition.textures = {"car_dark_grey.png"}

View File

@ -1,8 +1,7 @@
local name = "car_green" local name = "car_green"
local definition = ... local definition = ...
definition.description = "Green car" definition.description = vehicle_mash.S("Green car")
definition.inventory_image = "inv_car_green.png" definition.inventory_image = "inv_car_green.png"
definition.wield_image = "inv_car_green.png" definition.wield_image = "inv_car_green.png"
definition.textures = {"car_green.png"} definition.textures = {"car_green.png"}

View File

@ -1,8 +1,7 @@
local name = "car_grey" local name = "car_grey"
local definition = ... local definition = ...
definition.description = "Grey car" definition.description = vehicle_mash.S("Grey car")
definition.inventory_image = "inv_car_grey.png" definition.inventory_image = "inv_car_grey.png"
definition.wield_image = "inv_car_grey.png" definition.wield_image = "inv_car_grey.png"
definition.textures = {"car_grey.png"} definition.textures = {"car_grey.png"}

View File

@ -1,8 +1,7 @@
local name = "car_hot_rod" local name = "car_hot_rod"
local definition = ... local definition = ...
definition.description = "Hot Rod car" definition.description = vehicle_mash.S("Hot Rod car")
definition.inventory_image = "inv_car_red.png" definition.inventory_image = "inv_car_red.png"
definition.wield_image = "inv_car_red.png" definition.wield_image = "inv_car_red.png"
definition.textures = {"hot_rod.png"} definition.textures = {"hot_rod.png"}

View File

@ -1,8 +1,7 @@
local name = "car_magenta" local name = "car_magenta"
local definition = ... local definition = ...
definition.description = "Magenta car" definition.description = vehicle_mash.S("Magenta car")
definition.inventory_image = "inv_car_magenta.png" definition.inventory_image = "inv_car_magenta.png"
definition.wield_image = "inv_car_magenta.png" definition.wield_image = "inv_car_magenta.png"
definition.textures = {"car_magenta.png"} definition.textures = {"car_magenta.png"}

View File

@ -1,8 +1,7 @@
local name = "car_nyan_ride" local name = "car_nyan_ride"
local definition = ... local definition = ...
definition.description = "Nyan Ride car" definition.description = vehicle_mash.S("Nyan Ride car")
definition.inventory_image = "inv_car_pink.png" definition.inventory_image = "inv_car_pink.png"
definition.wield_image = "inv_car_pink.png" definition.wield_image = "inv_car_pink.png"
definition.textures = {"nyan_ride.png"} definition.textures = {"nyan_ride.png"}

View File

@ -1,8 +1,7 @@
local name = "car_oerkki_bliss" local name = "car_oerkki_bliss"
local definition = ... local definition = ...
definition.description = "Oerkki Bliss car" definition.description = vehicle_mash.S("Oerkki Bliss car")
definition.inventory_image = "inv_car_black.png" definition.inventory_image = "inv_car_black.png"
definition.wield_image = "inv_car_black.png" definition.wield_image = "inv_car_black.png"
definition.textures = {"oerkki_bliss.png"} definition.textures = {"oerkki_bliss.png"}

View File

@ -1,8 +1,7 @@
local name = "car_orange" local name = "car_orange"
local definition = ... local definition = ...
definition.description = "Orange car" definition.description = vehicle_mash.S("Orange car")
definition.inventory_image = "inv_car_orange.png" definition.inventory_image = "inv_car_orange.png"
definition.wield_image = "inv_car_orange.png" definition.wield_image = "inv_car_orange.png"
definition.textures = {"car_orange.png"} definition.textures = {"car_orange.png"}

View File

@ -1,8 +1,7 @@
local name = "car_pink" local name = "car_pink"
local definition = ... local definition = ...
definition.description = "Pink car" definition.description = vehicle_mash.S("Pink car")
definition.inventory_image = "inv_car_pink.png" definition.inventory_image = "inv_car_pink.png"
definition.wield_image = "inv_car_pink.png" definition.wield_image = "inv_car_pink.png"
definition.textures = {"car_pink.png"} definition.textures = {"car_pink.png"}

View File

@ -1,8 +1,7 @@
local name = "car_red" local name = "car_red"
local definition = ... local definition = ...
definition.description = "Red car" definition.description = vehicle_mash.S("Red car")
definition.inventory_image = "inv_car_red.png" definition.inventory_image = "inv_car_red.png"
definition.wield_image = "inv_car_red.png" definition.wield_image = "inv_car_red.png"
definition.textures = {"car_red.png"} definition.textures = {"car_red.png"}

View File

@ -1,8 +1,7 @@
local name = "car_road_master" local name = "car_road_master"
local definition = ... local definition = ...
definition.description = "Road Master car" definition.description = vehicle_mash.S("Road Master car")
definition.inventory_image = "inv_car_brown.png" definition.inventory_image = "inv_car_brown.png"
definition.wield_image = "inv_car_brown.png" definition.wield_image = "inv_car_brown.png"
definition.textures = {"road_master.png"} definition.textures = {"road_master.png"}

View File

@ -1,8 +1,7 @@
local name = "car_violet" local name = "car_violet"
local definition = ... local definition = ...
definition.description = "Violet car" definition.description = vehicle_mash.S("Violet car")
definition.inventory_image = "inv_car_violet.png" definition.inventory_image = "inv_car_violet.png"
definition.wield_image = "inv_car_violet.png" definition.wield_image = "inv_car_violet.png"
definition.textures = {"car_violet.png"} definition.textures = {"car_violet.png"}

View File

@ -1,8 +1,7 @@
local name = "car_white" local name = "car_white"
local definition = ... local definition = ...
definition.description = "White car" definition.description = vehicle_mash.S("White car")
definition.inventory_image = "inv_car_white.png" definition.inventory_image = "inv_car_white.png"
definition.wield_image = "inv_car_white.png" definition.wield_image = "inv_car_white.png"
definition.textures = {"car_white.png"} definition.textures = {"car_white.png"}

View File

@ -1,8 +1,7 @@
local name = "car_yellow" local name = "car_yellow"
local definition = ... local definition = ...
definition.description = "Yellow car" definition.description = vehicle_mash.S("Yellow car")
definition.inventory_image = "inv_car_yellow.png" definition.inventory_image = "inv_car_yellow.png"
definition.wield_image = "inv_car_yellow.png" definition.wield_image = "inv_car_yellow.png"
definition.textures = {"car_yellow.png"} definition.textures = {"car_yellow.png"}

View File

@ -1 +1,6 @@
Adds many types of vehicles. Adds many types of vehicles:
- Normal cars.
- Boats.
- Hovercrafts.
- And mesecars.

View File

@ -1,7 +1,3 @@
vehicle_mash = {}
local drive = lib_mount.drive
function vehicle_mash.register_vehicle(name, def) function vehicle_mash.register_vehicle(name, def)
minetest.register_entity(name, { minetest.register_entity(name, {
terrain_type = def.terrain_type, terrain_type = def.terrain_type,
@ -14,17 +10,8 @@ function vehicle_mash.register_vehicle(name, def)
driver_eye_offset = def.driver_eye_offset, driver_eye_offset = def.driver_eye_offset,
driver_detach_pos_offset = def.driver_detach_pos_offset, driver_detach_pos_offset = def.driver_detach_pos_offset,
number_of_passengers = def.number_of_passengers, number_of_passengers = def.number_of_passengers,
passenger_attach_at = def.passenger_attach_at,
passenger_eye_offset = def.passenger_eye_offset,
passenger_detach_pos_offset = def.passenger_detach_pos_offset,
passenger2_attach_at = def.passenger2_attach_at, passengers = def.passengers,
passenger2_eye_offset = def.passenger2_eye_offset,
passenger2_detach_pos_offset = def.passenger2_detach_pos_offset,
passenger3_attach_at = def.passenger3_attach_at,
passenger3_eye_offset = def.passenger3_eye_offset,
passenger3_detach_pos_offset = def.passenger3_detach_pos_offset,
enable_crash = def.enable_crash, enable_crash = def.enable_crash,
visual = def.visual, visual = def.visual,
@ -50,8 +37,12 @@ function vehicle_mash.register_vehicle(name, def)
mouselook = false, mouselook = false,
physical = true, physical = true,
removed = false, removed = false,
offset = {x=0, y=0, z=0}, offset = vector.new(0,0,0),
owner = "", owner = "",
hp_min = def.hp_min,
hp_max = def.hp_max,
armor = def.armor,
rpm_values = {{16, 16, .5}, {10, 10, .4}, {0, 5, .3}},
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
if not clicker or not clicker:is_player() then if not clicker or not clicker:is_player() then
return return
@ -60,42 +51,29 @@ function vehicle_mash.register_vehicle(name, def)
if self.driver then if self.driver then
-- if clicker is driver detach passengers and driver -- if clicker is driver detach passengers and driver
if clicker == self.driver then if clicker == self.driver then
if self.passenger then for i = 1, self.number_of_passengers do -- Detaches all passengers with the new Library Mount API.
lib_mount.detach(self.passenger, self.offset) local passenger = self.passengers[i]
if passenger.player then
lib_mount.detach(passenger.player, passenger.eye_offset)
end end
if self.passenger2 then
lib_mount.detach(self.passenger2, self.offset)
end
if self.passenger3 then
lib_mount.detach(self.passenger3, self.offset)
end end
-- detach driver -- detach driver
lib_mount.detach(self.driver, self.offset) lib_mount.detach(self.driver, self.offset)
-- if clicker is not the driver -- if clicker is not the driver
else else
-- if clicker is passenger -- if clicker is passenger
-- detach passengers -- detach passengers with the new Library Mount API
if clicker == self.passenger then for i = 1, self.number_of_passengers do
lib_mount.detach(self.passenger, self.offset) local passenger = self.passengers[i]
if clicker == passenger.player then
elseif clicker == self.passenger2 then lib_mount.detach(passenger.player, passenger.eye_offset)
lib_mount.detach(self.passenger2, self.offset) break
elseif clicker == self.passenger3 then
lib_mount.detach(self.passenger3, self.offset)
-- if clicker is not passenger
else else
-- attach passengers if possible -- Attach passengers with the new Library Mount API
if lib_mount.passengers[self.passenger] == self.passenger and self.number_of_passengers >= 1 then if not passenger.player then -- If there's no current passenger, attach if possible.
lib_mount.attach(self, clicker, true, 1) lib_mount.attach(self, clicker, true, i)
break -- We've already attached the player, no need to continue.
end end
if lib_mount.passengers[self.passenger2] == self.passenger2 and self.number_of_passengers >= 2 then
lib_mount.attach(self, clicker, true, 2)
end
if lib_mount.passengers[self.passenger3] == self.passenger3 and self.number_of_passengers >= 3 then
lib_mount.attach(self, clicker, true, 3)
end end
end end
end end
@ -108,7 +86,16 @@ function vehicle_mash.register_vehicle(name, def)
end end
end, end,
on_activate = function(self, staticdata, dtime_s) on_activate = function(self, staticdata, dtime_s)
self.object:set_armor_groups({immortal = 1}) if def.armor then
self.object:set_armor_groups({fleshy = def.armor}) -- Set armor groups to vehicle
else
self.object:set_armor_groups({fleshy = 0, immortal = 1}) -- Else, make vehicle immortal
end
if def.hp_min and def.hp_max then
self.object:set_hp(math.random(def.hp_min, def.hp_max), "Set HP to vehicle")
end
local tmp = minetest.deserialize(staticdata) local tmp = minetest.deserialize(staticdata)
if tmp then if tmp then
for _,stat in pairs(tmp) do for _,stat in pairs(tmp) do
@ -129,7 +116,7 @@ function vehicle_mash.register_vehicle(name, def)
end end
return core.serialize(tmp) return core.serialize(tmp)
end, end,
on_punch = function(self, puncher, time_from_last_punch, tool_capabilities, dir) on_punch = function(self, puncher, time_from_last_punch, tool_capabilities, dir, damage)
if not puncher or not puncher:is_player() or self.removed or self.driver then if not puncher or not puncher:is_player() or self.removed or self.driver then
return return
end end
@ -143,12 +130,24 @@ function vehicle_mash.register_vehicle(name, def)
puncher:get_inventory():add_item("main", self.name) puncher:get_inventory():add_item("main", self.name)
end end
end, end,
on_step = function(self, dtime) on_step = function(self, dtime, moveresult, ...)
-- Automatically set `enable_crash` to true if there's no value found -- Automatically set `enable_crash` to true if there's no value found
if def.enable_crash == nil then if def.enable_crash == nil then
def.enable_crash = true def.enable_crash = true
end end
drive(self, dtime, false, nil, nil, 0, def.can_fly, def.can_go_down, def.can_go_up, def.enable_crash) lib_mount.drive(self, dtime, false, nil, nil, 0, def.can_fly, def.can_go_down, def.can_go_up, def.enable_crash, moveresult)
end,
on_death = function(self, killer)
if self.driver then
lib_mount.detach(self.driver, self.offset)
end
for i = 1, self.number_of_passengers do -- Detaches all passengers with the new Library Mount API.
local passenger = self.passengers[i]
if passenger.player then
lib_mount.detach(passenger.player, passenger.eye_offset)
passenger.player:set_eye_offset(vector.new(0,0,0), vector.new(0,0,0))
end
end
end end
}) })

View File

@ -1,9 +1,8 @@
local name = "hover_blue" local name = "hover_blue"
local definition = ... local definition = ...
definition.description = "Blue hovercraft" definition.description = vehicle_mash.S("Blue hovercraft")
definition.inventory_image = "hovercraft_blue_inv.png" definition.inventory_image = "hovercraft_blue_inv.png"
definition.wield_image = "hovercraft_blue_inv.png" definition.wield_image = "hovercraft_blue_inv.png"
definition.textures = {"hovercraft_blue.png"} definition.textures = {"hovercraft_blue.png"}

View File

@ -1,9 +1,8 @@
local name = "hover_green" local name = "hover_green"
local definition = ... local definition = ...
definition.description = "Green hovercraft" definition.description = vehicle_mash.S("Green hovercraft")
definition.inventory_image = "hovercraft_green_inv.png" definition.inventory_image = "hovercraft_green_inv.png"
definition.wield_image = "hovercraft_green_inv.png" definition.wield_image = "hovercraft_green_inv.png"
definition.textures = {"hovercraft_green.png"} definition.textures = {"hovercraft_green.png"}

View File

@ -1,9 +1,8 @@
local name = "hover_red" local name = "hover_red"
local definition = ... local definition = ...
definition.description = "Red hovercraft" definition.description = vehicle_mash.S("Red hovercraft")
definition.inventory_image = "hovercraft_red_inv.png" definition.inventory_image = "hovercraft_red_inv.png"
definition.wield_image = "hovercraft_red_inv.png" definition.wield_image = "hovercraft_red_inv.png"
definition.textures = {"hovercraft_red.png"} definition.textures = {"hovercraft_red.png"}

View File

@ -1,9 +1,8 @@
local name = "hover_yellow" local name = "hover_yellow"
local definition = ... local definition = ...
definition.description = "Yellow hovercraft" definition.description = vehicle_mash.S("Yellow hovercraft")
definition.inventory_image = "hovercraft_yellow_inv.png" definition.inventory_image = "hovercraft_yellow_inv.png"
definition.wield_image = "hovercraft_yellow_inv.png" definition.wield_image = "hovercraft_yellow_inv.png"
definition.textures = {"hovercraft_yellow.png"} definition.textures = {"hovercraft_yellow.png"}

113
init.lua
View File

@ -1,5 +1,11 @@
vehicle_mash = {
S = minetest.get_translator(minetest.get_current_modname())
}
-- Fix `player_api` eye height model if desired -- Fix `player_api` eye height model if desired
if minetest.settings:get_bool("vehicle_mash.player_api_fix") == true or minetest.settings:get_bool("vehicle_mash.player_api_fix") == nil then if minetest.settings:get_bool("vehicle_mash.player_api_fix") == true or minetest.settings:get_bool("vehicle_mash.player_api_fix") == nil
and player_api.registered_models["character.b3d"] then
player_api.registered_models["character.b3d"].animations.sit.eye_height = 1.47 player_api.registered_models["character.b3d"].animations.sit.eye_height = 1.47
end end
@ -54,22 +60,34 @@ else
visual = "mesh", visual = "mesh",
mesh = "car.x", mesh = "car.x",
visual_size = {x=1, y=1}, visual_size = {x=1, y=1},
wield_scale = {x=1, y=1, z=1}, wield_scale = vector.new(1,1,1),
collisionbox = {-0.6, -0.05, -0.6, 0.6, 1, 0.6}, collisionbox = {-0.6, -0.05, -0.6, 0.6, 1, 0.6},
onplace_position_adj = -0.45, onplace_position_adj = -0.45,
-- player specific stuff -- player specific stuff
player_rotation = {x=0,y=90,z=0}, player_rotation = vector.new(0,90,0),
driver_attach_at = {x=3.5,y=3.7,z=3.5}, driver_attach_at = vector.new(3.5,3.7,3.5),
driver_eye_offset = {x=-4, y=0, z=0}, driver_eye_offset = vector.new(-4,0,0),
number_of_passengers = 3, number_of_passengers = 3,
passenger_attach_at = {x=3.5,y=3.7,z=-3.5},
passenger_eye_offset = {x=4, y=0, z=0},
passenger2_attach_at = {x=-4,y=3.7,z=3.5}, passengers = {
passenger2_eye_offset = {x=-4, y=3, z=0}, {
attach_at = vector.new(3.5,3.7,-3.5),
eye_offset = vector.new(4,0,0),
},
{
attach_at = vector.new(-4,3.7,3.5),
eye_offset = vector.new(-4,3,0),
},
{
attach_at = vector.new(-4,3.7,-3.5),
eye_offset = vector.new(4,3,0),
},
},
passenger3_attach_at = {x=-4,y=3.7,z=-3.5}, -- HP/Armor stuff. Uncomment to enable.
passenger3_eye_offset = {x=4, y=3, z=0}, -- min_hp = 10,
-- max_hp = 35,
-- armor = 25,
-- drop and recipe -- drop and recipe
drop_on_destroy = {"vehicle_mash:tire 2", "vehicle_mash:windshield", drop_on_destroy = {"vehicle_mash:tire 2", "vehicle_mash:windshield",
@ -110,22 +128,26 @@ else
visual = "cube", visual = "cube",
mesh = "", mesh = "",
visual_size = {x=1.5, y=1.5}, visual_size = {x=1.5, y=1.5},
wield_scale = {x=1, y=1, z=1}, wield_scale = vector.new(1,1,1),
collisionbox = {-0.75, -0.75, -0.75, 0.75, 0.75, 0.75}, collisionbox = {-0.75, -0.75, -0.75, 0.75, 0.75, 0.75},
onplace_position_adj = 0.25, onplace_position_adj = 0.25,
-- player specific stuff -- player specific stuff
player_rotation = {x=0,y=0,z=0}, player_rotation = vector.new(0,0,0),
driver_attach_at = {x=0,y=0,z=-2.0}, driver_attach_at = vector.new(0,0,-2.0),
driver_eye_offset = {x=0, y=0, z=0}, driver_eye_offset = vector.new(0,0,0),
number_of_passengers = 0, number_of_passengers = 0,
passenger_attach_at = {x=0,y=0,z=0},
passenger_eye_offset = {x=0, y=0, z=0},
passenger2_attach_at = {x=0,y=0,z=0}, passengers = {
passenger2_eye_offset = {x=0, y=0, z=0}, {
attach_at = vector.new(0,0,0),
eye_offset = vector.new(0,0,0),
},
},
passenger3_attach_at = {x=0,y=0,z=0}, -- HP/Armor stuff. Uncomment to enable.
passenger3_eye_offset = {x=0, y=0, z=0}, -- min_hp = 10,
-- max_hp = 35,
-- armor = 25,
-- drop and recipe -- drop and recipe
drop_on_destroy = {"vehicle_mash:motor", "vehicle_mash:battery"}, drop_on_destroy = {"vehicle_mash:motor", "vehicle_mash:battery"},
@ -162,23 +184,26 @@ else
-- model specific stuff -- model specific stuff
visual = "mesh", visual = "mesh",
visual_size = {x=1, y=1}, visual_size = {x=1, y=1},
wield_scale = {x=1, y=1, z=1}, wield_scale = vector.new(1,1,1),
collisionbox = {-0.5, -0.35, -0.5, 0.5, 0.3, 0.5}, collisionbox = {-0.5, -0.35, -0.5, 0.5, 0.3, 0.5},
onplace_position_adj = 0, onplace_position_adj = 0,
textures = {"default_wood.png"}, textures = {"default_wood.png"},
-- player specific stuff -- player specific stuff
player_rotation = {x=0, y=0, z=0}, player_rotation = vector.new(0,0,0),
driver_attach_at = {x=0.5,y=1,z=-3}, driver_attach_at = vector.new(0.5,1,-3),
driver_eye_offset = {x=0, y=0, z=0}, driver_eye_offset = vector.new(0,0,0),
number_of_passengers = 0, number_of_passengers = 0,
passenger_attach_at = {x=0,y=0,z=0}, passengers = {
passenger_eye_offset = {x=0, y=0, z=0}, {
attach_at = vector.new(0,0,0),
eye_offset = vector.new(0,0,0),
},
},
passenger2_attach_at = {x=0,y=0,z=0}, -- HP/Armor stuff. Uncomment to enable.
passenger2_eye_offset = {x=0, y=0, z=0}, -- min_hp = 10,
-- max_hp = 35,
passenger3_attach_at = {x=0,y=0,z=0}, -- armor = 25,
passenger3_eye_offset = {x=0, y=0, z=0}
} }
local boat_names = { local boat_names = {
@ -210,22 +235,26 @@ else
visual = "mesh", visual = "mesh",
mesh = "hovercraft.x", mesh = "hovercraft.x",
visual_size = {x=1, y=1}, visual_size = {x=1, y=1},
wield_scale = {x=1, y=1, z=1}, wield_scale = vector.new(1,1,1),
collisionbox = {-0.8, -0.25, -0.8, 0.8, 1.2, 0.8}, collisionbox = {-0.8, -0.25, -0.8, 0.8, 1.2, 0.8},
onplace_position_adj = -0.25, onplace_position_adj = -0.25,
-- player specific stuff -- player specific stuff
player_rotation = {x=0,y=90,z=0}, player_rotation = vector.new(0,90,0),
driver_attach_at = {x=-2,y=6.3,z=0}, driver_attach_at = vector.new(-2,6.3,0),
driver_eye_offset = {x=0, y=0, z=0}, driver_eye_offset = vector.new(0,0,0),
number_of_passengers = 0, number_of_passengers = 0,
passenger_attach_at = {x=0,y=0,z=0},
passenger_eye_offset = {x=0, y=0, z=0},
passenger2_attach_at = {x=0,y=0,z=0}, passengers = {
passenger2_eye_offset = {x=0, y=0, z=0}, {
attach_at = vector.new(0,0,0),
eye_offset = vector.new(0,0,0),
},
},
passenger3_attach_at = {x=0,y=0,z=0}, -- HP/Armor stuff. Uncomment to enable.
passenger3_eye_offset = {x=0, y=0, z=0}, -- min_hp = 10,
-- max_hp = 35,
-- armor = 25,
-- recipe -- recipe
recipe = nil recipe = nil

35
locale/template.txt Normal file
View File

@ -0,0 +1,35 @@
# textdomain: vehicle_mash
Motor=
Tire=
Wind Shield=
Car battery=
BoatA=
Rowboat=
Black car=
Blue car=
Brown car=
Cyan car=
Dark green car=
Dark grey car=
Green car=
Grey car=
Hot Rod car=
Magenta car=
Nyan Ride car=
Oerkki Bliss car=
Orange car=
Pink car=
Red car=
Road Master car=
Violet car=
White car=
Yellow car=
Blue hovercraft=
Green hovercraft=
Red hovercraft=
Yellow hovercraft=
Blue Mesecar=
Pink Mesecar=
Purple Mesecar=
Yellow Mesecar=

35
locale/vehicle_mash.es.tr Normal file
View File

@ -0,0 +1,35 @@
# textdomain: vehicle_mash
Motor=Motor
Tire=Lanta
Wind Shield=
Car battery=Batería de Carro
BoatA=BoteA
Rowboat=Bote de remos
Black car=Carro negro
Blue car=Carro azul
Brown car=Carro cáfe
Cyan car=Carro celeste
Dark green car=Carro verde oscuro
Dark grey car=Carro gris oscuro
Green car=Carro verde
Grey car=Carro gris
Hot Rod car=Carro de carreras
Magenta car=Carro magenta
Nyan Ride car=Carro de Nyan
Oerkki Bliss car=Carro de Oerkki
Orange car=Carro naranja
Pink car=Carro rosa
Red car=Carro rojo
Road Master car=Carro Maestro
Violet car=Carro violeta
White car=Carro blanco
Yellow car=Carro amarillo
Blue hovercraft=Aerodeslizador azul
Green hovercraft=Aerodeslizador verde
Red hovercraft=Aerodeslizador rojo
Yellow hovercraft=Aerodeslizador amarillo
Blue Mesecar=Carro de Mese azul
Pink Mesecar=Carro de Mese Rosa
Purple Mesecar=Carro de Mese Morado
Yellow Mesecar=Carro de Mese amarillo

View File

@ -1,8 +1,7 @@
local name = "mesecar_blue" local name = "mesecar_blue"
local definition = ... local definition = ...
definition.description = "Blue Mesecar" definition.description = vehicle_mash.S("Blue Mesecar")
definition.inventory_image = "mesecar_car1front.png" definition.inventory_image = "mesecar_car1front.png"
definition.wield_image = "mesecar_car1front.png" definition.wield_image = "mesecar_car1front.png"
definition.textures = { definition.textures = {

View File

@ -2,7 +2,7 @@
local name = "mesecar_pink" local name = "mesecar_pink"
local definition = ... local definition = ...
definition.description = "Pink Mesecar" definition.description = vehicle_mash.S("Pink Mesecar")
definition.inventory_image = "mesecar_car3front.png" definition.inventory_image = "mesecar_car3front.png"
definition.wield_image = "mesecar_car3front.png" definition.wield_image = "mesecar_car3front.png"
definition.textures = { definition.textures = {

View File

@ -2,7 +2,7 @@
local name = "mesecar_purple" local name = "mesecar_purple"
local definition = ... local definition = ...
definition.description = "Purple Mesecar" definition.description = vehicle_mash.S("Purple Mesecar")
definition.inventory_image = "mesecar_car2front.png" definition.inventory_image = "mesecar_car2front.png"
definition.wield_image = "mesecar_car2front.png" definition.wield_image = "mesecar_car2front.png"
definition.textures = { definition.textures = {

View File

@ -2,7 +2,7 @@
local name = "mesecar_yellow" local name = "mesecar_yellow"
local definition = ... local definition = ...
definition.description = "Yellow Mesecar" definition.description = vehicle_mash.S("Yellow Mesecar")
definition.inventory_image = "mesecar_car4front.png" definition.inventory_image = "mesecar_car4front.png"
definition.wield_image = "mesecar_car4front.png" definition.wield_image = "mesecar_car4front.png"
definition.textures = { definition.textures = {

View File

@ -9,3 +9,4 @@ Adds many types of vehicles:
- Hovercrafts. - Hovercrafts.
- And mesecars. - And mesecars.
""" """
min_minetest_version = 5.0.0

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -9,25 +9,30 @@ local definition = {
can_fly = false, -- if enabled, the specified vehicle will be able to fly around can_fly = false, -- if enabled, the specified vehicle will be able to fly around
can_go_down = false, -- applies only when `can_fly` is enabled can_go_down = false, -- applies only when `can_fly` is enabled
can_go_up = false, -- applies only when `can_fly` is enabled can_go_up = false, -- applies only when `can_fly` is enabled
player_rotation = {x=0,y=0,z=0}, -- rotate player so they sit facing the correct direction player_rotation = vector.new(0,0,0), -- rotate player so they sit facing the correct direction
driver_attach_at = {x=0,y=0,z=0}, -- attach the driver at driver_attach_at = vector.new(0,0,0), -- attach the driver at
driver_eye_offset = {x=0, y=0, z=0}, -- offset for first person driver view driver_eye_offset = vector.new(0,0,0), -- offset for first person driver view
number_of_passengers = 0, -- maximum number of passengers. Can have 3 passengers maximum number_of_passengers = 0, -- maximum number of passengers. Can have 3 passengers maximum
passenger_attach_at = {x=0,y=0,z=0}, -- attach the 1st passenger, if applicable, at the specified positions
passenger_eye_offset = {x=0, y=0, z=0}, -- offset for the 1st passenger in first-person view
passenger_detach_pos_offset = {x=0,y=0,z=0}, -- offset for the 1st passenger when they leave the vehicle
passenger2_attach_at = {x=0,y=0,z=0}, -- attach the 2nd passenger, if applicable, at the specified positions -- Attachment positions and offset for all passengers (can be over 3 passengers)
passenger2_eye_offset = {x=0,y=0,z=0}, -- offset for the 2nd passenger in first-person view passengers = {
passenger2_detach_pos_offset = {x=0,y=0,z=0}, -- offset for the 2nd passenger when they leave the vehicle {
attach_at = vector.new(0,0,0),
passenger3_attach_at = {x=0,y=0,z=0}, -- attach the 3rd passenger, if applicable, at the specified positions eye_offset = vector.new(0,0,0),
passenger3_eye_offset = {x=0,y=0,z=0}, -- offset for the 3rd passenger in first-person view },
passenger3_detach_pos_offset = {x=0,y=0,z=0}, -- offset for the 3rd passenger when they leave the vehicle {
attach_at = vector.new(0,0,0),
eye_offset = vector.new(0,0,0),
},
{
attach_at = vector.new(0,0,0),
eye_offset = vector.new(0,0,0),
},
},
inventory_image = "filename.png", -- image to use in inventory inventory_image = "filename.png", -- image to use in inventory
wield_image = "filename.png", -- image to use in hand wield_image = "filename.png", -- image to use in hand
wield_scale = {x=1, y=1, z=1}, -- wield_scale = vector.new(1,1,1), -- the size of the item in hand
visual = "mesh", -- what type of object (mesh, cube, etc...) visual = "mesh", -- what type of object (mesh, cube, etc...)
mesh = "filename.ext", -- mesh model to use mesh = "filename.ext", -- mesh model to use
textures = {"filename.png"}, -- mesh texture(s) textures = {"filename.png"}, -- mesh texture(s)
@ -41,7 +46,11 @@ local definition = {
braking = 2, -- how fast can the vehicle stop braking = 2, -- how fast can the vehicle stop
turn_speed = 2, -- how quick can the vehicle turn turn_speed = 2, -- how quick can the vehicle turn
drop_on_destroy = {""}, -- what gets dropped when vehicle is destroyed drop_on_destroy = {""}, -- what gets dropped when vehicle is destroyed
recipe = {} -- crafting recipe recipe = {}, -- crafting recipe
-- HP/Armor stuff.
min_hp = 1,
max_hp = 10,
armor = 25
} }
-- nothing to change down here -- nothing to change down here

Binary file not shown.

Before

Width:  |  Height:  |  Size: 73 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 57 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB