Add railgun cannons (#16)

* feat: add purple and blue cannons (railguns)

* fix: linter warnings

* fix: last commit

Seems I forgot to save some changes that were supposed to be part of the last commit.

* feat: don't change cannon projectile range

Avoid breaking builds on other servers
This commit is contained in:
Kiëd Llaentenn 2023-05-29 23:44:29 -04:00 committed by GitHub
parent e7f3f1eac6
commit 29c0daca0b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 178 additions and 42 deletions

13
ammo.lua Normal file

@ -0,0 +1,13 @@
minetest.register_craftitem("spacecannon:railgun_slug", {
description = "Railgun slug",
inventory_image = "spacecannon_railgun_slug.png",
})
minetest.register_craft({
output = "spacecannon:railgun_slug 2",
recipe = {
{ "", "technic:uranium0_ingot", ""},
{"basic_materials:carbon_steel_bar", "technic:stainless_steel_ingot", "basic_materials:carbon_steel_bar"},
{ "technic:stainless_steel_ingot", "technic:stainless_steel_ingot", "technic:stainless_steel_ingot"}
},
})

@ -1,3 +1,4 @@
-- vi: noexpandtab
local cable_entry = "^technic_cable_connection_overlay.png" local cable_entry = "^technic_cable_connection_overlay.png"
@ -23,6 +24,7 @@ local register_spacecannon = function(def)
timer = 0, timer = 0,
lifetime = 0, lifetime = 0,
static_save = false, static_save = false,
penetrated = 0,
on_step = function(self, dtime) on_step = function(self, dtime)
self.timer = self.timer + dtime self.timer = self.timer + dtime
@ -65,25 +67,33 @@ local register_spacecannon = function(def)
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 1) local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 1)
local collided = false local collided = false
for _, obj in pairs(objs) do for _, obj in pairs(objs) do
if obj:get_luaentity() ~= nil and obj:get_luaentity().name ~= self.name then if obj:get_luaentity() ~= nil
and obj:get_luaentity().name ~= self.name
and obj:get_luaentity().name ~= "__builtin:item"
then
collided = true collided = true
obj:punch(self.object, 1.0, { obj:punch(self.object, 1.0, {
full_punch_interval=1.0, full_punch_interval=1.0,
damage_groups={fleshy=def.range*2}, damage_groups={fleshy=def.damage},
}, nil) }, nil)
end end
end end
if collided then if collided then
spacecannon.destroy(pos, def.range, def.intensity) spacecannon.destroy(pos, def.range, def.intensity)
self.penetrated = self.penetrated + 1
if self.penetrated >= def.penetration then
self.object:remove() self.object:remove()
end end
end
else else
-- collision -- collision
spacecannon.destroy(pos, def.range, def.intensity) spacecannon.destroy(pos, def.range, def.intensity)
self.penetrated = self.penetrated + 1
if self.penetrated >= def.penetration then
self.object:remove() self.object:remove()
end
end end
end end
}) })
@ -112,7 +122,7 @@ local register_spacecannon = function(def)
action_on = function (pos) action_on = function (pos)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local owner = meta:get_string("owner") local owner = meta:get_string("owner")
spacecannon.fire(pos, owner, def.color, def.speed, def.range) spacecannon.fire(pos, owner, def.color, def.speed, def.is_th, def.storage_require_mod)
end end
}}, }},
@ -145,7 +155,13 @@ local register_spacecannon = function(def)
-- Set default digiline channel (do before updating formspec). -- Set default digiline channel (do before updating formspec).
meta:set_string("channel", "spacecannon") meta:set_string("channel", "spacecannon")
spacecannon.update_formspec(meta) -- Set inventory (not used for thermal cannons)
if not def.is_th then
local inv = meta:get_inventory()
inv:set_size("src", 1)
end
spacecannon.update_formspec(meta, def.is_th)
end, end,
technic_run = function(pos) technic_run = function(pos)
@ -154,13 +170,17 @@ local register_spacecannon = function(def)
local demand = meta:get_int("HV_EU_demand") local demand = meta:get_int("HV_EU_demand")
local store = meta:get_int("powerstorage") local store = meta:get_int("powerstorage")
local config_store = spacecannon.config.ki_powerstorage * def.storage_require_mod
if def.is_th then config_store = spacecannon.config.th_powerstorage * def.storage_require_mod end
local config_require = spacecannon.config.ki_powerrequirement
if def.is_th then config_require = spacecannon.config.th_powerrequirement end
meta:set_string("infotext", "Power: " .. eu_input .. "/" .. demand .. " Store: " .. store) meta:set_string("infotext", "Power: " .. eu_input .. "/" .. demand .. " Store: " .. store)
if store < spacecannon.config.powerstorage * def.range then if store < config_store then
-- charge -- charge
meta:set_int("HV_EU_demand", spacecannon.config.powerrequirement) meta:set_int("HV_EU_demand", config_require)
store = store + eu_input meta:set_int("powerstorage", store + eu_input)
meta:set_int("powerstorage", store)
else else
-- charged -- charged
meta:set_int("HV_EU_demand", 0) meta:set_int("HV_EU_demand", 0)
@ -177,16 +197,21 @@ local register_spacecannon = function(def)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
if fields.fire then if fields.fire then
spacecannon.fire(pos, playername, def.color, def.speed, def.range) spacecannon.fire(pos, playername, def.color, def.speed, def.is_th, def.storage_require_mod)
end end
if fields.set_digiline_channel and fields.digiline_channel then if fields.set_digiline_channel and fields.digiline_channel then
meta:set_string("channel", fields.digiline_channel) meta:set_string("channel", fields.digiline_channel)
end end
spacecannon.update_formspec(meta) spacecannon.update_formspec(meta, def.is_th)
end end,
after_dig_node = function(pos, _node, meta, _digger)
if meta.inventory and meta.inventory.src and meta.inventory.src[1] then
minetest.add_item(pos, ItemStack(meta.inventory.src[1]))
end
end
}) })
technic.register_machine("HV", "spacecannon:cannon_" .. def.color, technic.receiver) technic.register_machine("HV", "spacecannon:cannon_" .. def.color, technic.receiver)
@ -205,31 +230,75 @@ local register_spacecannon = function(def)
end end
register_spacecannon({ register_spacecannon({
is_th = true,
color = "green", color = "green",
range = 1, range = 1,
storage_require_mod = 1,
damage = 2,
intensity = 1, intensity = 1,
timeout = 8, timeout = 8,
speed = 10, speed = 10,
penetration = 0,
desc = "fast,low damage", desc = "fast,low damage",
ingredient = "default:mese_block" ingredient = "default:mese_block"
}) })
register_spacecannon({ register_spacecannon({
is_th = true,
color = "yellow", color = "yellow",
range = 3, range = 3,
storage_require_mod = 3,
intensity = 2, intensity = 2,
damage = 6,
timeout = 8, timeout = 8,
speed = 5, speed = 5,
penetration = 0,
desc = "medium speed, medium damage", desc = "medium speed, medium damage",
ingredient = "spacecannon:cannon_green" ingredient = "spacecannon:cannon_green"
}) })
register_spacecannon({ register_spacecannon({
is_th = true,
color = "red", color = "red",
range = 5, range = 5,
storage_require_mod = 5,
intensity = 4, intensity = 4,
damage = 10,
timeout = 15, timeout = 15,
speed = 3, speed = 3,
penetration = 0,
desc = "slow, heavy damage", desc = "slow, heavy damage",
ingredient = "spacecannon:cannon_yellow" ingredient = "spacecannon:cannon_yellow"
}) })
-- Railguns
-- Regular railgun
register_spacecannon({
is_th = false,
color = "blue",
range = 0,
storage_require_mod = 1,
intensity = 2,
damage = 5,
timeout = 10,
speed = 9,
penetration = 2,
desc = "fast, 2x penetrating damage",
ingredient = "technic:copper_coil"
})
-- Helical railgun
register_spacecannon({
is_th = false,
color = "purple",
range = 0,
storage_require_mod = 1.5,
intensity = 4,
damage = 10,
timeout = 15,
speed = 10,
penetration = 4,
desc = "fast, 4x penetrating damage",
ingredient = "spacecannon:cannon_blue"
})

@ -2,10 +2,12 @@
spacecannon = { spacecannon = {
config = { config = {
-- technic EU storage value -- technic EU storage value
powerstorage = 10000, th_powerstorage = 10000,
ki_powerstorage = 300,
-- charge value in EU -- charge value in EU
powerrequirement = 2500 th_powerrequirement = 2500,
ki_powerrequirement = 300
}, },
node_resilience = {} node_resilience = {}
} }
@ -15,6 +17,7 @@ local MP = minetest.get_modpath("spacecannon")
dofile(MP.."/util.lua") dofile(MP.."/util.lua")
dofile(MP.."/digiline.lua") dofile(MP.."/digiline.lua")
dofile(MP.."/cannon.lua") dofile(MP.."/cannon.lua")
dofile(MP.."/ammo.lua")
dofile(MP.."/node_resilience.lua") dofile(MP.."/node_resilience.lua")
print("[OK] Spacecannon") print("[OK] Spacecannon")

@ -1,4 +1,7 @@
name = spacecannon name = spacecannon
description = Adds three scifi/space cannons with various projectile-speed and explosion-strength description = Adds five scifi/space cannons with various properties
depends = default, technic depends = default, technic
optional_depends = mesecons, digilines optional_depends = mesecons, digilines
release = 6899
author = BuckarooBanzay
title = Spacecannon

BIN
textures/cannon_front_purple.png Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 209 B

BIN
textures/energycube_purple.png Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 159 B

@ -1,32 +1,58 @@
-- vi: noexpandtab
local has_digilines = minetest.get_modpath("digilines") local has_digilines = minetest.get_modpath("digilines")
spacecannon.update_formspec_digilines = function(meta) spacecannon.update_formspec = function(meta, is_th)
local channel = meta:get_string("channel") or "" local formspec = ""
local formspec = if not is_th then
formspec = formspec ..
"formspec_version[4]" .. "formspec_version[4]" ..
"size[6,4;]" .. "size[10.5,9;]"
-- Digiline channel -- Ammo inventory
"field[0.5,0.5;3.5,1;digiline_channel;Digiline Channel;" .. formspec = formspec ..
channel .. "]" .. "list[current_name;src;0.375,0.5;1,1;]" ..
"button_exit[4.5,0.5;1,1;set_digiline_channel;Set]" .. "list[current_player;main;0.375,4;8,4;]" ..
"listring[]" ..
"label[1.75,1;Ammunition]"
-- Manual "fire" button -- Manual "fire" button
"button_exit[0.5,2.5;5,1;fire;Fire]" formspec = formspec ..
"button_exit[5.125,0.5;5,1;fire;Fire]"
-- Digiline channel
if has_digilines then
local channel = meta:get_string("channel") or ""
formspec = formspec ..
"field[0.375,2.375;4,1;digiline_channel;Digiline Channel;" .. channel .. "]" ..
"button_exit[4.5,2.375;1,1;set_digiline_channel;Set]"
end
else
formspec = formspec .. "formspec_version[4]"
if has_digilines then
formspec = formspec .. "size[6,4;]"
else
formspec = formspec .. "size[6,2;]"
end
-- Manual "fire" button
formspec = formspec ..
"button_exit[0.5,0.5;5,1;fire;Fire]"
-- Digiline channel
if has_digilines then
local channel = meta:get_string("channel") or ""
formspec = formspec ..
"field[0.5,2.5;3.5,1;digiline_channel;Digiline Channel;" .. channel .. "]" ..
"button_exit[4.5,2.5;1,1;set_digiline_channel;Set]"
end
end
meta:set_string("formspec", formspec) meta:set_string("formspec", formspec)
end end
spacecannon.update_formspec = function(meta)
if has_digilines then
spacecannon.update_formspec_digilines(meta)
else
meta:set_string("formspec", "size[8,2;]" ..
"button_exit[0,1;8,1;fire;Fire]")
end
end
spacecannon.can_shoot = function() spacecannon.can_shoot = function()
-- arguments: pos, playername -- arguments: pos, playername
return true return true
@ -37,8 +63,7 @@ spacecannon.can_destroy = function()
return true return true
end end
spacecannon.fire = function(pos, playername, color, speed, range) spacecannon.fire = function(pos, playername, color, speed, is_th, storage_require_mod)
if not spacecannon.can_shoot(pos, playername) then if not spacecannon.can_shoot(pos, playername) then
return return
end end
@ -46,13 +71,36 @@ spacecannon.fire = function(pos, playername, color, speed, range)
-- check fuel/power -- check fuel/power
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
if meta:get_int("powerstorage") < spacecannon.config.powerstorage * range then local config_store = spacecannon.config.ki_powerstorage * storage_require_mod
if is_th then config_store = spacecannon.config.th_powerstorage * storage_require_mod end
if meta:get_int("powerstorage") < config_store then
-- not enough power -- not enough power
return return
end
-- check ammunition
if not is_th then
local inv = meta:get_inventory()
if inv:is_empty("src") then
--minetest.chat_send_player(playername, "No ammunition loaded!")
return false
end
local src_stack = inv:get_list("src")[1]
if not src_stack or src_stack:get_name() ~= "spacecannon:railgun_slug" then
--minetest.chat_send_player(playername, "Incorrect ammunition!")
return
end
end
else
-- use power -- use power
meta:set_int("powerstorage", 0) meta:set_int("powerstorage", 0)
-- use ammo
if not is_th then
local src_stack = (meta:get_inventory()):get_list("src")[1]
src_stack:take_item();
(meta:get_inventory()):set_stack("src", 1, src_stack)
end end
minetest.sound_play("spacecannon_shoot", { minetest.sound_play("spacecannon_shoot", {