241 lines
6.0 KiB
Lua
241 lines
6.0 KiB
Lua
|
--[[
|
||
|
|
||
|
TechAge
|
||
|
=======
|
||
|
|
||
|
Copyright (C) 2019 Joachim Stolberg
|
||
|
|
||
|
GPL v3
|
||
|
See LICENSE.txt for more information
|
||
|
|
||
|
TA4 Solar Module and Carriers
|
||
|
|
||
|
]]--
|
||
|
|
||
|
-- for lazy programmers
|
||
|
local P = minetest.string_to_pos
|
||
|
local M = minetest.get_meta
|
||
|
local S = techage.S
|
||
|
|
||
|
local PWR_PERF = 4
|
||
|
|
||
|
local Cable = techage.TA4_Cable
|
||
|
local power = techage.power
|
||
|
|
||
|
local function temperature(pos)
|
||
|
local data = minetest.get_biome_data(pos)
|
||
|
if data then
|
||
|
return math.floor(data.heat) or 0
|
||
|
end
|
||
|
return 0
|
||
|
end
|
||
|
|
||
|
-- return the required param2 for solar modules
|
||
|
local function get_param2(pos, side)
|
||
|
local node = minetest.get_node(pos)
|
||
|
local dir = power.side_to_dir(node.param2, side)
|
||
|
return (dir + 1) % 4
|
||
|
end
|
||
|
|
||
|
-- do we have enough light?
|
||
|
local function light(pos)
|
||
|
pos.y = pos.y + 1
|
||
|
local light = minetest.get_node_light(pos) or 0
|
||
|
pos.y = pos.y - 1
|
||
|
return light >= (minetest.LIGHT_MAX - 1)
|
||
|
end
|
||
|
|
||
|
-- check if solar module is available and has the correct orientation
|
||
|
local function is_solar_module(base_pos, pos, side)
|
||
|
local pos1 = techage.get_pos(pos, side)
|
||
|
if pos1 then
|
||
|
local node = minetest.get_node(pos1)
|
||
|
if node and node.name == "techage:ta4_solar_module" and light(pos1) then
|
||
|
if side == "L" and node.param2 == M(base_pos):get_int("left_param2") then
|
||
|
return true
|
||
|
elseif side == "R" and node.param2 == M(base_pos):get_int("right_param2") then
|
||
|
return true
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
return false
|
||
|
end
|
||
|
|
||
|
-- provide the available power, which is temperature dependent
|
||
|
local function on_getpower1(pos, mem)
|
||
|
local pos1 = {x = pos.x, y = pos.y, z = pos.z}
|
||
|
if is_solar_module(pos, pos1, "L") and is_solar_module(pos, pos1, "R") then
|
||
|
return PWR_PERF * M(pos):get_int("temperature") / 100.0
|
||
|
end
|
||
|
return 0
|
||
|
end
|
||
|
|
||
|
local function on_getpower2(pos, mem)
|
||
|
local pos1 = {x = pos.x, y = pos.y+1, z = pos.z}
|
||
|
if is_solar_module(pos, pos1, "L") and is_solar_module(pos, pos1, "R") then
|
||
|
return PWR_PERF * M(pos):get_int("temperature") / 100.0
|
||
|
end
|
||
|
return 0
|
||
|
end
|
||
|
|
||
|
|
||
|
minetest.register_node("techage:ta4_solar_module", {
|
||
|
description = S("TA4 Solar Module"),
|
||
|
tiles = {
|
||
|
-- up, down, right, left, back, front
|
||
|
"techage_solar_module_top.png",
|
||
|
"techage_solar_module_bottom.png",
|
||
|
},
|
||
|
drawtype = "nodebox",
|
||
|
node_box = {
|
||
|
type = "fixed",
|
||
|
fixed = {
|
||
|
{-1/2, 7/16, -1/2, 1/2, 8/16, 16/16},
|
||
|
},
|
||
|
},
|
||
|
|
||
|
paramtype = "light",
|
||
|
paramtype2 = "facedir",
|
||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||
|
is_ground_content = false,
|
||
|
})
|
||
|
|
||
|
minetest.register_node("techage:ta4_solar_carrier", {
|
||
|
description = S("TA4 Solar Carrier Module"),
|
||
|
tiles = {
|
||
|
-- up, down, right, left, back, front
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten^techage_appl_ta4_cable.png",
|
||
|
"techage_concrete.png^[brighten^techage_appl_ta4_cable.png",
|
||
|
},
|
||
|
drawtype = "nodebox",
|
||
|
node_box = {
|
||
|
type = "fixed",
|
||
|
fixed = {
|
||
|
{-3/8, -8/16, -1/2, 3/8, -6/16, 1/2},
|
||
|
{-1/8, -6/16, -1/2, 1/8, 6/16, 1/2},
|
||
|
{-3/8, 5/16, -1/2, 3/8, 7/16, 1/2},
|
||
|
},
|
||
|
},
|
||
|
|
||
|
after_place_node = function(pos)
|
||
|
M(pos):set_int("temperature", temperature(pos))
|
||
|
M(pos):set_int("left_param2", get_param2(pos, "L"))
|
||
|
M(pos):set_int("right_param2", get_param2(pos, "R"))
|
||
|
end,
|
||
|
|
||
|
paramtype = "light",
|
||
|
paramtype2 = "facedir",
|
||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||
|
is_ground_content = false,
|
||
|
})
|
||
|
|
||
|
minetest.register_node("techage:ta4_solar_carrierB", {
|
||
|
description = S("TA4 Solar Carrier Module B"),
|
||
|
tiles = {
|
||
|
-- up, down, right, left, back, front
|
||
|
"techage_concrete.png^[brighten^techage_appl_ta4_cable.png",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten^techage_appl_ta4_cable.png",
|
||
|
"techage_concrete.png^[brighten^techage_appl_ta4_cable.png",
|
||
|
},
|
||
|
drawtype = "nodebox",
|
||
|
node_box = {
|
||
|
type = "fixed",
|
||
|
fixed = {
|
||
|
{-3/8, -8/16, -1/2, 3/8, -6/16, 1/2},
|
||
|
{-1/8, -6/16, -1/2, 1/8, 8/16, 1/2},
|
||
|
},
|
||
|
},
|
||
|
|
||
|
after_place_node = function(pos)
|
||
|
M(pos):set_int("temperature", temperature(pos))
|
||
|
M(pos):set_int("left_param2", get_param2(pos, "L"))
|
||
|
M(pos):set_int("right_param2", get_param2(pos, "R"))
|
||
|
end,
|
||
|
|
||
|
paramtype = "light",
|
||
|
paramtype2 = "facedir",
|
||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||
|
is_ground_content = false,
|
||
|
})
|
||
|
|
||
|
minetest.register_node("techage:ta4_solar_carrierT", {
|
||
|
description = S("TA4 Solar Carrier Module T"),
|
||
|
tiles = {
|
||
|
-- up, down, right, left, back, front
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
"techage_concrete.png^[brighten",
|
||
|
},
|
||
|
drawtype = "nodebox",
|
||
|
node_box = {
|
||
|
type = "fixed",
|
||
|
fixed = {
|
||
|
{-1/8, -8/16, -1/2, 1/8, 6/16, 1/2},
|
||
|
{-3/8, 5/16, -1/2, 3/8, 7/16, 1/2},
|
||
|
},
|
||
|
},
|
||
|
|
||
|
paramtype = "light",
|
||
|
paramtype2 = "facedir",
|
||
|
groups = {cracky=2, crumbly=2, choppy=2},
|
||
|
is_ground_content = false,
|
||
|
})
|
||
|
|
||
|
techage.power.register_node({"techage:ta4_solar_carrier"}, {
|
||
|
power_network = Cable,
|
||
|
on_getpower = on_getpower1,
|
||
|
conn_sides ={"F", "B"},
|
||
|
})
|
||
|
|
||
|
techage.power.register_node({"techage:ta4_solar_carrierB"}, {
|
||
|
power_network = Cable,
|
||
|
on_getpower = on_getpower2,
|
||
|
conn_sides ={"F", "B"},
|
||
|
})
|
||
|
|
||
|
minetest.register_craft({
|
||
|
output = "techage:ta4_solar_module",
|
||
|
recipe = {
|
||
|
{"techage:ta4_silicon_wafer", "techage:ta4_silicon_wafer", "techage:ta4_silicon_wafer"},
|
||
|
{"default:tin_ingot", "default:copper_ingot", "default:tin_ingot"},
|
||
|
{"", "", ""},
|
||
|
},
|
||
|
})
|
||
|
|
||
|
minetest.register_craft({
|
||
|
output = "techage:ta4_solar_carrierB 2",
|
||
|
recipe = {
|
||
|
{"", "default:steel_ingot", ""},
|
||
|
{"", "techage:ta4_power_cableS", ""},
|
||
|
{"default:steel_ingot", "default:steel_ingot", "default:steel_ingot"},
|
||
|
},
|
||
|
})
|
||
|
|
||
|
minetest.register_craft({
|
||
|
output = "techage:ta4_solar_carrierT 2",
|
||
|
recipe = {
|
||
|
{"default:steel_ingot", "default:steel_ingot", "default:steel_ingot"},
|
||
|
{"", "default:steel_ingot", ""},
|
||
|
{"", "techage:ta4_power_cableS", ""},
|
||
|
},
|
||
|
})
|
||
|
|
||
|
minetest.register_craft({
|
||
|
output = "techage:ta4_solar_carrier",
|
||
|
recipe = {
|
||
|
{"", "techage:ta4_solar_carrierT", ""},
|
||
|
{"", "techage:ta4_solar_carrierB", ""},
|
||
|
{"", "", ""},
|
||
|
},
|
||
|
})
|