2013-10-27 09:53:05 +01:00
|
|
|
mg = {}
|
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
local DMAX = 20
|
|
|
|
local AREA_SIZE = 80
|
|
|
|
|
|
|
|
minetest.register_on_mapgen_init(function(mgparams)
|
2013-09-28 17:40:43 +02:00
|
|
|
minetest.set_mapgen_params({mgname="singlenode", flags="nolight", flagmask="nolight"})
|
2013-09-15 17:08:41 +02:00
|
|
|
end)
|
|
|
|
|
|
|
|
local cache = {}
|
|
|
|
|
|
|
|
local function cliff(x, n)
|
|
|
|
return 0.2*x*x - x + n*x - n*n*x*x - 0.01 * math.abs(x*x*x) + math.abs(x)*100*n*n*n*n
|
|
|
|
end
|
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
local function get_base_surface_at_point(x, z, vn, vh, ni, noise1, noise2, noise3, noise4)
|
2013-09-20 20:36:53 +02:00
|
|
|
local index = 65536*x+z
|
|
|
|
if cache[index] ~= nil then return cache[index] end
|
2013-10-27 16:48:24 +01:00
|
|
|
cache[index] = 25*noise1[ni]+noise2[ni]*noise3[ni]/3
|
|
|
|
if noise4[ni] > 0.8 then
|
|
|
|
cache[index] = cliff(cache[index], noise4[ni]-0.8)
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
|
|
|
if vn<40 then
|
|
|
|
cache[index] = vh
|
2013-09-21 12:31:38 +02:00
|
|
|
elseif vn<200 then
|
|
|
|
cache[index] = (vh*(200-vn) + cache[index]*(vn-40))/160
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
|
|
|
return cache[index]
|
|
|
|
end
|
|
|
|
|
|
|
|
local function surface_at_point(x, z, ...)
|
|
|
|
return get_base_surface_at_point(x, z, unpack({...}))
|
|
|
|
end
|
|
|
|
|
|
|
|
local SMOOTHED = AREA_SIZE+2*DMAX
|
|
|
|
local HSMOOTHED = AREA_SIZE+DMAX
|
|
|
|
local INSIDE = AREA_SIZE-DMAX
|
|
|
|
|
|
|
|
local function smooth(x, z, ...)
|
|
|
|
local s=0
|
|
|
|
local w=0
|
|
|
|
for xi=-DMAX, DMAX do
|
|
|
|
for zi=-DMAX, DMAX do
|
|
|
|
local d2=xi*xi+zi*zi
|
|
|
|
if d2<DMAX*DMAX then
|
|
|
|
local w1 = 1-d2/(DMAX*DMAX)
|
|
|
|
local w2 = 15/16*w1*w1
|
|
|
|
w = w+w2
|
|
|
|
s=s+w2*surface_at_point(x+xi, z+zi, unpack({...}))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return s/w
|
|
|
|
end
|
|
|
|
|
|
|
|
local function smooth_surface(x, z, vnoise, vx, vz, vs, vh, ...)
|
|
|
|
local vn
|
|
|
|
if vs ~= 0 then
|
|
|
|
vn = (vnoise:get2d({x=x, y=z})-2)*20+(40/(vs*vs))*((x-vx)*(x-vx)+(z-vz)*(z-vz))
|
|
|
|
else
|
2013-09-21 12:31:38 +02:00
|
|
|
vn = 1000
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
|
|
|
return surface_at_point(x, z, vn, vh, unpack({...}))
|
2013-09-15 17:08:41 +02:00
|
|
|
end
|
|
|
|
|
2013-09-22 15:38:07 +02:00
|
|
|
function inside_village(x, z, vx, vz, vs, vnoise)
|
|
|
|
return ((vnoise:get2d({x=x, y=z})-2)*20+(40/(vs*vs))*((x-vx)*(x-vx)+(z-vz)*(z-vz)))<=40
|
|
|
|
end
|
|
|
|
|
2013-09-20 20:36:53 +02:00
|
|
|
minetest.register_on_mapgen_init(function(mgparams)
|
|
|
|
wseed = math.floor(mgparams.seed/10000000000)
|
|
|
|
end)
|
2013-09-21 15:07:43 +02:00
|
|
|
function get_bseed(minp)
|
2013-09-20 20:36:53 +02:00
|
|
|
return wseed + math.floor(5*minp.x/47) + math.floor(873*minp.z/91)
|
|
|
|
end
|
|
|
|
|
2013-09-21 15:07:43 +02:00
|
|
|
function get_bseed2(minp)
|
2013-09-21 19:58:04 +02:00
|
|
|
return wseed + math.floor(87*minp.x/47) + math.floor(73*minp.z/91) + math.floor(31*minp.y/12)
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
|
|
|
|
2013-09-21 18:54:02 +02:00
|
|
|
c_air = minetest.get_content_id("air")
|
|
|
|
c_ignore = minetest.get_content_id("ignore")
|
2013-09-22 07:05:46 +02:00
|
|
|
c_water = minetest.get_content_id("default:water_source")
|
2013-09-20 20:36:53 +02:00
|
|
|
|
2013-09-22 09:28:18 +02:00
|
|
|
local function add_leaves(data, vi, c_leaves, c_snow)
|
|
|
|
if data[vi]==c_air or data[vi]==c_ignore or data[vi] == c_snow then
|
2013-09-20 20:36:53 +02:00
|
|
|
data[vi] = c_leaves
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-21 16:10:55 +02:00
|
|
|
function add_tree(data, a, x, y, z, minp, maxp, c_tree, c_leaves, pr)
|
2013-09-20 20:36:53 +02:00
|
|
|
th = pr:next(3, 4)
|
|
|
|
for yy=math.max(minp.y, y), math.min(maxp.y, y+th) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_tree
|
|
|
|
end
|
|
|
|
maxy = y+th
|
|
|
|
for xx=math.max(minp.x, x-1), math.min(maxp.x, x+1) do
|
|
|
|
for yy=math.max(minp.y, maxy-1), math.min(maxp.y, maxy+1) do
|
|
|
|
for zz=math.max(minp.z, z-1), math.min(maxp.z, z+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for i=1,8 do
|
|
|
|
xi = pr:next(x-2, x+1)
|
|
|
|
yi = pr:next(maxy-1, maxy+1)
|
2013-09-22 09:28:18 +02:00
|
|
|
zi = pr:next(z-2, z+1)
|
2013-09-20 20:36:53 +02:00
|
|
|
for xx=math.max(minp.x, xi), math.min(maxp.x, xi+1) do
|
|
|
|
for yy=math.max(minp.y, yi), math.min(maxp.y, yi+1) do
|
|
|
|
for zz=math.max(minp.z, zi), math.min(maxp.z, zi+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-21 16:10:55 +02:00
|
|
|
function add_jungletree(data, a, x, y, z, minp, maxp, c_tree, c_leaves, pr)
|
2013-09-20 20:36:53 +02:00
|
|
|
th = pr:next(7, 11)
|
|
|
|
for yy=math.max(minp.y, y), math.min(maxp.y, y+th) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_tree
|
|
|
|
end
|
|
|
|
maxy = y+th
|
|
|
|
for xx=math.max(minp.x, x-1), math.min(maxp.x, x+1) do
|
|
|
|
for yy=math.max(minp.y, maxy-1), math.min(maxp.y, maxy+1) do
|
|
|
|
for zz=math.max(minp.z, z-1), math.min(maxp.z, z+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for i=1,30 do
|
|
|
|
xi = pr:next(x-3, x+2)
|
|
|
|
yi = pr:next(maxy-2, maxy+1)
|
|
|
|
zi = pr:next(z-3, z+2)
|
|
|
|
for xx=math.max(minp.x, xi), math.min(maxp.x, xi+1) do
|
|
|
|
for yy=math.max(minp.y, yi), math.min(maxp.y, yi+1) do
|
|
|
|
for zz=math.max(minp.z, zi), math.min(maxp.z, zi+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-21 16:10:55 +02:00
|
|
|
function add_savannatree(data, a, x, y, z, minp, maxp, c_tree, c_leaves, pr)
|
|
|
|
th = pr:next(7, 11)
|
|
|
|
for yy=math.max(minp.y, y), math.min(maxp.y, y+th) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_tree
|
|
|
|
end
|
|
|
|
maxy = y+th
|
|
|
|
for xx=math.max(minp.x, x-1), math.min(maxp.x, x+1) do
|
|
|
|
for yy=math.max(minp.y, maxy-1), math.min(maxp.y, maxy+1) do
|
|
|
|
for zz=math.max(minp.z, z-1), math.min(maxp.z, z+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for i=1,20 do
|
|
|
|
xi = pr:next(x-3, x+2)
|
|
|
|
yi = pr:next(maxy-2, maxy)
|
|
|
|
zi = pr:next(z-3, z+2)
|
|
|
|
for xx=math.max(minp.x, xi), math.min(maxp.x, xi+1) do
|
|
|
|
for yy=math.max(minp.y, yi), math.min(maxp.y, yi+1) do
|
|
|
|
for zz=math.max(minp.z, zi), math.min(maxp.z, zi+1) do
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for i=1,15 do
|
|
|
|
xi = pr:next(x-3, x+2)
|
|
|
|
yy = pr:next(maxy-6, maxy-5)
|
|
|
|
zi = pr:next(z-3, z+2)
|
|
|
|
for xx=math.max(minp.x, xi), math.min(maxp.x, xi+1) do
|
|
|
|
for zz=math.max(minp.z, zi), math.min(maxp.z, zi+1) do
|
2013-09-21 16:43:02 +02:00
|
|
|
if minp.y<=yy and maxp.y>=yy then
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
end
|
2013-09-21 16:10:55 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-21 18:10:26 +02:00
|
|
|
function add_savannabush(data, a, x, y, z, minp, maxp, c_tree, c_leaves, pr)
|
|
|
|
bh = pr:next(1, 2)
|
|
|
|
bw = pr:next(2, 4)
|
|
|
|
|
|
|
|
for xx=math.max(minp.x, x-bw), math.min(maxp.x, x+bw) do
|
|
|
|
for zz=math.max(minp.z, z-bw), math.min(maxp.z, z+bw) do
|
|
|
|
for yy=math.max(minp.y, y-bh), math.min(maxp.y, y+bh) do
|
|
|
|
if pr:next(1, 100) < 95 and math.abs(xx-x) < pr:next(bh, bh+2)-math.abs(y-yy) and math.abs(zz-z) < pr:next(bh, bh+2)-math.abs(y-yy) then
|
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves)
|
|
|
|
for yyy=math.max(minp.y, yy-2), yy do
|
|
|
|
add_leaves(data, a:index(xx, yyy, zz), c_leaves)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-28 19:39:35 +02:00
|
|
|
if x<=maxp.x and x>=minp.x and y<=maxp.y and y>=minp.y and z<=maxp.z and z>=minp.z then
|
|
|
|
local vi = a:index(x, y, z)
|
|
|
|
data[vi] = c_tree
|
|
|
|
end
|
2013-09-21 18:10:26 +02:00
|
|
|
end
|
|
|
|
|
2013-09-22 09:28:18 +02:00
|
|
|
function add_pinetree(data, a, x, y, z, minp, maxp, c_tree, c_leaves, c_snow, pr)
|
2013-09-22 09:21:42 +02:00
|
|
|
th = pr:next(9, 13)
|
|
|
|
for yy=math.max(minp.y, y), math.min(maxp.y, y+th) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_tree
|
|
|
|
end
|
|
|
|
maxy = y+th
|
|
|
|
for xx=math.max(minp.x, x-3), math.min(maxp.x, x+3) do
|
|
|
|
for yy=math.max(minp.y, maxy-1), math.min(maxp.y, maxy-1) do
|
|
|
|
for zz=math.max(minp.z, z-3), math.min(maxp.z, z+3) do
|
|
|
|
if pr:next(1, 100) < 80 then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for xx=math.max(minp.x, x-2), math.min(maxp.x, x+2) do
|
|
|
|
for yy=math.max(minp.y, maxy), math.min(maxp.y, maxy) do
|
|
|
|
for zz=math.max(minp.z, z-2), math.min(maxp.z, z+2) do
|
|
|
|
if pr:next(1, 100) < 85 then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for xx=math.max(minp.x, x-1), math.min(maxp.x, x+1) do
|
|
|
|
for yy=math.max(minp.y, maxy+1), math.min(maxp.y, maxy+1) do
|
|
|
|
for zz=math.max(minp.z, z-1), math.min(maxp.z, z+1) do
|
|
|
|
if pr:next(1, 100) < 90 then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-22 09:31:59 +02:00
|
|
|
if maxy+1<=maxp.y and maxy+1>=minp.y then
|
|
|
|
add_leaves(data, a:index(x, maxy+1, z), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(x, maxy+2, z), c_snow)
|
|
|
|
end
|
2013-09-22 09:21:42 +02:00
|
|
|
my = 0
|
|
|
|
for i=1,20 do
|
|
|
|
xi = pr:next(x-3, x+2)
|
|
|
|
yy = pr:next(maxy-6, maxy-5)
|
|
|
|
zi = pr:next(z-3, z+2)
|
|
|
|
if yy > my then
|
|
|
|
my = yy
|
|
|
|
end
|
|
|
|
for xx=math.max(minp.x, xi), math.min(maxp.x, xi+1) do
|
|
|
|
for zz=math.max(minp.z, zi), math.min(maxp.z, zi+1) do
|
|
|
|
if minp.y<=yy and maxp.y>=yy then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for xx=math.max(minp.x, x-2), math.min(maxp.x, x+2) do
|
|
|
|
for yy=math.max(minp.y, my+1), math.min(maxp.y, my+1) do
|
|
|
|
for zz=math.max(minp.z, z-2), math.min(maxp.z, z+2) do
|
|
|
|
if pr:next(1, 100) < 85 then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for xx=math.max(minp.x, x-1), math.min(maxp.x, x+1) do
|
|
|
|
for yy=math.max(minp.y, my+2), math.min(maxp.y, my+2) do
|
|
|
|
for zz=math.max(minp.z, z-1), math.min(maxp.z, z+1) do
|
|
|
|
if pr:next(1, 100) < 90 then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_leaves(data, a:index(xx, yy, zz), c_leaves, c_snow)
|
|
|
|
add_leaves(data, a:index(xx, yy+1, zz), c_snow)
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-09-22 18:14:27 +02:00
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/we.lua")
|
2013-09-21 16:10:55 +02:00
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/nodes.lua")
|
2013-09-22 11:11:38 +02:00
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/rotate.lua")
|
2013-09-21 15:07:43 +02:00
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/buildings.lua")
|
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/villages.lua")
|
2013-09-21 18:54:02 +02:00
|
|
|
dofile(minetest.get_modpath(minetest.get_current_modname()).."/ores.lua")
|
2013-09-21 15:07:43 +02:00
|
|
|
|
2013-09-21 17:21:34 +02:00
|
|
|
local function get_biome_table(minp, humidity, temperature)
|
|
|
|
l = {}
|
|
|
|
for xi = -1, 1 do
|
|
|
|
for zi = -1, 1 do
|
|
|
|
mnp, mxp = {x=minp.x+xi*80,z=minp.z+zi*80}, {x=minp.x+xi*80+80,z=minp.z+zi*80+80}
|
|
|
|
pr = PseudoRandom(get_bseed(mnp))
|
|
|
|
bxp, bzp = pr:next(mnp.x, mxp.x), pr:next(mnp.z, mxp.z)
|
|
|
|
h, t = humidity:get2d({x=bxp, y=bzp}), temperature:get2d({x=bxp, y=bzp})
|
|
|
|
l[#l+1] = {x=bxp, z=bzp, h=h, t=t}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return l
|
|
|
|
end
|
|
|
|
|
|
|
|
local function get_distance(x1, x2, z1, z2)
|
|
|
|
return (x1-x2)*(x1-x2)+(z1-z2)*(z1-z2)
|
|
|
|
end
|
|
|
|
|
|
|
|
local function get_nearest_biome(biome_table, x, z)
|
|
|
|
m = math.huge
|
|
|
|
k = 0
|
|
|
|
for key, bdef in ipairs(biome_table) do
|
|
|
|
local dist = get_distance(bdef.x, x, bdef.z, z)
|
|
|
|
if dist<m then
|
|
|
|
m=dist
|
|
|
|
k=key
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return biome_table[k]
|
|
|
|
end
|
2013-09-22 15:38:07 +02:00
|
|
|
c_air = minetest.get_content_id("air")
|
|
|
|
c_grass = minetest.get_content_id("default:dirt_with_grass")
|
|
|
|
c_dry_grass = minetest.get_content_id("mg:dirt_with_dry_grass")
|
|
|
|
c_dirt_snow = minetest.get_content_id("default:dirt_with_snow")
|
|
|
|
c_snow = minetest.get_content_id("default:snow")
|
|
|
|
c_sapling = minetest.get_content_id("default:sapling")
|
|
|
|
c_tree = minetest.get_content_id("default:tree")
|
|
|
|
c_leaves = minetest.get_content_id("default:leaves")
|
|
|
|
c_junglesapling = minetest.get_content_id("default:junglesapling")
|
|
|
|
c_jungletree = minetest.get_content_id("default:jungletree")
|
|
|
|
c_jungleleaves = minetest.get_content_id("default:jungleleaves")
|
|
|
|
c_savannasapling = minetest.get_content_id("mg:savannasapling")
|
|
|
|
c_savannatree = minetest.get_content_id("mg:savannatree")
|
|
|
|
c_savannaleaves = minetest.get_content_id("mg:savannaleaves")
|
|
|
|
c_pinesapling = minetest.get_content_id("mg:pinesapling")
|
|
|
|
c_pinetree = minetest.get_content_id("mg:pinetree")
|
|
|
|
c_pineleaves = minetest.get_content_id("mg:pineleaves")
|
|
|
|
c_dirt = minetest.get_content_id("default:dirt")
|
|
|
|
c_stone = minetest.get_content_id("default:stone")
|
|
|
|
c_water = minetest.get_content_id("default:water_source")
|
|
|
|
c_ice = minetest.get_content_id("default:ice")
|
|
|
|
c_sand = minetest.get_content_id("default:sand")
|
|
|
|
c_sandstone = minetest.get_content_id("default:sandstone")
|
|
|
|
c_desert_sand = minetest.get_content_id("default:desert_sand")
|
|
|
|
c_desert_stone = minetest.get_content_id("default:desert_stone")
|
|
|
|
c_snowblock = minetest.get_content_id("default:snowblock")
|
|
|
|
c_cactus = minetest.get_content_id("default:cactus")
|
|
|
|
c_grass_1 = minetest.get_content_id("default:grass_1")
|
|
|
|
c_grass_2 = minetest.get_content_id("default:grass_2")
|
|
|
|
c_grass_3 = minetest.get_content_id("default:grass_3")
|
|
|
|
c_grass_4 = minetest.get_content_id("default:grass_4")
|
|
|
|
c_grass_5 = minetest.get_content_id("default:grass_5")
|
|
|
|
c_grasses = {c_grass_1, c_grass_2, c_grass_3, c_grass_4, c_grass_5}
|
|
|
|
c_jungle_grass = minetest.get_content_id("default:junglegrass")
|
|
|
|
c_dry_shrub = minetest.get_content_id("default:dry_shrub")
|
|
|
|
c_papyrus = minetest.get_content_id("default:papyrus")
|
2013-09-21 17:21:34 +02:00
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
local function get_perlin_map(seed, octaves, persistance, scale, minp, maxp)
|
|
|
|
local sidelen = maxp.x - minp.x +1
|
|
|
|
local pm = minetest.get_perlin_map(
|
|
|
|
{offset=0, scale=1, spread={x=scale, y=scale, z=scale}, seed=seed, octaves=octaves, persist=persistance},
|
|
|
|
{x=sidelen, y=sidelen, z=sidelen}
|
|
|
|
)
|
|
|
|
return pm:get2dMap_flat({x = minp.x, y = minp.z, z = 0})
|
|
|
|
end
|
|
|
|
|
2013-10-27 18:53:15 +01:00
|
|
|
local function copytable(t)
|
|
|
|
local t2 = {}
|
|
|
|
for key, val in pairs(t) do
|
|
|
|
t2[key] = val
|
|
|
|
end
|
|
|
|
return t2
|
|
|
|
end
|
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
minetest.register_on_generated(function(minp, maxp, seed)
|
|
|
|
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
|
|
|
|
local a = VoxelArea:new{
|
|
|
|
MinEdge={x=emin.x, y=emin.y, z=emin.z},
|
|
|
|
MaxEdge={x=emax.x, y=emax.y, z=emax.z},
|
|
|
|
}
|
|
|
|
|
2013-09-21 15:07:43 +02:00
|
|
|
local treemin = {x=emin.x, y=minp.y, z=emin.z}
|
|
|
|
local treemax = {x=emax.x, y=maxp.y, z=emax.z}
|
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
local sidelen = maxp.x-minp.x+1
|
|
|
|
|
|
|
|
local noise1 = get_perlin_map(12345, 6, 0.5, 256, minp, maxp)
|
|
|
|
local noise2 = get_perlin_map(56789, 6, 0.5, 256, minp, maxp)
|
|
|
|
local noise3 = get_perlin_map(42, 3, 0.5, 32, minp, maxp)
|
|
|
|
local noise4 = get_perlin_map(8954, 8, 0.5, 1024, minp, maxp)
|
|
|
|
|
|
|
|
local noise1raw = minetest.get_perlin(12345, 6, 0.5, 256)
|
|
|
|
--local noise2 = minetest.get_perlin(56789, 6, 0.5, 256)
|
|
|
|
--local noise3 = minetest.get_perlin(42, 3, 0.5, 32)
|
|
|
|
--local noise4 = minetest.get_perlin(8954, 8, 0.5, 1024)
|
2013-09-22 08:15:22 +02:00
|
|
|
|
2013-09-20 20:36:53 +02:00
|
|
|
local vx,vz,vs,vh
|
2013-09-24 20:02:54 +02:00
|
|
|
local exitloop = false
|
2013-09-20 20:36:53 +02:00
|
|
|
for xi = -1, 1 do
|
|
|
|
for zi = -1, 1 do
|
2013-10-27 16:48:24 +01:00
|
|
|
vx,vz,vs,vh = village_at_point({x=minp.x+xi*80,z=minp.z+zi*80}, noise1raw)
|
2013-09-24 20:02:54 +02:00
|
|
|
if vs ~= 0 then
|
|
|
|
--goto out
|
|
|
|
exitloop = true
|
|
|
|
break
|
|
|
|
end
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
2013-09-24 20:02:54 +02:00
|
|
|
if exitloop then break end
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
2013-09-24 20:02:54 +02:00
|
|
|
--::out::
|
2013-09-15 17:08:41 +02:00
|
|
|
|
2013-09-21 17:21:34 +02:00
|
|
|
|
2013-09-20 20:36:53 +02:00
|
|
|
local pr = PseudoRandom(get_bseed(minp))
|
|
|
|
|
2013-09-28 16:53:25 +02:00
|
|
|
local village_noise = minetest.get_perlin(7635, 3, 0.5, 16)
|
2013-09-15 17:08:41 +02:00
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
--local noise_top_layer = minetest.get_perlin(654, 6, 0.5, 256)
|
|
|
|
--local noise_second_layer = minetest.get_perlin(123, 6, 0.5, 256)
|
|
|
|
local noise_top_layer = get_perlin_map(654, 6, 0.5, 256, minp, maxp)
|
|
|
|
local noise_second_layer = get_perlin_map(123, 6, 0.5, 256, minp, maxp)
|
2013-09-15 17:08:41 +02:00
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
local noise_temperature_raw = minetest.get_perlin(763, 7, 0.5, 512)
|
|
|
|
local noise_humidity_raw = minetest.get_perlin(834, 7, 0.5, 512)
|
|
|
|
--local noise_beach = minetest.get_perlin(452, 6, 0.5, 256)
|
|
|
|
local noise_temperature = get_perlin_map(763, 7, 0.5, 512, minp, maxp)
|
|
|
|
local noise_humidity = get_perlin_map(834, 7, 0.5, 512, minp, maxp)
|
|
|
|
local noise_beach = get_perlin_map(452, 6, 0.5, 256, minp, maxp)
|
2013-09-15 17:08:41 +02:00
|
|
|
|
2013-10-27 16:48:24 +01:00
|
|
|
local biome_table = get_biome_table(minp, noise_humidity_raw, noise_temperature_raw)
|
2013-09-21 17:21:34 +02:00
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
local data = vm:get_data()
|
|
|
|
|
|
|
|
local ni = 1
|
|
|
|
local above_top
|
|
|
|
local liquid_top
|
|
|
|
local top
|
|
|
|
local top_layer
|
|
|
|
local second_layer
|
|
|
|
local humidity
|
|
|
|
local temperature
|
2013-09-22 15:38:07 +02:00
|
|
|
local villages_to_grow = {}
|
2013-10-27 16:48:24 +01:00
|
|
|
local ni = 0
|
2013-09-15 17:08:41 +02:00
|
|
|
for z = minp.z, maxp.z do
|
|
|
|
for x = minp.x, maxp.x do
|
2013-10-27 16:48:24 +01:00
|
|
|
ni = ni + 1
|
|
|
|
local y=math.floor(smooth_surface(x, z, village_noise, vx, vz, vs, vh, ni, noise1, noise2, noise3, noise4))
|
|
|
|
humidity = noise_humidity[ni]
|
|
|
|
temperature = noise_temperature[ni] - math.max(y, 0)/50
|
2013-09-21 17:21:34 +02:00
|
|
|
biome = get_nearest_biome(biome_table, x, z)
|
|
|
|
biome_humidity = biome.h
|
|
|
|
biome_temperature = biome.t
|
|
|
|
if biome_temperature<-0.4 then
|
2013-09-20 20:36:53 +02:00
|
|
|
liquid_top = c_ice
|
|
|
|
else
|
|
|
|
liquid_top = c_water
|
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
if y < -1 then
|
|
|
|
above_top = c_air
|
|
|
|
top = c_dirt
|
|
|
|
top_layer = c_dirt
|
|
|
|
second_layer = c_stone
|
2013-10-27 16:48:24 +01:00
|
|
|
elseif y < 3 and noise_beach[ni]<0.2 then
|
2013-09-21 12:31:38 +02:00
|
|
|
above_top = c_air
|
2013-09-15 17:08:41 +02:00
|
|
|
top = c_sand
|
|
|
|
top_layer = c_sand
|
|
|
|
second_layer = c_sandstone
|
|
|
|
else
|
2013-09-21 12:31:38 +02:00
|
|
|
above_top = c_air
|
2013-09-21 17:21:34 +02:00
|
|
|
if biome_temperature>0.4 then
|
|
|
|
if biome_humidity<-0.4 then
|
2013-09-15 17:08:41 +02:00
|
|
|
top = c_desert_sand
|
|
|
|
top_layer = c_desert_sand
|
|
|
|
second_layer = c_desert_stone
|
2013-09-21 12:31:38 +02:00
|
|
|
if pr:next(1, 50) == 1 then
|
|
|
|
above_top = c_cactus
|
|
|
|
elseif pr:next(1, 50) == 1 then
|
|
|
|
above_top = c_dry_shrub
|
|
|
|
end
|
2013-09-21 17:21:34 +02:00
|
|
|
elseif biome_humidity<0.4 then
|
2013-09-21 16:10:55 +02:00
|
|
|
top = c_dry_grass
|
2013-09-15 17:08:41 +02:00
|
|
|
top_layer = c_dirt
|
|
|
|
second_layer = c_stone
|
2013-09-22 08:51:30 +02:00
|
|
|
if (pr:next(1, 250) == 1 and y>12) or (pr:next(1, 1000) == 1 and y<=12) then
|
2013-09-21 16:10:55 +02:00
|
|
|
above_top = c_savannasapling
|
2013-09-22 08:51:30 +02:00
|
|
|
elseif (pr:next(1, 25) == 1 and y>12) or (pr:next(1, 50) == 1 and y<=12) then
|
2013-09-21 18:10:26 +02:00
|
|
|
if pr:next(1, 80) > 100*(humidity+0.4) then
|
2013-09-21 12:31:38 +02:00
|
|
|
above_top = c_dry_shrub
|
2013-09-21 18:10:26 +02:00
|
|
|
elseif pr:next(1, 100) == 1 then
|
|
|
|
above_top = "savannabush"
|
|
|
|
end
|
2013-09-21 12:31:38 +02:00
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
else
|
2013-09-21 16:43:02 +02:00
|
|
|
if pr:next(1, 14) == 1 then
|
2013-09-15 17:08:41 +02:00
|
|
|
above_top = c_sapling
|
2013-09-21 16:43:02 +02:00
|
|
|
elseif pr:next(1, 16) == 1 then
|
2013-09-20 20:36:53 +02:00
|
|
|
above_top = c_junglesapling
|
2013-09-21 12:31:38 +02:00
|
|
|
elseif pr:next(1, 30) == 1 then
|
|
|
|
above_top = c_jungle_grass
|
2013-09-15 17:08:41 +02:00
|
|
|
end
|
|
|
|
top = c_grass
|
|
|
|
top_layer = c_dirt
|
|
|
|
second_layer = c_stone
|
|
|
|
end
|
2013-09-21 17:21:34 +02:00
|
|
|
elseif biome_temperature<-0.4 then
|
2013-09-15 17:08:41 +02:00
|
|
|
above_top = c_snow
|
|
|
|
top = c_dirt_snow
|
|
|
|
top_layer = c_dirt
|
|
|
|
second_layer = c_stone
|
2013-09-22 09:35:52 +02:00
|
|
|
if biome_humidity>-0.4 then
|
|
|
|
if pr:next(1, 40) == 1 then
|
|
|
|
above_top = c_pinesapling
|
|
|
|
end
|
|
|
|
else
|
|
|
|
if pr:next(1, 500) == 1 then
|
|
|
|
above_top = c_pinesapling
|
|
|
|
end
|
2013-09-22 09:28:18 +02:00
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
else
|
2013-09-21 17:21:34 +02:00
|
|
|
if biome_humidity<-0.4 then
|
|
|
|
if pr:next(1, 250) == 1 then
|
|
|
|
above_top = c_sapling
|
|
|
|
elseif pr:next(1, 60) == 1 then
|
2013-09-21 12:31:38 +02:00
|
|
|
above_top = c_grasses[pr:next(1,4)]
|
|
|
|
end
|
2013-09-21 17:21:34 +02:00
|
|
|
elseif biome_humidity>0.4 then
|
|
|
|
if pr:next(1, 250) == 1 then
|
|
|
|
above_top = c_sapling
|
2013-09-22 09:39:28 +02:00
|
|
|
elseif pr:next(1, 3) == 1 then
|
2013-09-21 12:31:38 +02:00
|
|
|
above_top = c_grasses[pr:next(3,5)]
|
|
|
|
end
|
|
|
|
else
|
|
|
|
if pr:next(1, 20) == 1 and y>0 then
|
2013-09-15 17:08:41 +02:00
|
|
|
above_top = c_sapling
|
|
|
|
end
|
|
|
|
end
|
|
|
|
top = c_grass
|
|
|
|
top_layer = c_dirt
|
|
|
|
second_layer = c_stone
|
|
|
|
end
|
|
|
|
end
|
2013-09-15 18:08:17 +02:00
|
|
|
if y>=100 then
|
|
|
|
above_top = c_air
|
|
|
|
top = c_snow
|
|
|
|
top_layer = c_snowblock
|
|
|
|
end
|
2013-09-21 16:43:02 +02:00
|
|
|
if y<0 then
|
|
|
|
above_top = c_air
|
|
|
|
end
|
2013-09-22 08:42:44 +02:00
|
|
|
if y==0 then
|
|
|
|
if top == c_grass then
|
|
|
|
if pr:next(1, 10) == 1 then
|
|
|
|
above_top = c_papyrus
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-15 18:08:17 +02:00
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
if y<=maxp.y and y>=minp.y then
|
2013-09-28 17:40:43 +02:00
|
|
|
local vi = a:index(x, y, z)
|
|
|
|
if y >= 0 then
|
|
|
|
data[vi] = top
|
|
|
|
else
|
|
|
|
data[vi] = top_layer
|
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
end
|
2013-09-20 20:36:53 +02:00
|
|
|
if above_top == c_sapling then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-21 15:07:43 +02:00
|
|
|
add_tree(data, a, x, y+1, z, treemin, treemax, c_tree, c_leaves, pr)
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_sapling}
|
2013-09-21 15:07:43 +02:00
|
|
|
end
|
2013-09-20 20:36:53 +02:00
|
|
|
elseif above_top == c_junglesapling then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-21 15:07:43 +02:00
|
|
|
add_jungletree(data, a, x, y+1, z, treemin, treemax, c_jungletree, c_jungleleaves, pr)
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_junglesapling}
|
2013-09-21 15:07:43 +02:00
|
|
|
end
|
2013-09-21 16:10:55 +02:00
|
|
|
elseif above_top == c_savannasapling then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-21 16:10:55 +02:00
|
|
|
add_savannatree(data, a, x, y+1, z, treemin, treemax, c_savannatree, c_savannaleaves, pr)
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_savannasapling}
|
2013-09-21 16:10:55 +02:00
|
|
|
end
|
2013-09-21 18:10:26 +02:00
|
|
|
elseif above_top == "savannabush" then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-21 18:10:26 +02:00
|
|
|
add_savannabush(data, a, x, y+1, z, treemin, treemax, c_savannatree, c_savannaleaves, pr)
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content="savannabush"}
|
2013-09-21 18:10:26 +02:00
|
|
|
end
|
2013-09-22 09:21:42 +02:00
|
|
|
elseif above_top == c_pinesapling then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-22 09:28:18 +02:00
|
|
|
add_pinetree(data, a, x, y+1, z, treemin, treemax, c_pinetree, c_pineleaves, c_snow, pr)
|
2013-09-22 10:13:20 +02:00
|
|
|
else
|
|
|
|
if y+1<=maxp.y and y+1>=minp.y then
|
2013-09-28 17:40:43 +02:00
|
|
|
local vi = a:index(x, y+1, z)
|
|
|
|
data[vi] = c_snow
|
2013-09-22 10:13:20 +02:00
|
|
|
end
|
2013-09-22 15:38:07 +02:00
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_pinesapling}
|
2013-09-22 09:21:42 +02:00
|
|
|
end
|
2013-09-21 12:31:38 +02:00
|
|
|
elseif above_top == c_cactus then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-21 15:07:43 +02:00
|
|
|
ch = pr:next(1, 4)
|
|
|
|
for yy = math.max(y+1, minp.y), math.min(y+ch, maxp.y) do
|
|
|
|
data[a:index(x, yy, z)] = c_cactus
|
|
|
|
end
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_cactus}
|
2013-09-21 12:31:38 +02:00
|
|
|
end
|
2013-09-22 08:42:44 +02:00
|
|
|
elseif above_top == c_papyrus then
|
2013-09-22 15:38:07 +02:00
|
|
|
if not inside_village(x, z, vx, vz, vs, village_noise) then
|
2013-09-22 08:42:44 +02:00
|
|
|
ch = pr:next(2, 4)
|
|
|
|
for yy = math.max(y+1, minp.y), math.min(y+ch, maxp.y) do
|
|
|
|
data[a:index(x, yy, z)] = c_papyrus
|
|
|
|
end
|
2013-09-22 15:38:07 +02:00
|
|
|
else
|
|
|
|
villages_to_grow[#villages_to_grow+1] = {x=x, y=y+1, z=z, content=c_papyrus}
|
2013-09-22 08:42:44 +02:00
|
|
|
end
|
2013-09-20 20:36:53 +02:00
|
|
|
else
|
|
|
|
if y+1<=maxp.y and y+1>=minp.y then
|
2013-09-28 17:40:43 +02:00
|
|
|
local vi = a:index(x, y+1, z)
|
|
|
|
data[vi] = above_top
|
2013-09-20 20:36:53 +02:00
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
end
|
|
|
|
if y<0 and minp.y<=0 and maxp.y>y then
|
|
|
|
for yy = math.max(y+1, minp.y), math.min(0, maxp.y) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_water
|
|
|
|
end
|
|
|
|
if maxp.y>=0 then
|
|
|
|
data[a:index(x, 0, z)] = liquid_top
|
|
|
|
end
|
|
|
|
end
|
2013-10-27 16:48:24 +01:00
|
|
|
local tl = math.floor((noise_top_layer[ni]+2.5)*2)
|
2013-09-15 17:08:41 +02:00
|
|
|
if y-tl-1<=maxp.y and y-1>=minp.y then
|
|
|
|
for yy = math.max(y-tl-1, minp.y), math.min(y-1, maxp.y) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = top_layer
|
|
|
|
end
|
|
|
|
end
|
2013-10-27 16:48:24 +01:00
|
|
|
local sl = math.floor((noise_second_layer[ni]+5)*3)
|
2013-09-15 17:08:41 +02:00
|
|
|
if y-sl-1<=maxp.y and y-tl-2>=minp.y then
|
|
|
|
for yy = math.max(y-sl-1, minp.y), math.min(y-tl-2, maxp.y) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = second_layer
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if y-sl-2>=minp.y then
|
|
|
|
for yy = minp.y, math.min(y-sl-2, maxp.y) do
|
|
|
|
local vi = a:index(x, yy, z)
|
|
|
|
data[vi] = c_stone
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-21 18:54:02 +02:00
|
|
|
|
2013-09-21 19:58:04 +02:00
|
|
|
local va = VoxelArea:new{MinEdge=minp, MaxEdge=maxp}
|
2013-09-21 18:54:02 +02:00
|
|
|
|
2013-10-27 18:53:15 +01:00
|
|
|
for _, ore_sheet in ipairs(mg.registered_ore_sheets) do
|
|
|
|
local sidelen = maxp.x - minp.x + 1
|
|
|
|
local np = copytable(ore_sheet.noise_params)
|
|
|
|
np.seed = np.seed + minp.y
|
|
|
|
local pm = minetest.get_perlin_map(np, {x=sidelen, y=sidelen, z=1})
|
|
|
|
local map = pm:get2dMap_flat({x = minp.x, y = minp.z})
|
|
|
|
local ni = 0
|
|
|
|
local trh = ore_sheet.threshhold
|
2013-10-28 08:16:38 +01:00
|
|
|
local wherein = minetest.get_content_id(ore_sheet.wherein)
|
|
|
|
local ore = minetest.get_content_id(ore_sheet.name)
|
2013-10-27 18:53:15 +01:00
|
|
|
local hmin = ore_sheet.height_min
|
|
|
|
local hmax = ore_sheet.height_max
|
|
|
|
local tmin = ore_sheet.tmin
|
|
|
|
local tmax = ore_sheet.tmax
|
|
|
|
for z = minp.z, maxp.z do
|
|
|
|
for x = minp.x, maxp.x do
|
|
|
|
ni = ni+1
|
|
|
|
local noise = map[ni]
|
|
|
|
if noise > trh then
|
|
|
|
local thickness = pr:next(tmin, tmax)
|
2013-10-28 07:28:48 +01:00
|
|
|
local y0 = math.floor(minp.y + (noise-trh)*4)
|
2013-10-27 18:53:15 +01:00
|
|
|
for y = math.max(y0, hmin), math.min(y0+thickness-1, hmax) do
|
|
|
|
local vi = a:index(x, y, z)
|
2013-10-28 07:28:48 +01:00
|
|
|
if data[vi] == wherein or wherein == c_ignore then
|
2013-10-27 18:53:15 +01:00
|
|
|
data[vi] = ore
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-10-27 10:18:38 +01:00
|
|
|
for _, ore in ipairs(mg.registered_ores) do
|
2013-10-28 08:16:38 +01:00
|
|
|
generate_vein(minetest.get_content_id(ore.name), minetest.get_content_id(ore.wherein), minp, maxp, ore.seeddiff, ore, data, a, va)
|
2013-10-27 09:53:05 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
to_add = generate_village(vx, vz, vs, vh, minp, maxp, data, a, village_noise, villages_to_grow)
|
2013-09-21 18:49:24 +02:00
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
vm:set_data(data)
|
2013-09-21 18:49:24 +02:00
|
|
|
|
2013-09-15 17:08:41 +02:00
|
|
|
vm:calc_lighting(
|
|
|
|
{x=minp.x-16, y=minp.y, z=minp.z-16},
|
|
|
|
{x=maxp.x+16, y=maxp.y, z=maxp.z+16}
|
|
|
|
)
|
2013-09-21 18:49:24 +02:00
|
|
|
|
2013-09-21 15:42:00 +02:00
|
|
|
vm:write_to_map(data)
|
2013-09-21 18:49:24 +02:00
|
|
|
|
2013-09-21 15:42:00 +02:00
|
|
|
local meta
|
2013-09-21 19:16:04 +02:00
|
|
|
for _, n in pairs(to_add) do
|
|
|
|
minetest.set_node(n.pos, n.node)
|
|
|
|
if n.meta ~= nil then
|
2013-09-22 18:24:50 +02:00
|
|
|
meta = minetest.get_meta(n.pos)
|
2013-09-21 19:16:04 +02:00
|
|
|
meta:from_table(n.meta)
|
2013-09-28 17:40:43 +02:00
|
|
|
if n.node.name == "default:chest" then
|
|
|
|
inv = meta:get_inventory()
|
|
|
|
items = inv:get_list("main")
|
2013-09-28 17:56:13 +02:00
|
|
|
for i=1, inv:get_size("main") do
|
|
|
|
inv:set_stack("main", i, ItemStack(""))
|
|
|
|
end
|
2013-09-29 09:26:38 +02:00
|
|
|
numitems = pr:next(3, 20)
|
2013-09-28 17:40:43 +02:00
|
|
|
for i=1,numitems do
|
|
|
|
ii = pr:next(1, #items)
|
|
|
|
prob = items[ii]:get_count() % 2 ^ 8
|
|
|
|
stacksz = math.floor(items[ii]:get_count() / 2 ^ 8)
|
2013-09-29 09:26:38 +02:00
|
|
|
if pr:next(0, prob) == 0 and stacksz>0 then
|
|
|
|
stk = ItemStack({name=items[ii]:get_name(), count=pr:next(1, stacksz), wear=items[ii]:get_count(), metadata=items[ii]:get_metadata()})
|
2013-09-28 19:03:49 +02:00
|
|
|
local ind = pr:next(1, inv:get_size("main"))
|
|
|
|
while not inv:get_stack("main",ind):is_empty() do
|
|
|
|
ind = pr:next(1, inv:get_size("main"))
|
|
|
|
end
|
|
|
|
inv:set_stack("main", ind, stk)
|
2013-09-28 17:40:43 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-09-21 19:16:04 +02:00
|
|
|
end
|
2013-09-21 15:42:00 +02:00
|
|
|
end
|
2013-09-15 17:08:41 +02:00
|
|
|
end)
|
2013-10-27 09:53:05 +01:00
|
|
|
|
|
|
|
mg.registered_ores = {}
|
|
|
|
function mg.register_ore(oredef)
|
|
|
|
if oredef.wherein == nil then
|
|
|
|
oredef.wherein = "ignore"
|
|
|
|
end
|
2013-10-27 18:53:15 +01:00
|
|
|
if DEBUG then
|
|
|
|
oredef.wherein = "ignore"
|
|
|
|
oredef.maxheight = 31000
|
|
|
|
end
|
2013-10-27 09:53:05 +01:00
|
|
|
mg.registered_ores[#mg.registered_ores+1] = oredef
|
|
|
|
end
|
|
|
|
|
2013-10-27 18:53:15 +01:00
|
|
|
mg.registered_ore_sheets = {}
|
|
|
|
function mg.register_ore_sheet(oredef)
|
|
|
|
if oredef.wherein == nil then
|
|
|
|
oredef.wherein = "ignore"
|
|
|
|
end
|
2013-10-28 07:28:48 +01:00
|
|
|
if DEBUG then
|
|
|
|
oredef.wherein = "ignore"
|
|
|
|
oredef.height_max = 31000
|
|
|
|
end
|
2013-10-27 18:53:15 +01:00
|
|
|
mg.registered_ore_sheets[#mg.registered_ore_sheets+1] = oredef
|
|
|
|
end
|
|
|
|
|
2013-10-27 09:53:05 +01:00
|
|
|
mg.register_ore({
|
|
|
|
name = "air",
|
2013-10-27 10:18:38 +01:00
|
|
|
seeddiff = 1234,
|
2013-10-27 09:53:05 +01:00
|
|
|
maxhdistance = 70,
|
|
|
|
maxvdistance = 70,
|
|
|
|
maxheight = -3,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0.2,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 5,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 0,
|
|
|
|
mothersizen = -1,
|
|
|
|
mothersizedev = 0,
|
|
|
|
sizen = 100,
|
|
|
|
sizedev = 30,
|
|
|
|
radius = 2.3
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_iron",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 0,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -16,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2.5
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_coal",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 1,
|
|
|
|
maxvdistance = 10,
|
|
|
|
sizen = 54,
|
|
|
|
sizedev = 27,
|
|
|
|
maxheight = 64,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.36,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
radius = 1,
|
|
|
|
numperblock = 6
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_mese",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 2,
|
|
|
|
maxvdistance = 50,
|
|
|
|
sizen = 7,
|
|
|
|
sizedev = 3,
|
|
|
|
maxheight = -128,
|
|
|
|
seglenghtn = 2,
|
|
|
|
seglenghtdev = 1,
|
|
|
|
segincln = 4,
|
|
|
|
segincldev = 1,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 0.8,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
fork_chance = 0.1,
|
|
|
|
mothersizen = 0,
|
|
|
|
mothersizedev = 0
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:mese",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 3,
|
|
|
|
maxvdistance = 50,
|
|
|
|
sizen = 3,
|
|
|
|
sizedev = 1,
|
|
|
|
maxheight = -1024,
|
|
|
|
seglenghtn = 2,
|
|
|
|
seglenghtdev = 1,
|
|
|
|
segincln = 4,
|
|
|
|
segincldev = 1,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
fork_chance = 0.1,
|
|
|
|
radius = 1
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({ -- Same parameters exactly as the previous one so it spawns inside
|
|
|
|
name = "default:lava_source",
|
|
|
|
wherein = "default:mese",
|
|
|
|
seeddiff = 3,
|
|
|
|
maxvdistance = 50,
|
|
|
|
sizen = 3,
|
|
|
|
sizedev = 1,
|
|
|
|
maxheight = -1024,
|
|
|
|
seglenghtn = 2,
|
|
|
|
seglenghtdev = 1,
|
|
|
|
segincln = 4,
|
|
|
|
segincldev = 1,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
fork_chance = 0.1,
|
|
|
|
mothersizen = 0,
|
|
|
|
mothersizedev = 0
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_copper",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 4,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -16,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_diamond",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 5,
|
|
|
|
maxvdistance = 50,
|
2013-10-28 16:55:41 +01:00
|
|
|
sizen = 20,
|
|
|
|
sizedev = 5,
|
2013-10-27 09:53:05 +01:00
|
|
|
maxheight = -256,
|
2013-10-28 16:55:41 +01:00
|
|
|
seglenghtn = 4,
|
|
|
|
seglenghtdev = 2,
|
2013-10-27 09:53:05 +01:00
|
|
|
segincln = 0.3,
|
|
|
|
segincldev = 0.1,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
fork_chance = 0.1,
|
|
|
|
radius = 1
|
|
|
|
})
|
2013-10-27 10:45:23 +01:00
|
|
|
|
2013-10-27 18:53:15 +01:00
|
|
|
mg.register_ore({
|
|
|
|
name = "default:stone_with_gold",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 17,
|
|
|
|
maxvdistance = 10,
|
|
|
|
sizen = 30,
|
|
|
|
sizedev = 8,
|
|
|
|
maxheight = -256,
|
|
|
|
seglenghtn = 8,
|
|
|
|
seglenghtdev = 4,
|
|
|
|
segincln = 0.6,
|
|
|
|
segincldev = 0.4,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
fork_chance = 0.1,
|
|
|
|
radius = 1
|
|
|
|
})
|
|
|
|
|
|
|
|
|
2013-10-27 10:45:23 +01:00
|
|
|
mg.register_ore({
|
|
|
|
name = "default:clay",
|
|
|
|
wherein = "default:dirt",
|
|
|
|
seeddiff = 6,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = 0,
|
|
|
|
minheight = -50,
|
|
|
|
sizen = 50,
|
|
|
|
sizedev = 20,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 1,
|
|
|
|
radius = 1.5
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "default:lava_source",
|
|
|
|
seeddiff = 7,
|
|
|
|
maxhdistance = 20,
|
|
|
|
maxvdistance = 70,
|
|
|
|
maxheight = -100,
|
|
|
|
seglenghtn = 2,
|
|
|
|
seglenghtdev = 1,
|
|
|
|
segincln = -5,
|
|
|
|
segincldev = 2,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 1,
|
|
|
|
numbranchesn = 2,
|
|
|
|
numbranchesdev = 1,
|
|
|
|
mothersizen = 5,
|
|
|
|
mothersizedev = 3,
|
|
|
|
sizen = 8,
|
|
|
|
sizedev = 2,
|
|
|
|
radius = 2.3
|
|
|
|
})
|
2013-10-27 18:53:15 +01:00
|
|
|
|
|
|
|
if minetest.get_modpath("moreores") ~= nil then
|
|
|
|
mg.register_ore({
|
|
|
|
name = "moreores:mineral_tin",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 8,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = 8,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "moreores:mineral_silver",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 9,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -2,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
sizen = 60,
|
|
|
|
sizedev = 30,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "moreores:mineral_mithril",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 9,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -512,
|
|
|
|
seglenghtn = 1,
|
|
|
|
seglenghtdev = 2,
|
|
|
|
sizen = 5,
|
|
|
|
sizedev = 3,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
if minetest.get_modpath("technic") ~= nil then
|
|
|
|
mg.register_ore({
|
|
|
|
name = "technic:mineral_uranium",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 11,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -80,
|
|
|
|
minheight = -300,
|
|
|
|
sizen = 20,
|
|
|
|
sizedev = 10,
|
|
|
|
seglenghtn = 3,
|
|
|
|
seglenghtdev = 1,
|
|
|
|
segincln = 0.4,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
numperblock = 1,
|
|
|
|
fork_chance = 0
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "technic:mineral_chromium",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 12,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = -100,
|
|
|
|
sizen = 50,
|
|
|
|
sizedev = 20,
|
|
|
|
seglenghtn = 8,
|
|
|
|
seglenghtdev = 3,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2
|
|
|
|
})
|
|
|
|
|
|
|
|
mg.register_ore({
|
|
|
|
name = "technic:mineral_zinc",
|
|
|
|
wherein = "default:stone",
|
|
|
|
seeddiff = 13,
|
|
|
|
maxvdistance = 10.5,
|
|
|
|
maxheight = 2,
|
|
|
|
seglenghtn = 15,
|
|
|
|
seglenghtdev = 6,
|
|
|
|
segincln = 0,
|
|
|
|
segincldev = 0.6,
|
|
|
|
turnangle = 57,
|
|
|
|
forkturnangle = 57,
|
|
|
|
numperblock = 2
|
|
|
|
})
|
|
|
|
|
2013-10-28 08:01:28 +01:00
|
|
|
if technic.config:get_bool("enable_granite_generation") then
|
2013-10-27 18:53:15 +01:00
|
|
|
mg.register_ore_sheet({
|
|
|
|
name = "technic:granite",
|
|
|
|
wherein = "default:stone",
|
|
|
|
height_min = -31000,
|
|
|
|
height_max = -150,
|
|
|
|
tmin = 3,
|
|
|
|
tmax = 6,
|
|
|
|
threshhold = 0.4,
|
|
|
|
noise_params = {offset=0, scale=15, spread={x=130, y=130, z=130}, seed=24, octaves=3, persist=0.70}
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
2013-10-28 08:01:28 +01:00
|
|
|
if technic.config:get_bool("enable_marble_generation") then
|
2013-10-27 18:53:15 +01:00
|
|
|
mg.register_ore_sheet({
|
|
|
|
name = "technic:marble",
|
|
|
|
wherein = "default:stone",
|
|
|
|
height_min = -31000,
|
|
|
|
height_max = -50,
|
|
|
|
tmin = 3,
|
|
|
|
tmax = 6,
|
|
|
|
threshhold = 0.4,
|
|
|
|
noise_params = {offset=0, scale=15, spread={x=130, y=130, z=130}, seed=23, octaves=3, persist=0.70}
|
|
|
|
})
|
|
|
|
end
|
|
|
|
end
|