forked from mtcontrib/watershed
Clay at mid temperature
This commit is contained in:
parent
7fd9ef3625
commit
9c85ca40f9
@ -1,4 +1,4 @@
|
|||||||
watershed 0.2.8 by paramat
|
watershed 0.2.9 by paramat
|
||||||
For latest stable Minetest back to 0.4.8
|
For latest stable Minetest back to 0.4.8
|
||||||
Depends default
|
Depends default
|
||||||
Licenses: code WTFPL
|
Licenses: code WTFPL
|
19
init.lua
19
init.lua
@ -1,10 +1,12 @@
|
|||||||
-- watershed 0.2.8 by paramat
|
-- watershed 0.2.9 by paramat
|
||||||
-- For latest stable Minetest and back to 0.4.8
|
-- For latest stable Minetest and back to 0.4.8
|
||||||
-- Depends default
|
-- Depends default
|
||||||
-- License: code WTFPL
|
-- License: code WTFPL
|
||||||
|
|
||||||
|
-- 0.2.9 added clay at mid-temperatures
|
||||||
|
|
||||||
-- TODO
|
-- TODO
|
||||||
-- clay
|
-- fog
|
||||||
|
|
||||||
-- Parameters
|
-- Parameters
|
||||||
|
|
||||||
@ -13,7 +15,6 @@ local YMAX = 8000 -- Approximate top of atmosphere / mountains / floatlands
|
|||||||
local TERCEN = 6960 -- Terrain 'centre', average seabed level
|
local TERCEN = 6960 -- Terrain 'centre', average seabed level
|
||||||
local YWAT = 7024 -- Sea level
|
local YWAT = 7024 -- Sea level
|
||||||
local YCLOUD = 7152 -- Cloud level
|
local YCLOUD = 7152 -- Cloud level
|
||||||
local STRACEN = 7088 -- Strata centre
|
|
||||||
|
|
||||||
local TERSCA = 384 -- Vertical terrain scale
|
local TERSCA = 384 -- Vertical terrain scale
|
||||||
local XLSAMP = 0 -- Extra large scale height variation amplitude
|
local XLSAMP = 0 -- Extra large scale height variation amplitude
|
||||||
@ -191,6 +192,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax}
|
local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax}
|
||||||
local data = vm:get_data()
|
local data = vm:get_data()
|
||||||
|
|
||||||
|
-- make all nodes air except ores and strata, for testing
|
||||||
|
|
||||||
--local c_air = minetest.get_content_id("air")
|
--local c_air = minetest.get_content_id("air")
|
||||||
--local c_water = minetest.get_content_id("air")
|
--local c_water = minetest.get_content_id("air")
|
||||||
--local c_sand = minetest.get_content_id("air")
|
--local c_sand = minetest.get_content_id("air")
|
||||||
@ -200,6 +203,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
--local c_dirtsnow = minetest.get_content_id("air")
|
--local c_dirtsnow = minetest.get_content_id("air")
|
||||||
--local c_jungrass = minetest.get_content_id("air")
|
--local c_jungrass = minetest.get_content_id("air")
|
||||||
--local c_dryshrub = minetest.get_content_id("air")
|
--local c_dryshrub = minetest.get_content_id("air")
|
||||||
|
--local c_clay = minetest.get_content_id("air")
|
||||||
|
|
||||||
--local c_wswater = minetest.get_content_id("air")
|
--local c_wswater = minetest.get_content_id("air")
|
||||||
--local c_wsstone = minetest.get_content_id("air")
|
--local c_wsstone = minetest.get_content_id("air")
|
||||||
@ -229,6 +233,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
local c_stocoal = minetest.get_content_id("default:stone_with_coal")
|
local c_stocoal = minetest.get_content_id("default:stone_with_coal")
|
||||||
local c_sandstone = minetest.get_content_id("default:sandstone")
|
local c_sandstone = minetest.get_content_id("default:sandstone")
|
||||||
local c_gravel = minetest.get_content_id("default:gravel")
|
local c_gravel = minetest.get_content_id("default:gravel")
|
||||||
|
local c_clay = minetest.get_content_id("default:clay")
|
||||||
|
|
||||||
local c_wswater = minetest.get_content_id("watershed:water")
|
local c_wswater = minetest.get_content_id("watershed:water")
|
||||||
local c_wsstone = minetest.get_content_id("watershed:stone")
|
local c_wsstone = minetest.get_content_id("watershed:stone")
|
||||||
@ -330,7 +335,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
if density >= tstone and nofis -- stone cut by fissures
|
if density >= tstone and nofis -- stone cut by fissures
|
||||||
or (density >= tstone and density < TSTONE * 3 and y <= YWAT) -- stone around water
|
or (density >= tstone and density < TSTONE * 3 and y <= YWAT) -- stone around water
|
||||||
or (density >= tstone and density < TSTONE * 3 and densitybase >= triv ) then -- stone around river
|
or (density >= tstone and density < TSTONE * 3 and densitybase >= triv ) then -- stone around river
|
||||||
local densitystr = nvals_strata[nixyz] / 4 + (STRACEN - y) / TERSCA
|
local densitystr = nvals_strata[nixyz] / 4 + (TERCEN - y) / TERSCA
|
||||||
local densityper = densitystr - math.floor(densitystr) -- periodic strata 'density'
|
local densityper = densitystr - math.floor(densitystr) -- periodic strata 'density'
|
||||||
if (densityper >= -0.1 and densityper <= -0.05) -- sandstone strata
|
if (densityper >= -0.1 and densityper <= -0.05) -- sandstone strata
|
||||||
or (densityper >= 0.05 and densityper <= 0.1) then
|
or (densityper >= 0.05 and densityper <= 0.1) then
|
||||||
@ -367,9 +372,11 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
under[si] = 0
|
under[si] = 0
|
||||||
soil[si] = 0
|
soil[si] = 0
|
||||||
elseif density >= 0 and density < tstone and stable[si] >= 2 then -- fine materials
|
elseif density >= 0 and density < tstone and stable[si] >= 2 then -- fine materials
|
||||||
if densitybase >= tsand + math.random() * 0.003
|
if y == YWAT - 2 and math.abs(n_temp) < 0.05 then -- clay
|
||||||
|
data[vi] = c_clay
|
||||||
|
elseif densitybase >= tsand + math.random() * 0.003 -- river / seabed sand not cut by fissures
|
||||||
or y <= YWAT + 1 + math.random(2) then
|
or y <= YWAT + 1 + math.random(2) then
|
||||||
data[vi] = c_sand -- river / seabed sand not cut by fissures
|
data[vi] = c_sand
|
||||||
elseif nofis then -- fine materials cut by fissures
|
elseif nofis then -- fine materials cut by fissures
|
||||||
if biome == 6 then
|
if biome == 6 then
|
||||||
data[vi] = c_desand
|
data[vi] = c_desand
|
||||||
|
Loading…
Reference in New Issue
Block a user