mirror of
https://github.com/ZNixian/equivalent_exchange.git
synced 2024-12-26 23:17:28 +01:00
added interdiction stone and respective texture
This commit is contained in:
parent
8204443fa9
commit
416865206b
@ -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({
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
BIN
textures/equivalent_exchange_interdiction_stone.png
Normal file
BIN
textures/equivalent_exchange_interdiction_stone.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 719 B |
Loading…
Reference in New Issue
Block a user