added interdiction stone and respective texture

This commit is contained in:
unknown 2015-07-31 14:08:38 -04:00
parent 8204443fa9
commit 416865206b
3 changed files with 84 additions and 41 deletions

@ -1,11 +1,10 @@
collector = { collector = {
emc_gather = function(orig_emc, mark) emc_gather = function(orig_emc, mark,multiplier)
return orig_emc + (10^(mark - 1)) return orig_emc + (10^(mark - 1)) * multiplier
end, end,
emc_transfer = function(mark,pos) emc_transfer = function(mark,pos,multiplier)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local emc = meta:get_int("emc") local emc = meta:get_int("emc")
local newemc = (collector.emc_gather(emc, mark))
local surrounding_nodes = { local surrounding_nodes = {
minetest.get_meta({x = pos.x + 1, y = pos.y, z = pos.z}), minetest.get_meta({x = pos.x + 1, y = pos.y, z = pos.z}),
minetest.get_meta({x = pos.x - 1, y = pos.y, z = pos.z}), minetest.get_meta({x = pos.x - 1, y = pos.y, z = pos.z}),
@ -22,6 +21,7 @@ collector = {
emc_transferable_nodes_length = emc_transferable_nodes_length + 1 emc_transferable_nodes_length = emc_transferable_nodes_length + 1
end end
end end
local newemc = (collector.emc_gather(emc, mark, multiplier))
local distribution = math.floor(newemc / emc_transferable_nodes_length) local distribution = math.floor(newemc / emc_transferable_nodes_length)
for j = 1,emc_transferable_nodes_length do for j = 1,emc_transferable_nodes_length do
meta:set_string("formspec", meta:set_string("formspec",
@ -33,6 +33,13 @@ collector = {
emc_transferable_nodes[j]:set_int("emc", (emc_transferable_nodes[j]:get_int("emc") + distribution)) emc_transferable_nodes[j]:set_int("emc", (emc_transferable_nodes[j]:get_int("emc") + distribution))
end end
end, end,
check_multiplier = function(pos)
local multiplier = 1
if minetest.get_meta({x = pos.x, y = pos.y + 1, z = pos.z}):get_int("multiplier") == 2 then
multiplier = 2
end
return multiplier
end,
} }
-- Registering ABMs -- -- Registering ABMs --
@ -44,13 +51,14 @@ minetest.register_abm({
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local emc = meta:get_int("emc") local emc = meta:get_int("emc")
local multiplier = collector.check_multiplier(pos)
meta:set_string("formspec", meta:set_string("formspec",
"size[6,1.5]".. "size[6,1.5]"..
"label[0,0;Energy Collector Mark 1]".. "label[0,0;Energy Collector Mark 1]"..
"label[4,0;EMC Stored: "..collector.emc_gather(emc,1).."]".. "label[4,0;EMC Stored: "..collector.emc_gather(emc,1,multiplier).."]"..
"list[current_name;container;0,0.5;6,1;]") "list[current_name;container;0,0.5;6,1;]")
meta:set_int("emc",collector.emc_gather(emc,1)) meta:set_int("emc",collector.emc_gather(emc,1,multiplier))
collector.emc_transfer(1,pos) collector.emc_transfer(1,pos,multiplier)
end, end,
}) })
@ -61,13 +69,14 @@ minetest.register_abm({
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local emc = meta:get_int("emc") local emc = meta:get_int("emc")
local multiplier = collector.check_multiplier(pos)
meta:set_string("formspec", meta:set_string("formspec",
"size[6,1.5]".. "size[6,1.5]"..
"label[0,0;Energy Collector Mark 2]".. "label[0,0;Energy Collector Mark 2]"..
"label[4,0;EMC Stored: "..collector.emc_gather(emc,2).."]".. "label[4,0;EMC Stored: "..collector.emc_gather(emc,2,multiplier).."]"..
"list[current_name;container;0,0.5;6,1;]") "list[current_name;container;0,0.5;6,1;]")
meta:set_int("emc",collector.emc_gather(emc,2)) meta:set_int("emc",collector.emc_gather(emc,2,multiplier))
collector.emc_transfer(2,pos) collector.emc_transfer(2,pos,multiplier)
end, end,
}) })
@ -78,13 +87,14 @@ minetest.register_abm({
action = function(pos, node, active_object_count, active_object_count_wider) action = function(pos, node, active_object_count, active_object_count_wider)
local meta = minetest.get_meta(pos) local meta = minetest.get_meta(pos)
local emc = meta:get_int("emc") local emc = meta:get_int("emc")
local multiplier = collector.check_multiplier(pos)
meta:set_string("formspec", meta:set_string("formspec",
"size[6,1.5]".. "size[6,1.5]"..
"label[0,0;Energy Collector Mark 3]".. "label[0,0;Energy Collector Mark 3]"..
"label[4,0;EMC Stored: "..collector.emc_gather(emc,3).."]".. "label[4,0;EMC Stored: "..collector.emc_gather(emc,3,multiplier).."]"..
"list[current_name;container;0,0.5;6,1;]") "list[current_name;container;0,0.5;6,1;]")
meta:set_int("emc",collector.emc_gather(emc,3)) meta:set_int("emc",collector.emc_gather(emc,3,multiplier))
collector.emc_transfer(3,pos) collector.emc_transfer(3,pos,multiplier)
end, end,
}) })
@ -191,6 +201,28 @@ minetest.register_node("equivalent_exchange:energy_collector_mk3", {
end, end,
emc = 529605 emc = 529605
}) })
minetest.register_node("equivalent_exchange:interdiction_stone", {
description = "Interdiction Stone",
tiles = {
"equivalent_exchange_interdiction_stone.png",
"equivalent_exchange_interdiction_stone.png",
"equivalent_exchange_interdiction_stone.png",
"equivalent_exchange_interdiction_stone.png",
"equivalent_exchange_interdiction_stone.png",
"equivalent_exchange_interdiction_stone.png"
},
paramtype2 = "facedir",
groups = {cracky = 1},
is_ground_content = false,
sounds = default.node_sound_stone_defaults(),
light_source = 10,
on_construct = function(pos)
local meta = minetest.get_meta(pos)
meta:set_int("multiplier", 2)
end,
})
-- Registering Crafts -- -- Registering Crafts --
minetest.register_craft({ minetest.register_craft({
@ -219,3 +251,12 @@ minetest.register_craft({
{"default:mese", "default:mese", "default:mese"} {"default:mese", "default:mese", "default:mese"}
} }
}) })
minetest.register_craft({
output = "equivalent_exchange:interdiction_stone",
recipe = {
{"default:torch", "equivalent_exchange:aeternalis_fuel", "default:torch"},
{"equivalent_exchange:aeternalis_fuel", "equivalent_exchange:philosophers_stone", "equivalent_exchange:aeternalis_fuel"},
{"equivalent_exchange:high_covalence", "equivalent_exchange:high_covalence", "equivalent_exchange:high_covalence"}
}
})

@ -72,3 +72,5 @@ minetest.register_craft({
}) })

Binary file not shown.

After

Width:  |  Height:  |  Size: 719 B