Add new turbine -metan
This commit is contained in:
parent
efc6e02d15
commit
216b65da25
|
@ -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"}
|
||||
}
|
||||
})
|
|
@ -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")
|
||||
dofile(path .. "/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
|
Loading…
Reference in New Issue