From 609f4b52c33087e977cc3380ae0f53df40444565 Mon Sep 17 00:00:00 2001 From: Evert Prants Date: Sun, 24 Nov 2019 00:00:31 +0200 Subject: [PATCH] A simple mining device --- elepower_mining/crafting.lua | 0 elepower_mining/craftitems.lua | 27 ++ elepower_mining/depends.txt | 3 + elepower_mining/init.lua | 14 + elepower_mining/miner.lua | 259 ++++++++++++++++++ elepower_mining/mod.conf | 3 + .../elepower_mining_apparatus_base.png | Bin 0 -> 647 bytes .../elepower_mining_apparatus_side.png | Bin 0 -> 448 bytes .../textures/elepower_mining_core.png | Bin 0 -> 705 bytes elepower_papi/helpers.lua | 10 + 10 files changed, 316 insertions(+) create mode 100644 elepower_mining/crafting.lua create mode 100644 elepower_mining/craftitems.lua create mode 100644 elepower_mining/depends.txt create mode 100644 elepower_mining/init.lua create mode 100644 elepower_mining/miner.lua create mode 100644 elepower_mining/mod.conf create mode 100644 elepower_mining/textures/elepower_mining_apparatus_base.png create mode 100644 elepower_mining/textures/elepower_mining_apparatus_side.png create mode 100644 elepower_mining/textures/elepower_mining_core.png diff --git a/elepower_mining/crafting.lua b/elepower_mining/crafting.lua new file mode 100644 index 0000000..e69de29 diff --git a/elepower_mining/craftitems.lua b/elepower_mining/craftitems.lua new file mode 100644 index 0000000..102f3a0 --- /dev/null +++ b/elepower_mining/craftitems.lua @@ -0,0 +1,27 @@ + +minetest.register_craft({ + output = "elepower_mining:miner_controller", + recipe = { + {"elepower_dynamics:invar_gear", "elepower_dynamics:induction_coil_advanced", "elepower_dynamics:invar_gear"}, + {"elepower_machines:resonant_capacitor", "elepower_machines:machine_block", "elepower_machines:resonant_capacitor"}, + {"elepower_dynamics:viridisium_plate", "elepower_dynamics:lcd_panel", "elepower_dynamics:viridisium_plate"}, + } +}) + +minetest.register_craft({ + output = "elepower_mining:miner_core", + recipe = { + {"default:steelblock", "elepower_dynamics:invar_gear", "default:steelblock"}, + {"elepower_dynamics:invar_gear", "fluid_transfer:fluid_duct", "elepower_dynamics:invar_gear"}, + {"default:steelblock", "elepower_dynamics:invar_gear", "default:steelblock"}, + } +}) + +minetest.register_craft({ + output = "elepower_mining:miner_drill", + recipe = { + {"default:steelblock", "elepower_dynamics:induction_coil_advanced", "default:steelblock"}, + {"basic_materials:motor", "elepower_machines:machine_block", "basic_materials:motor"}, + {"elepower_tools:hand_drill", "elepower_tools:hand_drill", "elepower_tools:hand_drill"}, + } +}) diff --git a/elepower_mining/depends.txt b/elepower_mining/depends.txt new file mode 100644 index 0000000..3984713 --- /dev/null +++ b/elepower_mining/depends.txt @@ -0,0 +1,3 @@ +elepower_papi +elepower_farming +3d_armor? diff --git a/elepower_mining/init.lua b/elepower_mining/init.lua new file mode 100644 index 0000000..320aa25 --- /dev/null +++ b/elepower_mining/init.lua @@ -0,0 +1,14 @@ +-- An Elepower Mod +-- Copyright 2018 Evert "Diamond" Prants + +local modpath = minetest.get_modpath(minetest.get_current_modname()) + +elemining = rawget(_G, "elemining") or {} +elemining.modpath = modpath + +-- Crafting +dofile(modpath .. "/craftitems.lua") +dofile(modpath .. "/crafting.lua") + +-- Nodes +dofile(modpath .. "/miner.lua") diff --git a/elepower_mining/miner.lua b/elepower_mining/miner.lua new file mode 100644 index 0000000..405242e --- /dev/null +++ b/elepower_mining/miner.lua @@ -0,0 +1,259 @@ + +local structures = {} +local TIMER = 10 + +local function determine_structure(controller, player) + local below1 = vector.add(controller, {x=0,y=-1,z=0}) + local below2 = vector.add(below1, {x=0,y=-1,z=0}) + + local miners = 0 + local nodes = {} + + local cpos = minetest.pos_to_string(controller) + + if ele.helpers.node_compare(below1, "elepower_mining:miner_core") and + ele.helpers.node_compare(below2, "elepower_mining:miner_drill") then + table.insert(nodes, below1) + table.insert(nodes, below2) + miners = 1 + end + + if miners == 0 then + if structures[cpos] then + structures[cpos] = nil + end + return false + end + + for x = -1, 1 do + for z = -1, 1 do + if not (x == 0 and z == 0) then + local duct = vector.add(controller, {x=x,y=-1,z=z}) + local appr = vector.add(duct, {x=0,y=-1,z=0}) + if ele.helpers.node_compare(appr, "elepower_mining:miner_drill") and + ele.helpers.node_compare(duct, "group:fluid_transport") then + table.insert(nodes, duct) + table.insert(nodes, appr) + miners = miners + 1 + end + end + end + end + + structures[cpos] = { + miners = miners, + nodes = nodes + } + + if player then + minetest.chat_send_player(player, string.format("Miner structure complete (detected %d drills)!", miners)) + end + + local t = minetest.get_node_timer(controller) + if not t:is_started() then + t:start(1.0) + end + + return true, miners, nodes +end + +local function get_mining_results(drills) + local results = {} + local amount = math.random(0, 1 * drills) + + for i = 0, amount do + local ores = {} + for _,def in pairs(minetest.registered_ores) do + table.insert(ores, def.ore) + end + + local picked = math.random(1, #ores) + local count = math.random(1, 3) + local drops = minetest.get_node_drops(ores[picked], "elepower_tools:hand_drill") + for _,stack in pairs(drops) do + stack = ItemStack(stack) + stack:set_count(count) + table.insert(results, stack) + end + end + + return results +end + +local function get_formspec(timer, power, buffer, state) + if not timer then + timer = 0 + end + + return "size[8,8.5]".. + default.gui_bg.. + default.gui_bg_img.. + default.gui_slots.. + ele.formspec.power_meter(power).. + ele.formspec.state_switcher(0, 0, state).. + ele.formspec.fluid_bar(7, 0, buffer).. + ele.formspec.create_bar(1, 0, 100 - timer, "#00ff11", true).. + "list[context;dst;1.5,0;5,3;]".. + "list[current_player;main;0,4.25;8,1;]".. + "list[current_player;main;0,5.5;8,3;8]".. + "listring[current_player;main]".. + "listring[context;dst]".. + "listring[current_player;main]".. + default.get_hotbar_bg(0, 4.25) +end + +local function on_timer(pos, elapsed) + local refresh = false + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + + local buffer = fluid_lib.get_buffer_data(pos, "input") + local state = meta:get_int("state") + local work = meta:get_int("work") + + local is_enabled = ele.helpers.state_enabled(meta, pos, state) + local capacity = ele.helpers.get_node_property(meta, pos, "capacity") + local usage = ele.helpers.get_node_property(meta, pos, "usage") + local storage = ele.helpers.get_node_property(meta, pos, "storage") + + local pow_buffer = {capacity = capacity, storage = storage, usage = 0} + local active = "with Invalid structure - Punch to redetect" + local miners = 0 + + local pts = minetest.pos_to_string(pos) + while true do + if not structures[pts] then break end + + active = "Idle" + miners = structures[pts].miners + + usage = usage * miners + + if storage < usage then + active = "Out of Power!" + break + end + + active = string.format("Mining with %d miners", miners) + pow_buffer.usage = usage + + if work < TIMER then + work = work + 1 + pow_buffer.storage = pow_buffer.storage - usage + break + end + + -- Get some lumps + local added = 0 + local itms = get_mining_results(miners) + for _,stack in pairs(itms) do + if inv:room_for_item("dst", stack) then + inv:add_item("dst", stack) + added = added + 1 + end + end + + if added == 0 then + active = "Inventory full!" + refresh = false + break + end + + pow_buffer.storage = pow_buffer.storage - usage + work = 0 + refresh = true + break + end + + local wp = math.floor(work / TIMER * 100) + + meta:set_string("infotext", ("Miner %s\n%s"):format(active, + ele.capacity_text(capacity, storage))) + meta:set_string("formspec", get_formspec(wp, pow_buffer, buffer, state)) + meta:set_int("storage", pow_buffer.storage) + meta:set_int("work", work) + + return refresh +end + +local function recalc_on_break(pos) + for core,data in pairs(structures) do + local cp = minetest.string_to_pos(core) + local match = false + for _,ipos in pairs(data.nodes) do + if vector.equals(pos, ipos) then + match = true + determine_structure(cp) + break + end + end + if match then break end + end +end + +ele.register_machine("elepower_mining:miner_controller", { + description = "Miner Controller\nMachine Component", + tiles = { + "elepower_machine_top.png^elepower_power_port.png", "elepower_machine_base.png^elepower_power_port.png", + "elepower_machine_side.png^elepower_power_port.png", + "elepower_machine_side.png^elepower_power_port.png", "elepower_machine_side.png^elepower_power_port.png", + "elepower_machine_side.png^elenuclear_fusion_controller.png", + }, + fluid_buffers = { + input = { + capacity = 8000, + accepts = {"default:water_source"}, + drainable = false, + }, + }, + ele_capacity = 320000, + ele_inrush = 1200, + ele_usage = 128, + paramtype2 = "facedir", + groups = {fluid_container = 1, oddly_breakable_by_hand = 1, cracky = 1, tube = 1, ele_user = 1}, + on_construct = function (pos) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + + inv:set_size("dst", 5*3) + + meta:set_string("formspec", get_formspec()) + end, + on_timer = on_timer, + on_punch = function (pos, node, puncher, pointed_thing) + determine_structure(pos, puncher:get_player_name()) + minetest.node_punch(pos, node, puncher, pointed_thing) + end, +}) + +minetest.register_node("elepower_mining:miner_core", { + description = "Miner Core\nMachine Component", + tiles = { + "elepower_mining_core.png^elepower_power_port.png", "elepower_mining_core.png^elepower_power_port.png", + "elepower_mining_core.png^elepower_power_port.png", + "elepower_mining_core.png^elepower_power_port.png", "elepower_mining_core.png^elepower_power_port.png", + "elepower_mining_core.png^elepower_power_port.png", + }, + groups = {fluid_container = 1, oddly_breakable_by_hand = 1, cracky = 1}, + after_dig_node = recalc_on_break, +}) + +minetest.register_node("elepower_mining:miner_drill", { + description = "Miner Drill\nMachine Component", + tiles = { + "elepower_machine_top.png^elepower_power_port.png", "elepower_mining_apparatus_base.png", "elepower_mining_apparatus_side.png", + "elepower_mining_apparatus_side.png", "elepower_mining_apparatus_side.png", "elepower_mining_apparatus_side.png", + }, + groups = {fluid_container = 1, oddly_breakable_by_hand = 1, cracky = 1}, + after_dig_node = recalc_on_break, +}) + +minetest.register_lbm({ + label = "Enable Miners on load", + name = "elepower_mining:load_miner_controllers", + nodenames = {"elepower_mining:miner_controller"}, + run_at_every_load = true, + action = function (pos) + determine_structure(pos) + end, +}) diff --git a/elepower_mining/mod.conf b/elepower_mining/mod.conf new file mode 100644 index 0000000..8b5fb98 --- /dev/null +++ b/elepower_mining/mod.conf @@ -0,0 +1,3 @@ +name = elepower_mining +description = Elepower powered mining equipment! +depends = elepower_papi,elepower_tools diff --git a/elepower_mining/textures/elepower_mining_apparatus_base.png b/elepower_mining/textures/elepower_mining_apparatus_base.png new file mode 100644 index 0000000000000000000000000000000000000000..1d21304bd31e21eef5c6497a87f7447d4829856b GIT binary patch literal 647 zcmV;20(kw2P)Px#24YJ`L;zC&EdYI((biS~000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2jdGD z6bJ&_;(ap!0013nR9JLFZ*6U5Zgc_CX>@2HM@dakWG-a~0005r zNklpB32VL(->wE}Q|e@{ekI2?W(%urRjt|KB)RYg@Pr7*8D z%LQg@H6j?t@ggMu2W6TjRJE=7|2KfSJ5Ntf7pa@y!gjkQGa1Jb zfc<_Cz;?TBS+V(rt=DTJg45~LZmPA?bsZwYFbo$FzrMbvl!A%~=kpmeYcL~%Ibbua hIXE+$tE(#j{s5@Jbi-{SXm9`k002ovPDHLkV1n-W3S0mH literal 0 HcmV?d00001 diff --git a/elepower_mining/textures/elepower_mining_apparatus_side.png b/elepower_mining/textures/elepower_mining_apparatus_side.png new file mode 100644 index 0000000000000000000000000000000000000000..e8f452ab7c13d890e11bfc3ce05a68504f421e85 GIT binary patch literal 448 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^NEH zbQx-AT)Y+r6yYrJh%9Dc;1&j9Muu5)B!GhKC7!;n?2oy{MOXw{-Z_^8g=8~BB1)X| zb8}PkN`PDj2Ir#G#FEq$h4Rdj3}c-3o% zQ1?4;rz462)!VfhGBjI*yi_l&+xp~4yh*6>>N8oqJo0C9%I@DiY3c8~?)q!<#kYiy zi5UJWa;?6%=fkg$$6h5K-7B$OnQcSuojai~w!eG)yF%Rkln^NRkk_9f5v zS6*Io=*%;hbCSl&&v^`vA6)q<_Il<0?{zkEwo9L!F27znFX)%y{Gg(jzwhZ!=iYs{ n?`zdr1D-pdul*O{KYT#k_tUq=*k8Q)ps@3F^>bP0l+XkKjViTn literal 0 HcmV?d00001 diff --git a/elepower_mining/textures/elepower_mining_core.png b/elepower_mining/textures/elepower_mining_core.png new file mode 100644 index 0000000000000000000000000000000000000000..e5e58b3b2839aa92d8fe14a0f4e4c0b93fc75bb5 GIT binary patch literal 705 zcmV;y0zUnTP)Px#24YJ`L;zC&EdYI((biS~000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2jdGD z6cZvzx|U%80013nR9JLFZ*6U5Zgc_CX>@2HM@dakWG-a~0006Q zNkl<(T5CiE?>*jo0F+WR zO#?vFG-#~>Fy4ENF&JY2&|0^NA`DJW0Jy)u4<7?mRfX1?x~@?jAkTA7Pfu~q@%Hw{ zucs&CI3|u`o}Zt|^E~9_c}^5X0LbCtp*O~Gc6LUu*TXpnz;HO^@$nIWe!tJ{?JWS- zT8g4z_3*%^ERlnQ10TmR&N-&jDZO3~0O#DdyR{a8q9~Zp=j`n4P?jai7(-Q6{7-bl z)LNsu$-ln7G8&C=&V}k(mXT#ypj{LN=jZ1*=MWK;Qf&(t7Z=2FOp+v_N|t4e$74i< z#bWX8t*R-uf^8Wq~K$0XBMFGHgJf^N| z_V@Q&ABYGd!tU-a%jJ?ZO-a*~^?FT`Bmr!##aheF%?*2ddx%Ku&|t~mPW-6~BGNJ_ z%aW?9m`o<2@_M~yI2;DRXfz5cSZleux@y5nVF0$awwTRkOs7-k^Eo2IX0r+Y@ZK|< z&G6oHd3nk8^)=hu+wBmKkB@y6MS)UX*BE0E5e9<+0ISuCvMlMgR%?ycn$OSAR)ubL nyR+*tiX!T|4lMp&YZ2iK;5i?dYy_T000000NkvXXu0mjf)nzfG literal 0 HcmV?d00001 diff --git a/elepower_papi/helpers.lua b/elepower_papi/helpers.lua index 5b1ed3c..755ae27 100644 --- a/elepower_papi/helpers.lua +++ b/elepower_papi/helpers.lua @@ -47,6 +47,16 @@ function ele.helpers.flatten(map) return list end +function ele.helpers.node_compare(pos, name) + local node = minetest.get_node_or_nil(pos) + if not node then return false end + if name:match("^group:") then + return ele.helpers.get_item_group(node.name, name:sub(7)) + end + if node.name ~= name then return false end + return true +end + function ele.helpers.get_node_property(meta, pos, prop) local value = meta:get_int(prop)