From e6f5a35fe5b7e81e725e7f2830d355cc6f0e881a Mon Sep 17 00:00:00 2001 From: h-v-smacker Date: Wed, 16 May 2018 14:38:58 +0300 Subject: Make bridgewood craftable (for repairs etc) --- technic/machines/register/compressor_recipes.lua | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/technic/machines/register/compressor_recipes.lua b/technic/machines/register/compressor_recipes.lua index b36936c..2576952 100644 --- a/technic/machines/register/compressor_recipes.lua +++ b/technic/machines/register/compressor_recipes.lua @@ -45,9 +45,15 @@ if minetest.get_modpath("ethereal") then if minetest.get_modpath("technic_worldgen") or minetest.get_modpath("moretrees") then table.insert(recipes, {"moretrees:rubber_tree_leaves 15", "ethereal:charcoal_lump 1"}) end - + end +if minetest.get_modpath("pathv7") then + table.insert(recipes, {"default:acacia_tree", "pathv7:bridgewood 1"}) + table.insert(recipes, {"default:jungletree", "pathv7:junglewood 1"}) +end + + -- liquid oxygen table.insert(recipes, {"vessels:steel_bottle", "technic:lox"}) -- cgit v1.2.3 From f76bea5a44f7c772a1459265b6b71b30e263eb48 Mon Sep 17 00:00:00 2001 From: h-v-smacker Date: Sun, 27 May 2018 23:42:05 +0300 Subject: grind all rubber tree trunks --- technic/machines/register/compressor_recipes.lua | 4 ++-- technic/machines/register/grindings.lua | 3 ++- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/technic/machines/register/compressor_recipes.lua b/technic/machines/register/compressor_recipes.lua index 2576952..021c393 100644 --- a/technic/machines/register/compressor_recipes.lua +++ b/technic/machines/register/compressor_recipes.lua @@ -49,8 +49,8 @@ if minetest.get_modpath("ethereal") then end if minetest.get_modpath("pathv7") then - table.insert(recipes, {"default:acacia_tree", "pathv7:bridgewood 1"}) - table.insert(recipes, {"default:jungletree", "pathv7:junglewood 1"}) + table.insert(recipes, {"default:acacia_wood", "pathv7:bridgewood 1"}) + table.insert(recipes, {"default:junglewood", "pathv7:junglewood 1"}) end diff --git a/technic/machines/register/grindings.lua b/technic/machines/register/grindings.lua index 9231166..018eed9 100644 --- a/technic/machines/register/grindings.lua +++ b/technic/machines/register/grindings.lua @@ -49,7 +49,8 @@ local default_extract = dye and "dye:brown 2" local grinding_recipes = { {"Common Tree", "group:tree", "group:wood", default_extract }, - {"Rubber Tree", "moretrees:rubber_tree_trunk", rubber_tree_planks, "technic:raw_latex"} + {"Rubber Tree", "moretrees:rubber_tree_trunk", rubber_tree_planks, "technic:raw_latex"}, + {"Rubber Tree", "moretrees:rubber_tree_trunk_empty",rubber_tree_planks, "technic:raw_latex"} } for _, data in pairs(grinding_recipes) do -- cgit v1.2.3 From c84ceedf1eb50e5e189ac42270b9c144f21eff7e Mon Sep 17 00:00:00 2001 From: h-v-smacker Date: Wed, 30 May 2018 23:31:45 +0300 Subject: water-powered grinder --- technic/machines/other/init.lua | 5 + technic/machines/other/water_powered_grinder.lua | 198 +++++++++++++++++++++ .../technic_water_powered_grinder_front.png | Bin 0 -> 417 bytes .../technic_water_powered_grinder_front_active.png | Bin 0 -> 432 bytes ...chnic_water_powered_grinder_front_unpowered.png | Bin 0 -> 382 bytes .../technic_water_powered_grinder_side.png | Bin 0 -> 336 bytes .../textures/technic_water_powered_grinder_top.png | Bin 0 -> 208 bytes 7 files changed, 203 insertions(+) create mode 100644 technic/machines/other/water_powered_grinder.lua create mode 100644 technic/textures/technic_water_powered_grinder_front.png create mode 100644 technic/textures/technic_water_powered_grinder_front_active.png create mode 100644 technic/textures/technic_water_powered_grinder_front_unpowered.png create mode 100644 technic/textures/technic_water_powered_grinder_side.png create mode 100644 technic/textures/technic_water_powered_grinder_top.png diff --git a/technic/machines/other/init.lua b/technic/machines/other/init.lua index f4a82f0..a67d1a1 100644 --- a/technic/machines/other/init.lua +++ b/technic/machines/other/init.lua @@ -8,6 +8,11 @@ if technic.config:get_bool("enable_frames") and minetest.get_modpath("mesecons_m dofile(path.."/frames.lua") end +if minetest.get_modpath("mesecons_hydroturbine") then + dofile(path.."/water_powered_grinder.lua") +end + + -- Coal-powered machines dofile(path.."/coal_alloy_furnace.lua") dofile(path.."/coal_furnace.lua") diff --git a/technic/machines/other/water_powered_grinder.lua b/technic/machines/other/water_powered_grinder.lua new file mode 100644 index 0000000..c5177cd --- /dev/null +++ b/technic/machines/other/water_powered_grinder.lua @@ -0,0 +1,198 @@ + +-- Water-powered grinder. Uses the hydro turbine from mesecons to "power" itself. +-- Can be used along the fuel-powered alloying furnace to get some minimal benefits +-- of the technic mod. Also adds a purpose for mesecon hydroturbine which, despite +-- being beautifully animated, doesn't do much practical in game. + + +local S = technic.getter + +minetest.register_craft({ + output = 'technic:water_powered_grinder', + recipe = { + {'technic:granite', 'technic:granite', 'technic:granite'}, + {'technic:granite', 'technic:wrought_iron_ingot', 'technic:granite'}, + {'default:brick', 'technic:wrought_iron_ingot', 'default:brick'}, + } +}) + +local machine_name = S("Water-powered Grinder") +local formspec = + "size[8,9]".. + "label[0,0;"..machine_name.."]".. + "image[2,2;1,1;technic_power_meter_bg.png]".. + "list[current_name;src;2,1;1,1;]".. + "list[current_name;dst;5,1;2,2;]".. + "list[current_player;main;0,5;8,4;]".. + "listring[current_name;dst]".. + "listring[current_player;main]".. + "listring[current_name;src]".. + "listring[current_player;main]" + +minetest.register_node("technic:water_powered_grinder", { + description = machine_name, + tiles = {"technic_water_powered_grinder_top.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_front.png"}, + paramtype2 = "facedir", + groups = {cracky=2}, + legacy_facedir_simple = true, + sounds = default.node_sound_stone_defaults(), + on_construct = function(pos) + local meta = minetest.get_meta(pos) + meta:set_string("formspec", formspec) + meta:set_string("infotext", machine_name) + local inv = meta:get_inventory() + inv:set_size("src", 1) + inv:set_size("dst", 4) + end, + can_dig = technic.machine_can_dig, + allow_metadata_inventory_put = technic.machine_inventory_put, + allow_metadata_inventory_take = technic.machine_inventory_take, + allow_metadata_inventory_move = technic.machine_inventory_move, +}) + +minetest.register_node("technic:water_powered_grinder_unpowered", { + description = machine_name, + tiles = {"technic_water_powered_grinder_top.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_front_unpowered.png"}, + paramtype2 = "facedir", + drop = "technic:water_powered_grinder", + groups = {cracky=2, not_in_creative_inventory=1}, + legacy_facedir_simple = true, + sounds = default.node_sound_stone_defaults(), + can_dig = technic.machine_can_dig, + allow_metadata_inventory_put = technic.machine_inventory_put, + allow_metadata_inventory_take = technic.machine_inventory_take, + allow_metadata_inventory_move = technic.machine_inventory_move, +}) + +minetest.register_node("technic:water_powered_grinder_active", { + description = machine_name, + tiles = {"technic_water_powered_grinder_top.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_side.png", + "technic_water_powered_grinder_side.png", "technic_water_powered_grinder_front_active.png"}, + paramtype2 = "facedir", + light_source = 8, + drop = "technic:water_powered_grinder", + groups = {cracky=2, not_in_creative_inventory=1}, + legacy_facedir_simple = true, + sounds = default.node_sound_stone_defaults(), + can_dig = technic.machine_can_dig, + allow_metadata_inventory_put = technic.machine_inventory_put, + allow_metadata_inventory_take = technic.machine_inventory_take, + allow_metadata_inventory_move = technic.machine_inventory_move, +}) + +minetest.register_abm({ + label = "Machines: run water-powered grinder", + nodenames = {"technic:water_powered_grinder", "technic:water_powered_grinder_active", "technic:water_powered_grinder_unpowered"}, + interval = 1, + chance = 1, + action = function(pos, node, active_object_count, active_object_count_wider) + local meta = minetest.get_meta(pos) + local inv = meta:get_inventory() + + local recipe = nil + + if not meta:get_int("processing") then + meta:set_int("processing", 0) + end + + local result = technic.get_recipe("grinding", inv:get_list("src")) + + local power_pos = { + {x = -1, y = 0, z = 0}, + {x = 1, y = 0, z = 0}, + {x = 0, y = -1, z = 0}, + {x = 0, y = 1, z = 0}, + {x = 0, y = 0, z = -1}, + {x = 0, y = 0, z = 1} + } + local powered = false + for _,pp in ipairs(power_pos) do + local node = minetest.get_node_or_nil({x = pos.x + pp.x, y = pos.y + pp.y, z = pos.z + pp.z}) + if node and node.name == "mesecons_hydroturbine:hydro_turbine_on" then + powered = true + break + end + end + + if powered then + + if result then + + if meta:get_int("processing") == 5 then + + local percent = 100 + meta:set_string("infotext", S("%s is active"):format(machine_name).." ("..percent.."%)") + meta:set_string("formspec", + "size[8,9]".. + "label[0,0;"..machine_name.."]".. + "image[2,2;1,1;technic_power_meter_bg.png^[lowpart:" .. percent .. ":technic_power_meter_fg.png]".. + "list[current_name;src;2,1;1,1;]".. + "list[current_name;dst;5,1;2,2;]".. + "list[current_player;main;0,5;8,4;]".. + "listring[current_name;dst]".. + "listring[current_player;main]".. + "listring[current_name;src]".. + "listring[current_player;main]") + + local result_stack = ItemStack(result.output) + if inv:room_for_item("dst", result_stack) then + inv:set_list("src", result.new_input) + inv:add_item("dst", result_stack) + end + + meta:set_int("processing", 0) + + local recipe = technic.get_recipe("grinding", inv:get_list("src")) + + if not recipe then + meta:set_string("infotext", S("%s is empty"):format(machine_name)) + technic.swap_node(pos, "technic:water_powered_grinder") + meta:set_string("formspec", formspec) + end + + else + + local percent = math.floor(meta:get_int("processing") / 5 * 100) + meta:set_string("infotext", S("%s is active"):format(machine_name).." ("..percent.."%)") + technic.swap_node(pos, "technic:water_powered_grinder_active") + meta:set_string("formspec", + "size[8,9]".. + "label[0,0;"..machine_name.."]".. + "image[2,2;1,1;technic_power_meter_bg.png^[lowpart:" .. percent .. ":technic_power_meter_fg.png]".. + "list[current_name;src;2,1;1,1;]".. + "list[current_name;dst;5,1;2,2;]".. + "list[current_player;main;0,5;8,4;]".. + "listring[current_name;dst]".. + "listring[current_player;main]".. + "listring[current_name;src]".. + "listring[current_player;main]") + return + + meta:set_int("processing", meta:get_int("processing") + 1) + end + else + meta:set_int("processing", 0) + + meta:set_string("infotext", S("%s is empty"):format(machine_name)) + technic.swap_node(pos, "technic:water_powered_grinder") + meta:set_string("formspec", formspec) + end + + else + + meta:set_int("processing", 0) + + meta:set_string("infotext", S("%s is unpowered"):format(machine_name)) + technic.swap_node(pos, "technic:water_powered_grinder_unpowered") + meta:set_string("formspec", formspec) + end + + + end, +}) + diff --git a/technic/textures/technic_water_powered_grinder_front.png b/technic/textures/technic_water_powered_grinder_front.png new file mode 100644 index 0000000..b5ec2c6 Binary files /dev/null and b/technic/textures/technic_water_powered_grinder_front.png differ diff --git a/technic/textures/technic_water_powered_grinder_front_active.png b/technic/textures/technic_water_powered_grinder_front_active.png new file mode 100644 index 0000000..6720cf8 Binary files /dev/null and b/technic/textures/technic_water_powered_grinder_front_active.png differ diff --git a/technic/textures/technic_water_powered_grinder_front_unpowered.png b/technic/textures/technic_water_powered_grinder_front_unpowered.png new file mode 100644 index 0000000..70e14c7 Binary files /dev/null and b/technic/textures/technic_water_powered_grinder_front_unpowered.png differ diff --git a/technic/textures/technic_water_powered_grinder_side.png b/technic/textures/technic_water_powered_grinder_side.png new file mode 100644 index 0000000..fafaf36 Binary files /dev/null and b/technic/textures/technic_water_powered_grinder_side.png differ diff --git a/technic/textures/technic_water_powered_grinder_top.png b/technic/textures/technic_water_powered_grinder_top.png new file mode 100644 index 0000000..df5a007 Binary files /dev/null and b/technic/textures/technic_water_powered_grinder_top.png differ -- cgit v1.2.3