From 670b8c784513149942e37dc82be4671002a32282 Mon Sep 17 00:00:00 2001 From: Leo Spratt Date: Thu, 30 Dec 2021 21:45:58 +0000 Subject: [PATCH] add a energy collector --- config.lua | 1 + energy_collector.lua | 124 +++++++++++++++++++++++++ init.lua | 2 + settingtypes.txt | 2 + textures/ee_energy_collector_down.png | Bin 0 -> 545 bytes textures/ee_energy_collector_right.png | Bin 0 -> 598 bytes textures/ee_energy_collector_up.png | Bin 0 -> 572 bytes 7 files changed, 129 insertions(+) create mode 100644 config.lua create mode 100644 energy_collector.lua create mode 100644 settingtypes.txt create mode 100644 textures/ee_energy_collector_down.png create mode 100644 textures/ee_energy_collector_right.png create mode 100644 textures/ee_energy_collector_up.png diff --git a/config.lua b/config.lua new file mode 100644 index 0000000..ab7097f --- /dev/null +++ b/config.lua @@ -0,0 +1 @@ +COLLECTOR_INTERVAL = minetest.settings:get("element_exchange.collector_interval") or 20 diff --git a/energy_collector.lua b/energy_collector.lua new file mode 100644 index 0000000..0dc0b3a --- /dev/null +++ b/energy_collector.lua @@ -0,0 +1,124 @@ +function get_energy_collector_formspec() + local formspec = { + "size[8,9]", + "label[3,2;Orb]", + "list[context;dst;4,2;1,1;]", + "list[current_player;main;0,5;8,4;]", + } + return table.concat(formspec, "") +end + +local function can_dig(pos, player) + local meta = minetest.get_meta(pos); + local inv = meta:get_inventory() + return inv:is_empty("dst") +end + +local function on_timer(pos, elapsed) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + + -- get block above + pos.y = pos.y + 1 + + if inv:is_empty("dst") then + -- stop timer + minetest.get_node_timer(pos):stop() + return false + end + + if minetest.get_natural_light(pos) == 15 then + local dest_orb = inv:get_stack("dst", 1) + local stored = dest_orb:get_meta():get_int("stored_charge") or 0 + stored = stored + 1 + dest_orb:get_meta():set_int("stored_charge", stored) + inv:set_stack("dst", 1, dest_orb) + end + return true +end + +local function on_construct(pos) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + inv:set_size("dst", 1) + meta:set_string("formspec", get_energy_collector_formspec()) + meta:set_string("infotext", "Energy Collector") + on_timer(pos, 0) +end + +local function allow_metadata_inventory_put(pos, listname, index, stack, player) + if minetest.is_protected(pos, player:get_player_name()) then + return 0 + end + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + if listname == "dst" then + if stack:get_name() == "element_exchange:exchange_orb" then + return stack:get_count() + else + return 0 + end + end +end + +local function allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + local stack = inv:get_stack(from_list, from_index) + return allow_metadata_inventory_put(pos, to_list, to_index, stack, player) +end + +local function allow_metadata_inventory_take(pos, listname, index, stack, player) + if minetest.is_protected(pos, player:get_player_name()) then + return 0 + end + return stack:get_count() +end + +local function on_blast(pos) + local drops = {} + default.get_inventory_drops(pos, "dst", drops) + drops[#drops+1] = "element_exchange:energy_collector" + minetest.remove_node(pos) + return drops +end + +minetest.register_node("element_exchange:energy_collector", { + description = "Energy Collector", + tiles = { + "ee_energy_collector_up.png", + "ee_energy_collector_down.png", + "ee_energy_collector_right.png", + "ee_energy_collector_right.png", + "ee_energy_collector_right.png", + "ee_energy_collector_right.png" + }, + groups = {cracky = 2}, + is_ground_content = false, + can_dig = can_dig, + on_timer = on_timer, + on_construct = on_construct, + on_metadata_inventory_move = function(pos) + minetest.get_node_timer(pos):start(COLLECTOR_INTERVAL) + end, + on_metadata_inventory_put = function(pos) + minetest.get_node_timer(pos):start(COLLECTOR_INTERVAL) + end, + on_metadata_inventory_take = function(pos) + minetest.get_node_timer(pos):start(COLLECTOR_INTERVAL) + end, + on_blast = on_blast, + allow_metadata_inventory_put = allow_metadata_inventory_put, + allow_metadata_inventory_move = allow_metadata_inventory_move, + allow_metadata_inventory_take = allow_metadata_inventory_take, +}) + +minetest.register_craft({ + type = "shaped", + output = "element_exchange:energy_collector", + recipe = { + {"default:obsidian_glass", "default:obsidian_glass","default:obsidian_glass"}, + {"element_exchange:exchange_orb", "default:chest", "element_exchange:exchange_orb"}, + {"default:steelblock", "default:steelblock", "default:steelblock"} + } +}) diff --git a/init.lua b/init.lua index eedb49f..8130b95 100644 --- a/init.lua +++ b/init.lua @@ -4,7 +4,9 @@ function get_item_energy(name) return minetest.registered_items[name].energy_value or 1 end +dofile(default_path.."/config.lua") dofile(default_path.."/constructor.lua") dofile(default_path.."/deconstructor.lua") +dofile(default_path.."/energy_collector.lua") dofile(default_path.."/energy.lua") dofile(default_path.."/orb.lua") diff --git a/settingtypes.txt b/settingtypes.txt new file mode 100644 index 0000000..93b7a28 --- /dev/null +++ b/settingtypes.txt @@ -0,0 +1,2 @@ +# How fast the energy collector gathers energy from the light +element_exchange.collector_interval (Collector Gather Interval) int 20 diff --git a/textures/ee_energy_collector_down.png b/textures/ee_energy_collector_down.png new file mode 100644 index 0000000000000000000000000000000000000000..ff2613f2b2ada396a06ea601670c0d52ac4103ec GIT binary patch literal 545 zcmV++0^a?JP)7*82&W}f+> z=8e~TBgt0TPElgx*Mh%*t+G~%NXbrF6C3oL=c$p*xt)7H_j~U--Fq&0)vTsl0i3GNvvpFDIa9 zm$aYzI4|)hb5oNNTg98Ph!P=;!YD%w(n~k}GWXI!h)!8iBERc9e}YBH)nqnU!DN9n z8S(^0U6Sfai7C;OGP0~V{r}rnE7cQntNX)H@nG98ZQ$F0&w_2g@7wn00hHatS+1DB zxCec&q8Ex9oF;N-lhCAQ#n9h&ZpxEcSJ%EY~?6g(e6O$_QUp=#Fc+0Q78E5dwrFSPJfbEw3-X j@EKtmTq4P4?el&Ba~uw*!XMI)00000NkvXXu0mjf*#G#a literal 0 HcmV?d00001 diff --git a/textures/ee_energy_collector_right.png b/textures/ee_energy_collector_right.png new file mode 100644 index 0000000000000000000000000000000000000000..0b63959e71d9e07a3bbd665add71e8a87546b72d GIT binary patch literal 598 zcmV-c0;&CpP)7*82&W}f+> z=8e~TBgt0TPElgx*Mh%*t+G~%NXbrF6C3oL=c$p*xt)7H_j~U--Fq&0)vTsl0i3GNvvpFDIa9 zm$aYzI4|)hb5oNNTg98Ph!P=;!YD%w(n~k}GWXI!h)!8iBERc9e}YBH)nqnU!DN9n z8S(^0U6Sfai7C;OGP0~V{r}rnE7cQntNX)H@nG98ZQ$F0&w_2g@7wn00hHatS+1DB zxCec&q8Ex9oF;N-lhCAQ#n9h&ZpxEcSJ%EY~?6g(e6O$_QUp=#Fc+0Q78E5L2nC)YXy+(tg0Kjl+qKi-d5Vs zBxUR!I#%qMxOtr8=tl^hnFf$Z=A7r2b0Yw)H3_d()e;AI;TZo$8eh5kHwkH%jE=16 kl_MKEbUrWNExcdv3;cplBMWR$KmY&$07*qoM6N<$f+5Ebv;Y7A literal 0 HcmV?d00001 diff --git a/textures/ee_energy_collector_up.png b/textures/ee_energy_collector_up.png new file mode 100644 index 0000000000000000000000000000000000000000..b46ff739ab091bedd3eaf91071bbcb97a5b653e5 GIT binary patch literal 572 zcmV-C0>k}@P)7*82&W}f+> z=8e~TBgt0TPElgx*Mh%*t+G~%NXbrF6C3oL=c$p*xt)7H_j~U--Fq&0)vTsl0i3GNvvpFDIa9 zm$aYzI4|)hb5oNNTg98Ph!P=;!YD%w(n~k}GWXI!h)!8iBERc9e}YBH)nqnU!DN9n z8S(^0U6Sfai7C;OGP0~V{r}rnE7cQntNX)H@nG98ZQ$F0&w_2g@7wn00hHatS+1DB zxCec&q8Ex9oF;N-lhCAQ#n9h&ZpxEcSJ%EY~?6g(e6O$_QUp=#Fc+0Q78E5F z@{`#R1`DPTelQ4aU?Rp;>^2NtPm^o|6C@212{vrlzzAUxpS%Iy@+IYr?I(Qz0000< KMNUMnLSTa2y#P)C literal 0 HcmV?d00001