1
0
mirror of https://github.com/paramat/watershed.git synced 2025-10-25 22:35:25 +02:00

Terrain, biome noises tuned. More floatlands. Bugfix: set under table to 0

This commit is contained in:
paramat
2014-04-16 12:31:00 +01:00
parent aab16376e6
commit d2d8c88571
2 changed files with 21 additions and 45 deletions

View File

@@ -1,4 +1,4 @@
watershed 0.3.10 by paramat watershed 0.3.11 by paramat
For latest stable Minetest back to 0.4.8 For latest stable Minetest back to 0.4.8
Depends default bucket Depends default bucket
Licenses: code WTFPL, textures CC BY-SA Licenses: code WTFPL, textures CC BY-SA

View File

@@ -1,13 +1,13 @@
-- watershed 0.3.10 by paramat -- watershed 0.3.11 by paramat
-- For latest stable Minetest and back to 0.4.8 -- For latest stable Minetest and back to 0.4.8
-- Depends default bucket -- Depends default bucket
-- License: code WTFPL, textures CC BY-SA -- License: code WTFPL, textures CC BY-SA
-- Red cobble texture CC BY-SA by brunob.santos -- Red cobble texture CC BY-SA by brunob.santos
-- remove randomness from n_temp n_humid -- terrain and biome noise changes
-- bugfix: initialise under table -- bugfix: under table set to 0
-- TODO -- bugfix: reset icetet value
-- all 2 octaves to 3 octaves for better shapes -- more floatlands, spikier mountains
-- Parameters -- Parameters
@@ -25,7 +25,7 @@ local XLSAMP = 0.2 -- Extra large scale height variation amplitude
local BASAMP = 0.4 -- Base terrain amplitude local BASAMP = 0.4 -- Base terrain amplitude
local CANAMP = 0.4 -- Canyon terrain amplitude local CANAMP = 0.4 -- Canyon terrain amplitude
local CANEXP = 1.33 -- Canyon shape exponent local CANEXP = 1.33 -- Canyon shape exponent
local ATANAMP = 1.2 -- Arctan function amplitude, smaller = more and larger floatlands above ridges local ATANAMP = 1.1 -- Arctan function amplitude, smaller = more and larger floatlands above ridges
local TSTONE = 0.02 -- Density threshold for stone, depth of soil at TERCEN local TSTONE = 0.02 -- Density threshold for stone, depth of soil at TERCEN
local TRIV = -0.02 -- Maximum densitybase threshold for river water local TRIV = -0.02 -- Maximum densitybase threshold for river water
@@ -38,7 +38,7 @@ local BERGDEP = 32 -- Maximum iceberg depth
local HITET = 0.35 -- High temperature threshold local HITET = 0.35 -- High temperature threshold
local LOTET = -0.35 -- Low .. local LOTET = -0.35 -- Low ..
local ICETET = -0.35 -- Ice .. local ICETET = -0.7 -- Ice ..
local HIHUT = 0.35 -- High humidity threshold local HIHUT = 0.35 -- High humidity threshold
local LOHUT = -0.35 -- Low .. local LOHUT = -0.35 -- Low ..
local BLEND = 0.03 -- Biome blend randomness local BLEND = 0.03 -- Biome blend randomness
@@ -47,15 +47,15 @@ local PINCHA = 36 -- Pine tree 1/x chance per node
local APTCHA = 36 -- Appletree local APTCHA = 36 -- Appletree
local FLOCHA = 36 -- Flower local FLOCHA = 36 -- Flower
local FOGCHA = 9 -- Forest grass local FOGCHA = 9 -- Forest grass
local GRACHA = 4 -- Grassland grasses local GRACHA = 5 -- Grassland grasses
local JUTCHA = 16 -- Jungletree local JUTCHA = 16 -- Jungletree
local JUGCHA = 9 -- Junglegrass local JUGCHA = 9 -- Junglegrass
local CACCHA = 841 -- Cactus local CACCHA = 841 -- Cactus
local DRYCHA = 169 -- Dry shrub local DRYCHA = 169 -- Dry shrub
local PAPCHA = 2 -- Papyrus local PAPCHA = 2 -- Papyrus
local ACACHA = 529 -- Acacia tree local ACACHA = 841 -- Acacia tree
local GOGCHA = 4 -- Golden grass local GOGCHA = 5 -- Golden grass
local DUGCHA = 4 -- Dune grass local DUGCHA = 5 -- Dune grass
-- 3D noise for rough terrain -- 3D noise for rough terrain
@@ -76,7 +76,7 @@ local np_smooth = {
spread = {x=512, y=512, z=512}, spread = {x=512, y=512, z=512},
seed = 593, seed = 593,
octaves = 6, octaves = 6,
persist = 0.4 persist = 0.33
} }
-- 3D noise for fissures -- 3D noise for fissures
@@ -97,7 +97,7 @@ local np_temp = {
scale = 1, scale = 1,
spread = {x=512, y=512, z=512}, spread = {x=512, y=512, z=512},
seed = 9130, seed = 9130,
octaves = 2, octaves = 3,
persist = 0.5 persist = 0.5
} }
@@ -108,7 +108,7 @@ local np_humid = {
scale = 1, scale = 1,
spread = {x=512, y=512, z=512}, spread = {x=512, y=512, z=512},
seed = -55500, seed = -55500,
octaves = 2, octaves = 3,
persist = 0.5 persist = 0.5
} }
@@ -130,7 +130,7 @@ local np_strata = {
scale = 1, scale = 1,
spread = {x=512, y=512, z=512}, spread = {x=512, y=512, z=512},
seed = 92219, seed = 92219,
octaves = 2, octaves = 3,
persist = 0.5 persist = 0.5
} }
@@ -142,7 +142,7 @@ local np_base = {
spread = {x=4096, y=4096, z=4096}, spread = {x=4096, y=4096, z=4096},
seed = 8890, seed = 8890,
octaves = 4, octaves = 4,
persist = 0.4 persist = 0.33
} }
-- 2D noise for extra large scale height variation -- 2D noise for extra large scale height variation
@@ -288,10 +288,10 @@ minetest.register_on_generated(function(minp, maxp, seed)
local triv = TRIV * (1 - terblen) -- other values local triv = TRIV * (1 - terblen) -- other values
local tsand = TSAND * (1 - terblen) local tsand = TSAND * (1 - terblen)
local tstone = math.max(TSTONE * (1 + grad * 0.5), 0) local tstone = TSTONE * (1 + grad * 0.5)
local tlava = TLAVA * (1 - n_magma ^ 4 * terblen ^ 16 * 0.5) local tlava = TLAVA * (1 - n_magma ^ 4 * terblen ^ 16 * 0.5)
local ysand = YSAV + n_fissure * SAMP + math.random() * 2 local ysand = YSAV + n_fissure * SAMP + math.random() * 2
local bergdep = math.abs(n_magma) * BERGDEP local bergdep = math.abs(n_seam) * BERGDEP
local nofis = false -- set fissure bool local nofis = false -- set fissure bool
if math.abs(n_fissure) > math.sqrt(density) * FISEXP then if math.abs(n_fissure) > math.sqrt(density) * FISEXP then
@@ -326,8 +326,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
end end
-- overgeneration and in-chunk generation -- overgeneration and in-chunk generation
if y == y0 - 1 then -- node layer below chunk if y == y0 - 1 then -- node layer below chunk, initialise tables
-- set stable table under[si] = 0 -- 0 to stop floating surface nodes bug
if ungen then if ungen then
if nofis and density >= 0 then -- if node solid if nofis and density >= 0 then -- if node solid
stable[si] = 2 stable[si] = 2
@@ -358,30 +358,6 @@ minetest.register_on_generated(function(minp, maxp, seed)
stable[si] = 0 stable[si] = 0
end end
end end
-- set under table
if nofis and density >= 0 and density < tstone then -- if fine materials
if biome == 1 then
under[si] = 1
elseif biome == 2 then
under[si] = 2
elseif biome == 3 then
under[si] = 3
elseif biome == 4 then
under[si] = 4
elseif biome == 5 then
under[si] = 5
elseif biome == 6 then
under[si] = 6
elseif biome == 7 then
under[si] = 7
elseif biome == 8 then
under[si] = 8
elseif biome == 9 then
under[si] = 9
end
else
under[si] = 0
end
elseif y >= y0 and y <= y1 then -- chunk elseif y >= y0 and y <= y1 then -- chunk
-- add nodes and flora -- add nodes and flora
if densitybase >= tlava then -- lava if densitybase >= tlava then -- lava