techage/solar/solarcell.lua

241 lines
6.0 KiB
Lua
Raw Normal View History

2019-09-30 00:37:35 +03:00
--[[
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", ""},
{"", "", ""},
},
})