Tidy up ore registrations (#422)

This commit is contained in:
HybridDog 2018-07-21 19:09:27 +02:00 committed by SmallJoker
parent fb93388f06
commit 80c6a14566

View File

@ -1,132 +1,157 @@
local uranium_params = {offset = 0, scale = 1, spread = {x = 100, y = 100, z = 100}, seed = 420, octaves = 3, persist = 0.7} local uranium_params = {
offset = 0,
scale = 1,
spread = {x = 100, y = 100, z = 100},
seed = 420,
octaves = 3,
persist = 0.7
}
local uranium_threshold = 0.55 local uranium_threshold = 0.55
local chromium_params = {offset = 0, scale = 1, spread = {x = 100, y = 100, z = 100}, seed = 421, octaves = 3, persist = 0.7} local chromium_params = {
offset = 0,
scale = 1,
spread = {x = 100, y = 100, z = 100},
seed = 421,
octaves = 3,
persist = 0.7
}
local chromium_threshold = 0.55 local chromium_threshold = 0.55
local zinc_params = {offset = 0, scale = 1, spread = {x = 100, y = 100, z = 100}, seed = 422, octaves = 3, persist = 0.7} local zinc_params = {
offset = 0,
scale = 1,
spread = {x = 100, y = 100, z = 100},
seed = 422,
octaves = 3,
persist = 0.7
}
local zinc_threshold = 0.5 local zinc_threshold = 0.5
local lead_params = {offset = 0, scale = 1, spread = {x = 100, y = 100, z = 100}, seed = 423, octaves = 3, persist = 0.7} local lead_params = {
offset = 0,
scale = 1,
spread = {x = 100, y = 100, z = 100},
seed = 423,
octaves = 3,
persist = 0.7
}
local lead_threshold = 0.3 local lead_threshold = 0.3
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_uranium", ore = "technic:mineral_uranium",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 8*8*8, clust_scarcity = 8*8*8,
clust_num_ores = 4, clust_num_ores = 4,
clust_size = 3, clust_size = 3,
y_min = -300, y_min = -300,
y_max = -80, y_max = -80,
noise_params = uranium_params, noise_params = uranium_params,
noise_threshold = uranium_threshold, noise_threshold = uranium_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_chromium", ore = "technic:mineral_chromium",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 8*8*8, clust_scarcity = 8*8*8,
clust_num_ores = 2, clust_num_ores = 2,
clust_size = 3, clust_size = 3,
y_min = -200, y_min = -200,
y_max = -100, y_max = -100,
noise_params = chromium_params, noise_params = chromium_params,
noise_threshold = chromium_threshold, noise_threshold = chromium_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_chromium", ore = "technic:mineral_chromium",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 6*6*6, clust_scarcity = 6*6*6,
clust_num_ores = 2, clust_num_ores = 2,
clust_size = 3, clust_size = 3,
y_min = -31000, y_min = -31000,
y_max = -200, y_max = -200,
flags = "absheight", flags = "absheight",
noise_params = chromium_params, noise_params = chromium_params,
noise_threshold = chromium_threshold, noise_threshold = chromium_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_zinc", ore = "technic:mineral_zinc",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 8*8*8, clust_scarcity = 8*8*8,
clust_num_ores = 5, clust_num_ores = 5,
clust_size = 7, clust_size = 7,
y_min = -32, y_min = -32,
y_max = 2, y_max = 2,
noise_params = zinc_params, noise_params = zinc_params,
noise_threshold = zinc_threshold, noise_threshold = zinc_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_zinc", ore = "technic:mineral_zinc",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 6*6*6, clust_scarcity = 6*6*6,
clust_num_ores = 4, clust_num_ores = 4,
clust_size = 3, clust_size = 3,
y_min = -31000, y_min = -31000,
y_max = -32, y_max = -32,
flags = "absheight", flags = "absheight",
noise_params = zinc_params, noise_params = zinc_params,
noise_threshold = zinc_threshold, noise_threshold = zinc_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_lead", ore = "technic:mineral_lead",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 9*9*9, clust_scarcity = 9*9*9,
clust_num_ores = 5, clust_num_ores = 5,
clust_size = 3, clust_size = 3,
y_min = -16, y_min = -16,
y_max = 16, y_max = 16,
noise_params = lead_params, noise_params = lead_params,
noise_threshold = lead_threshold, noise_threshold = lead_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_lead", ore = "technic:mineral_lead",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 8*8*8, clust_scarcity = 8*8*8,
clust_num_ores = 5, clust_num_ores = 5,
clust_size = 3, clust_size = 3,
y_min = -128, y_min = -128,
y_max = -16, y_max = -16,
noise_params = lead_params, noise_params = lead_params,
noise_threshold = lead_threshold, noise_threshold = lead_threshold,
}) })
minetest.register_ore({ minetest.register_ore({
ore_type = "scatter", ore_type = "scatter",
ore = "technic:mineral_lead", ore = "technic:mineral_lead",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 6*6*6, clust_scarcity = 6*6*6,
clust_num_ores = 5, clust_num_ores = 5,
clust_size = 3, clust_size = 3,
y_min = -31000, y_min = -31000,
y_max = -128, y_max = -128,
flags = "absheight", flags = "absheight",
noise_params = lead_params, noise_params = lead_params,
noise_threshold = lead_threshold, noise_threshold = lead_threshold,
}) })
-- Sulfur -- Sulfur
local sulfur_buf = {} local sulfur_buf = {}
local sulfur_noise= nil local sulfur_noise
minetest.register_on_generated(function(minp, maxp, seed) minetest.register_on_generated(function(minp, maxp)
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip") local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
local a = VoxelArea:new{ local a = VoxelArea:new({MinEdge=emin, MaxEdge=emax})
MinEdge = {x = emin.x, y = emin.y, z = emin.z},
MaxEdge = {x = emax.x, y = emax.y, z = emax.z},
}
local data = vm:get_data(sulfur_buf) local data = vm:get_data(sulfur_buf)
local pr = PseudoRandom(17 * minp.x + 42 * minp.y + 101 * minp.z) local pr = PseudoRandom(17 * minp.x + 42 * minp.y + 101 * minp.z)
sulfur_noise = sulfur_noise or minetest.get_perlin(9876, 3, 0.5, 100) sulfur_noise = sulfur_noise or minetest.get_perlin(9876, 3, 0.5, 100)
@ -142,7 +167,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
for z = minp.z + math.floor(grid_size / 2), maxp.z, grid_size do for z = minp.z + math.floor(grid_size / 2), maxp.z, grid_size do
local c = data[a:index(x, y, z)] local c = data[a:index(x, y, z)]
if (c == c_lava or c == c_lava_flowing) if (c == c_lava or c == c_lava_flowing)
and sulfur_noise:get3d({x = x, y = z, z = z}) >= 0.4 then and sulfur_noise:get_3d({x = x, y = z, z = z}) >= 0.4 then
for i in a:iter( for i in a:iter(
math.max(minp.x, x - grid_size), math.max(minp.x, x - grid_size),
math.max(minp.y, y - grid_size), math.max(minp.y, y - grid_size),
@ -166,32 +191,37 @@ end)
if technic.config:get_bool("enable_marble_generation") then if technic.config:get_bool("enable_marble_generation") then
minetest.register_ore({ minetest.register_ore({
ore_type = "sheet", ore_type = "sheet",
ore = "technic:marble", ore = "technic:marble",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 1, clust_scarcity = 1,
clust_num_ores = 1, clust_num_ores = 1,
clust_size = 3, clust_size = 3,
y_min = -31000, y_min = -31000,
y_max = -50, y_max = -50,
noise_threshold = 0.4, noise_threshold = 0.4,
noise_params = {offset=0, scale=15, spread={x=150, y=150, z=150}, seed=23, octaves=3, persist=0.70} noise_params = {
}) offset = 0, scale = 15, spread = {x = 150, y = 150, z = 150},
seed = 23, octaves = 3, persist = 0.70
}
})
end end
if technic.config:get_bool("enable_granite_generation") then if technic.config:get_bool("enable_granite_generation") then
minetest.register_ore({ minetest.register_ore({
ore_type = "sheet", ore_type = "sheet",
ore = "technic:granite", ore = "technic:granite",
wherein = "default:stone", wherein = "default:stone",
clust_scarcity = 1, clust_scarcity = 1,
clust_num_ores = 1, clust_num_ores = 1,
clust_size = 4, clust_size = 4,
y_min = -31000, y_min = -31000,
y_max = -150, y_max = -150,
noise_threshold = 0.4, noise_threshold = 0.4,
noise_params = {offset=0, scale=15, spread={x=130, y=130, z=130}, seed=24, octaves=3, persist=0.70} noise_params = {
}) offset = 0, scale = 15, spread = {x = 130, y = 130, z = 130},
seed = 24, octaves = 3, persist = 0.70
}
})
end end