From 216b65da258929810ae642561d98305f73b1b2bd Mon Sep 17 00:00:00 2001 From: ConfidentOwl Date: Fri, 17 Feb 2023 15:18:56 +0300 Subject: [PATCH] Add new turbine -metan --- electro_generator/base_steam_turbins.lua | 101 --------------------- electro_generator/init.lua | 2 +- electro_generator/small_turbins.lua | 111 +++++++++++++++++++++++ 3 files changed, 112 insertions(+), 102 deletions(-) delete mode 100644 electro_generator/base_steam_turbins.lua create mode 100644 electro_generator/small_turbins.lua diff --git a/electro_generator/base_steam_turbins.lua b/electro_generator/base_steam_turbins.lua deleted file mode 100644 index eed201f..0000000 --- a/electro_generator/base_steam_turbins.lua +++ /dev/null @@ -1,101 +0,0 @@ -local S = minetest.get_translator(minetest.get_current_modname()) -local name = minetest.get_current_modname() -local path = minetest.get_modpath(name) - -local function set_formspect_base_steam_turbine(meta) - local fluid_1_name = owl_tech.get_pull_fluid_name(meta,1) - local fluid_1_volume = owl_tech.get_pull_volume(meta,1) - local max_charge = owl_tech:get_charge_max(meta) - local curent_charge = owl_tech:get_charge(meta) - local voltage = owl_tech:get_voltage(meta) - local formspec = "size[9,8.75]".. - "label[0,4;"..minetest.formspec_escape(minetest.colorize("#313131", S("Inventory"))).."]".. - "list[current_player;main;0,4.5;9,3;9]".. - mcl_formspec.get_itemslot_bg(0,4.5,9,3).. - "list[current_player;main;0,7.74;9,1;]".. - mcl_formspec.get_itemslot_bg(0,7.74,9,1).. - "label[2.75,0;"..minetest.formspec_escape(minetest.colorize("#313131", S("Base steam turbin"))).."]".. - "label[0,2.5;"..minetest.formspec_escape(minetest.colorize("#313131", (max_charge.."--"..curent_charge.."--"..voltage))).."]".. - "list[context;battari_slot;2.5,2.5;1,1;]".. - mcl_formspec.get_itemslot_bg(2.5,2.5,1,1).. - "label[0,1.5;"..minetest.formspec_escape(minetest.colorize("#313131", (fluid_1_name.."--"..fluid_1_volume))).."]".. - "listring[current_player;main]".. - "listring[context;battari_slot]".. - "listring[current_player;main]".. - "listring[current_player;main]" - meta:set_string("formspec", formspec) -end - - -minetest.register_node("owl_tech:base_steam_turbin", { - description = S("Base turbine"), - _doc_items_longdesc = S("First generate electro"),-- owl_tech_base_electro_turbine.png - tiles = { - "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)", - "owl_tech_base_meshanism_side.png^[colorize:#575757:128", - "owl_tech_base_meshanism_side.png^[colorize:#575757:128", - "owl_tech_base_meshanism_side.png^[colorize:#575757:128", - "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)^owl_tech_base_electro_turbine.png", - "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)^owl_tech_base_electro_turbine.png", - }, - is_ground_content = false, - stack_max = 64, - groups = {pickaxey=2,owl_tech_electro_gen=1 ,fluid_in=1,fuel=1,dst=1 ,owl_tech_generator=1}, - sounds = mcl_sounds.node_sound_metal_defaults(), - paramtype2 = "facedir", - _mcl_blast_resistance = 6, - _mcl_hardness = 5, - on_construct = function(pos) - local meta = minetest.get_meta(pos) - owl_tech.add_new_pull(meta,16000,1,0) --steam for input - owl_tech.set_pull_fluid_whitlist(meta,1,"owl_tech_steam") --whitlist for make input ONLY Water - owl_tech:add_electro(pos,32,16000) - owl_tech.update_fluid_pipe_around(pos) - set_formspect_base_steam_turbine(meta) - local timer =minetest.get_node_timer(pos) - local inv = meta:get_inventory() - inv:set_size("battari_slot", 1) ---Can charge items in slot WIP - timer:start(0.2) - end, - on_timer = function(pos, elapsed) - local timer = minetest.get_node_timer(pos) - local meta = minetest.get_meta(pos) - local inv = meta:get_inventory() - inv:set_size("battari_slot", 1) - if owl_tech:get_charge_max(meta)-owl_tech:get_charge(meta)>owl_tech:get_voltage(meta)*2 and owl_tech.get_pull_volume(meta,1)>=owl_tech:get_voltage(meta) then - owl_tech.set_pull_volume(meta,1, owl_tech.get_pull_volume(meta,1)-owl_tech:get_voltage(meta) ) - owl_tech:set_charge(meta,owl_tech:get_charge(meta)+owl_tech:get_voltage(meta)*2) - end - if minetest.get_item_group((minetest.get_node({x=pos.x,y=pos.y-1,z=pos.z})).name,"fluid_pipe") then --get from pipe steam - local meta_up = minetest.get_meta({x=pos.x,y=pos.y-1,z=pos.z}) - local can_do ,inde_pull =owl_tech.test_add_fluid_in_any_pulls(meta,"owl_tech_steam",owl_tech.get_fluid_sand_in_tick(meta)) - local can_do2 ,inde_pull_2 , remove_amount =owl_tech.test_remove_fluid_in_any_pulls(meta_up,"owl_tech_steam",owl_tech.get_fluid_sand_in_tick(meta_up)) - if can_do and can_do2 then - owl_tech.add_fluid_in_node_pull(meta,"owl_tech_steam",remove_amount,inde_pull) - owl_tech.remove_fluid_in_node_pull(meta_up,remove_amount,inde_pull) - end - end - if minetest.get_item_group((minetest.get_node({x=pos.x,y=pos.y+1,z=pos.z})).name,"owl_tech_electro_wire") then --send electro in wire - local meta_up = minetest.get_meta({x=pos.x,y=pos.y+1,z=pos.z}) - if owl_tech:get_voltage(meta)==owl_tech:get_voltage(meta_up) and - owl_tech:get_charge(meta)>=owl_tech:get_voltage(meta) and - owl_tech:get_charge_max(meta_up)-owl_tech:get_charge(meta_up)>=owl_tech:get_voltage(meta) then - owl_tech:set_charge(meta,owl_tech:get_charge(meta)-owl_tech:get_voltage(meta)) - owl_tech:set_charge(meta_up,owl_tech:get_charge(meta_up)+owl_tech:get_voltage(meta_up)) - end - end - owl_tech.delit_name_fluid_if_0(meta) - set_formspect_base_steam_turbine(meta) - timer:start(0.2) - end -}) ---Crafte bronze boiler -minetest.register_craft({ - type = "shaped", - output = "owl_tech:base_steam_turbin", - recipe = { - {"owl_tech:steel_plate","owl_tech:steel_plate","owl_tech:steel_plate"}, - {"owl_tech:steel_plate","owl_tech:steel_frames","owl_tech:steel_plate"}, - {"owl_tech:steel_plate","owl_tech:circuit_tire_1","owl_tech:steel_plate"} - } -}) diff --git a/electro_generator/init.lua b/electro_generator/init.lua index b494c19..fabbc4a 100644 --- a/electro_generator/init.lua +++ b/electro_generator/init.lua @@ -2,4 +2,4 @@ local S = minetest.get_translator(minetest.get_current_modname()) local name = minetest.get_current_modname() local path = minetest.get_modpath(name) -dofile(path .. "/electro_generator/base_steam_turbins.lua") \ No newline at end of file +dofile(path .. "/electro_generator/small_turbins.lua") \ No newline at end of file diff --git a/electro_generator/small_turbins.lua b/electro_generator/small_turbins.lua new file mode 100644 index 0000000..a32ba6a --- /dev/null +++ b/electro_generator/small_turbins.lua @@ -0,0 +1,111 @@ +local S = minetest.get_translator(minetest.get_current_modname()) +local name = minetest.get_current_modname() +local path = minetest.get_modpath(name) +--[[ + 1)name 2)Name 3)material mame 4)add_coponent ,5)circuit 6)fluid input 7)energy modif 8)Voltage 9)max-electro + +]] +local small_turbins_conf={ + {"base_steam","Base steam","steel","owl_tech:copper_stick","owl_tech:circuit_tire_1","owl_tech_steam",2,32,16000}, + {"base_metan","Base metan","steel","owl_tech:tin_stick","owl_tech:circuit_tire_1","owl_tech:metan_source",8,32,16000}, +} +for i = 1, #small_turbins_conf, 1 do + + local function set_formspect_base_steam_turbine(meta) + local fluid_1_name = owl_tech.get_pull_fluid_name(meta,1) + local fluid_1_volume = owl_tech.get_pull_volume(meta,1) + local max_charge = owl_tech:get_charge_max(meta) + local curent_charge = owl_tech:get_charge(meta) + local voltage = owl_tech:get_voltage(meta) + local formspec = "size[9,8.75]".. + "label[0,4;"..minetest.formspec_escape(minetest.colorize("#313131", S("Inventory"))).."]".. + "list[current_player;main;0,4.5;9,3;9]".. + mcl_formspec.get_itemslot_bg(0,4.5,9,3).. + "list[current_player;main;0,7.74;9,1;]".. + mcl_formspec.get_itemslot_bg(0,7.74,9,1).. + "label[2.75,0;"..minetest.formspec_escape(minetest.colorize("#313131", S(small_turbins_conf[i][2].." turbin"))).."]".. + "label[0,2.5;"..minetest.formspec_escape(minetest.colorize("#313131", (max_charge.."--"..curent_charge.."--"..voltage))).."]".. + "list[context;battari_slot;2.5,2.5;1,1;]".. + mcl_formspec.get_itemslot_bg(2.5,2.5,1,1).. + "label[0,1.5;"..minetest.formspec_escape(minetest.colorize("#313131", (fluid_1_name.."--"..fluid_1_volume))).."]".. + "listring[current_player;main]".. + "listring[context;battari_slot]".. + "listring[current_player;main]".. + "listring[current_player;main]" + meta:set_string("formspec", formspec) + end + + + minetest.register_node("owl_tech:"..small_turbins_conf[i][1].."turbin", { + description = S(small_turbins_conf[i][2].." turbine"), + _doc_items_longdesc = S("Generate electro"),-- owl_tech_base_electro_turbine.png + tiles = { + "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)", + "owl_tech_base_meshanism_side.png^[colorize:#575757:128", + "owl_tech_base_meshanism_side.png^[colorize:#575757:128", + "owl_tech_base_meshanism_side.png^[colorize:#575757:128", + "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)^owl_tech_base_electro_turbine.png", + "(owl_tech_base_meshanism_side.png^[colorize:#575757:128)^owl_tech_base_electro_turbine.png", + }, + is_ground_content = false, + stack_max = 64, + groups = {pickaxey=2,owl_tech_electro_gen=1 ,fluid_in=1,fuel=1,dst=1 ,owl_tech_generator=1}, + sounds = mcl_sounds.node_sound_metal_defaults(), + paramtype2 = "facedir", + _mcl_blast_resistance = 6, + _mcl_hardness = 5, + on_construct = function(pos) + local meta = minetest.get_meta(pos) + owl_tech.add_new_pull(meta,16000,1,0) --steam for input + owl_tech.set_pull_fluid_whitlist(meta,1,small_turbins_conf[i][6]) --whitlist for make input ONLY Water + owl_tech:add_electro(pos,small_turbins_conf[i][8],small_turbins_conf[i][9]) + owl_tech.update_fluid_pipe_around(pos) + set_formspect_base_steam_turbine(meta) + local timer =minetest.get_node_timer(pos) + local inv = meta:get_inventory() + inv:set_size("battari_slot", 1) ---Can charge items in slot WIP + timer:start(0.2) + end, + on_timer = function(pos, elapsed) + local timer = minetest.get_node_timer(pos) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + inv:set_size("battari_slot", 1) + if owl_tech:get_charge_max(meta)-owl_tech:get_charge(meta)>owl_tech:get_voltage(meta)*small_turbins_conf[i][7] and owl_tech.get_pull_volume(meta,1)>=owl_tech:get_voltage(meta) then + owl_tech.set_pull_volume(meta,1, owl_tech.get_pull_volume(meta,1)-owl_tech:get_voltage(meta) ) + owl_tech:set_charge(meta,owl_tech:get_charge(meta)+owl_tech:get_voltage(meta)*small_turbins_conf[i][7]) + end + if minetest.get_item_group((minetest.get_node({x=pos.x,y=pos.y-1,z=pos.z})).name,"fluid_pipe") then --get from pipe steam + local meta_up = minetest.get_meta({x=pos.x,y=pos.y-1,z=pos.z}) + local can_do ,inde_pull =owl_tech.test_add_fluid_in_any_pulls(meta,small_turbins_conf[i][6],owl_tech.get_fluid_sand_in_tick(meta)) + local can_do2 ,inde_pull_2 , remove_amount =owl_tech.test_remove_fluid_in_any_pulls(meta_up,small_turbins_conf[i][6],owl_tech.get_fluid_sand_in_tick(meta_up)) + if can_do and can_do2 then + owl_tech.add_fluid_in_node_pull(meta,small_turbins_conf[i][6],remove_amount,inde_pull) + owl_tech.remove_fluid_in_node_pull(meta_up,remove_amount,inde_pull) + end + end + if minetest.get_item_group((minetest.get_node({x=pos.x,y=pos.y+1,z=pos.z})).name,"owl_tech_electro_wire") then --send electro in wire + local meta_up = minetest.get_meta({x=pos.x,y=pos.y+1,z=pos.z}) + if owl_tech:get_voltage(meta)==owl_tech:get_voltage(meta_up) and + owl_tech:get_charge(meta)>=owl_tech:get_voltage(meta) and + owl_tech:get_charge_max(meta_up)-owl_tech:get_charge(meta_up)>=owl_tech:get_voltage(meta) then + owl_tech:set_charge(meta,owl_tech:get_charge(meta)-owl_tech:get_voltage(meta)) + owl_tech:set_charge(meta_up,owl_tech:get_charge(meta_up)+owl_tech:get_voltage(meta_up)) + end + end + owl_tech.delit_name_fluid_if_0(meta) + set_formspect_base_steam_turbine(meta) + timer:start(0.2) + end + }) + --Crafte bronze boiler + minetest.register_craft({ + type = "shaped", + output = "owl_tech:"..small_turbins_conf[i][1].."turbin", + recipe = { + {"owl_tech:"..small_turbins_conf[i][1].."_plate",small_turbins_conf[i][4],"owl_tech:"..small_turbins_conf[i][1].."_plate"}, + {small_turbins_conf[i][4],"owl_tech:"..small_turbins_conf[i][1].."_frames",small_turbins_conf[i][4]}, + {"owl_tech:"..small_turbins_conf[i][1].."_plate",small_turbins_conf[i][5],"owl_tech:"..small_turbins_conf[i][1].."_plate"} + } + }) +end