mirror of
				https://github.com/paramat/watershed.git
				synced 2025-10-25 22:35:25 +02:00 
			
		
		
		
	Snowy berg if humid. Harmonic noise returns. Flatter lowlands. New node icydirt: tundra surface
This commit is contained in:
		| @@ -1,4 +1,4 @@ | |||||||
| watershed 0.3.11 by paramat | watershed 0.3.12 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 | ||||||
|   | |||||||
| @@ -240,14 +240,30 @@ if SINGLENODE then | |||||||
| 			spread = {x=512, y=512, z=512}, | 			spread = {x=512, y=512, z=512}, | ||||||
| 			seed = 593, | 			seed = 593, | ||||||
| 			octaves = 6, | 			octaves = 6, | ||||||
| 			persist = 0.63 | 			persist = 0.67 | ||||||
| 		} | 		} | ||||||
| 		local np_smooth = { | 		local np_smooth = { | ||||||
| 			offset = 0, | 			offset = 0, | ||||||
| 			scale = 1, | 			scale = 1, | ||||||
| 			spread = {x=512, y=512, z=512}, | 			spread = {x=512, y=512, z=512}, | ||||||
| 			seed = 593, | 			seed = 593, | ||||||
|  | 			octaves = 5, | ||||||
|  | 			persist = 0.33 | ||||||
|  | 		} | ||||||
|  | 		local np_roughalt = { | ||||||
|  | 			offset = 0, | ||||||
|  | 			scale = 1, | ||||||
|  | 			spread = {x=414, y=414, z=414}, | ||||||
|  | 			seed = -9003, | ||||||
| 			octaves = 6, | 			octaves = 6, | ||||||
|  | 			persist = 0.67 | ||||||
|  | 		} | ||||||
|  | 		local np_smoothalt = { | ||||||
|  | 			offset = 0, | ||||||
|  | 			scale = 1, | ||||||
|  | 			spread = {x=414, y=414, z=414}, | ||||||
|  | 			seed = -9003, | ||||||
|  | 			octaves = 5, | ||||||
| 			persist = 0.33 | 			persist = 0.33 | ||||||
| 		} | 		} | ||||||
| 		local np_base = { | 		local np_base = { | ||||||
| @@ -282,6 +298,8 @@ if SINGLENODE then | |||||||
|  |  | ||||||
| 			local nvals_rough = minetest.get_perlin_map(np_rough, chulens):get3dMap_flat(minposxyz) | 			local nvals_rough = minetest.get_perlin_map(np_rough, chulens):get3dMap_flat(minposxyz) | ||||||
| 			local nvals_smooth = minetest.get_perlin_map(np_smooth, chulens):get3dMap_flat(minposxyz) | 			local nvals_smooth = minetest.get_perlin_map(np_smooth, chulens):get3dMap_flat(minposxyz) | ||||||
|  | 			local nvals_roughalt = minetest.get_perlin_map(np_roughalt, chulens):get3dMap_flat(minposxyz) | ||||||
|  | 			local nvals_smoothalt = minetest.get_perlin_map(np_smoothalt, chulens):get3dMap_flat(minposxyz) | ||||||
|  |  | ||||||
| 			local nvals_base = minetest.get_perlin_map(np_base, chulens):get2dMap_flat(minposxz) | 			local nvals_base = minetest.get_perlin_map(np_base, chulens):get2dMap_flat(minposxz) | ||||||
| 			local nvals_xlscale = minetest.get_perlin_map(np_xlscale, chulens):get2dMap_flat(minposxz) | 			local nvals_xlscale = minetest.get_perlin_map(np_xlscale, chulens):get2dMap_flat(minposxz) | ||||||
| @@ -291,12 +309,18 @@ if SINGLENODE then | |||||||
| 			for z = z0, z1 do | 			for z = z0, z1 do | ||||||
| 				for y = y0, y1 do | 				for y = y0, y1 do | ||||||
| 					for x = x0, x1 do | 					for x = x0, x1 do | ||||||
|  | 						local n_rough = nvals_rough[nixyz] | ||||||
|  | 						local n_smooth = nvals_smooth[nixyz] | ||||||
|  | 						local n_roughalt = nvals_roughalt[nixyz] | ||||||
|  | 						local n_smoothalt = nvals_smoothalt[nixyz] | ||||||
| 						local n_base = nvals_base[nixz] | 						local n_base = nvals_base[nixz] | ||||||
|  | 						local n_xlscale = nvals_xlscale[nixz] | ||||||
| 						local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP | 						local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP | ||||||
| 						local densitybase = (1 - math.abs(n_base)) * BASAMP + nvals_xlscale[nixz] * XLSAMP + grad | 						local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad | ||||||
| 						local terblen = math.max(1 - math.abs(n_base), 0) | 						local terblen = math.max(1 - math.abs(n_base), 0) | ||||||
| 						local density = densitybase | 						local density = densitybase + | ||||||
| 						+ math.abs(nvals_rough[nixyz] * terblen + nvals_smooth[nixyz] * (1 - terblen)) ^ CANEXP * CANAMP | 						math.abs((n_rough + n_roughalt) * 0.5 * terblen + | ||||||
|  | 						(n_smooth + n_smoothalt) * 0.25 * (1 - terblen)) ^ CANEXP * CANAMP | ||||||
| 						if y >= 1 and density > -0.01 and density < 0 then | 						if y >= 1 and density > -0.01 and density < 0 then | ||||||
| 							ysp = y + 1 | 							ysp = y + 1 | ||||||
| 							xsp = x | 							xsp = x | ||||||
|   | |||||||
							
								
								
									
										70
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										70
									
								
								init.lua
									
									
									
									
									
								
							| @@ -1,11 +1,17 @@ | |||||||
| -- watershed 0.3.11 by paramat | -- watershed 0.3.12 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 | ||||||
|  |  | ||||||
| -- bugfix spawn function | -- snowy iceberg only if humid enough | ||||||
| -- 2 iron ore layers | -- add rough alt, smooth alt noises for harmonic noise | ||||||
|  | -- persistence to 0.67 for rough noises | ||||||
|  | -- half scale of smooth noise for flatter lowlands | ||||||
|  | -- 1 less octave for smooth noise | ||||||
|  | -- fix sea ice in tundra at y = 47 | ||||||
|  | -- removed snow from tundra | ||||||
|  | -- New icydirt surface node in tundra | ||||||
|  |  | ||||||
| -- Parameters | -- Parameters | ||||||
|  |  | ||||||
| @@ -63,7 +69,7 @@ local np_rough = { | |||||||
| 	spread = {x=512, y=512, z=512}, | 	spread = {x=512, y=512, z=512}, | ||||||
| 	seed = 593, | 	seed = 593, | ||||||
| 	octaves = 6, | 	octaves = 6, | ||||||
| 	persist = 0.63 | 	persist = 0.67 | ||||||
| } | } | ||||||
|  |  | ||||||
| -- 3D noise for smooth terrain | -- 3D noise for smooth terrain | ||||||
| @@ -73,7 +79,29 @@ local np_smooth = { | |||||||
| 	scale = 1, | 	scale = 1, | ||||||
| 	spread = {x=512, y=512, z=512}, | 	spread = {x=512, y=512, z=512}, | ||||||
| 	seed = 593, | 	seed = 593, | ||||||
|  | 	octaves = 5, | ||||||
|  | 	persist = 0.33 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | -- 3D noise for alt rough terrain | ||||||
|  |  | ||||||
|  | local np_roughalt = { | ||||||
|  | 	offset = 0, | ||||||
|  | 	scale = 1, | ||||||
|  | 	spread = {x=414, y=414, z=414}, | ||||||
|  | 	seed = -9003, | ||||||
| 	octaves = 6, | 	octaves = 6, | ||||||
|  | 	persist = 0.67 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | -- 3D noise for alt smooth terrain | ||||||
|  |  | ||||||
|  | local np_smoothalt = { | ||||||
|  | 	offset = 0, | ||||||
|  | 	scale = 1, | ||||||
|  | 	spread = {x=414, y=414, z=414}, | ||||||
|  | 	seed = -9003, | ||||||
|  | 	octaves = 5, | ||||||
| 	persist = 0.33 | 	persist = 0.33 | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -232,6 +260,7 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 	local c_wsfreshice = minetest.get_content_id("watershed:freshice") | 	local c_wsfreshice = minetest.get_content_id("watershed:freshice") | ||||||
| 	local c_wscloud = minetest.get_content_id("watershed:cloud") | 	local c_wscloud = minetest.get_content_id("watershed:cloud") | ||||||
| 	local c_wsluxoreoff = minetest.get_content_id("watershed:luxoreoff") | 	local c_wsluxoreoff = minetest.get_content_id("watershed:luxoreoff") | ||||||
|  | 	local c_wsicydirt = minetest.get_content_id("watershed:icydirt") | ||||||
| 	-- perlinmap stuff | 	-- perlinmap stuff | ||||||
| 	local sidelen = x1 - x0 + 1 -- chunk sidelength | 	local sidelen = x1 - x0 + 1 -- chunk sidelength | ||||||
| 	local chulens = {x=sidelen, y=sidelen+2, z=sidelen} -- chunk dimensions, '+2' for overgeneration | 	local chulens = {x=sidelen, y=sidelen+2, z=sidelen} -- chunk dimensions, '+2' for overgeneration | ||||||
| @@ -240,6 +269,8 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 	-- 3D and 2D perlinmaps | 	-- 3D and 2D perlinmaps | ||||||
| 	local nvals_rough = minetest.get_perlin_map(np_rough, chulens):get3dMap_flat(minposxyz) | 	local nvals_rough = minetest.get_perlin_map(np_rough, chulens):get3dMap_flat(minposxyz) | ||||||
| 	local nvals_smooth = minetest.get_perlin_map(np_smooth, chulens):get3dMap_flat(minposxyz) | 	local nvals_smooth = minetest.get_perlin_map(np_smooth, chulens):get3dMap_flat(minposxyz) | ||||||
|  | 	local nvals_roughalt = minetest.get_perlin_map(np_roughalt, chulens):get3dMap_flat(minposxyz) | ||||||
|  | 	local nvals_smoothalt = minetest.get_perlin_map(np_smoothalt, chulens):get3dMap_flat(minposxyz) | ||||||
| 	local nvals_fissure = minetest.get_perlin_map(np_fissure, chulens):get3dMap_flat(minposxyz) | 	local nvals_fissure = minetest.get_perlin_map(np_fissure, chulens):get3dMap_flat(minposxyz) | ||||||
| 	local nvals_temp = minetest.get_perlin_map(np_temp, chulens):get3dMap_flat(minposxyz) | 	local nvals_temp = minetest.get_perlin_map(np_temp, chulens):get3dMap_flat(minposxyz) | ||||||
| 	local nvals_humid = minetest.get_perlin_map(np_humid, chulens):get3dMap_flat(minposxyz) | 	local nvals_humid = minetest.get_perlin_map(np_humid, chulens):get3dMap_flat(minposxyz) | ||||||
| @@ -268,6 +299,8 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 				-- noise values for node | 				-- noise values for node | ||||||
| 				local n_rough = nvals_rough[nixyz] | 				local n_rough = nvals_rough[nixyz] | ||||||
| 				local n_smooth = nvals_smooth[nixyz] | 				local n_smooth = nvals_smooth[nixyz] | ||||||
|  | 				local n_roughalt = nvals_roughalt[nixyz] | ||||||
|  | 				local n_smoothalt = nvals_smoothalt[nixyz] | ||||||
| 				local n_fissure = nvals_fissure[nixyz] | 				local n_fissure = nvals_fissure[nixyz] | ||||||
| 				local n_temp = nvals_temp[nixyz] | 				local n_temp = nvals_temp[nixyz] | ||||||
| 				local n_humid = nvals_humid[nixyz] | 				local n_humid = nvals_humid[nixyz] | ||||||
| @@ -281,8 +314,9 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 				local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP -- vertical density gradient | 				local grad = math.atan((TERCEN - y) / TERSCA) * ATANAMP -- vertical density gradient | ||||||
| 				local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad -- base terrain | 				local densitybase = (1 - math.abs(n_base)) * BASAMP + n_xlscale * XLSAMP + grad -- base terrain | ||||||
| 				local terblen = math.max(1 - math.abs(n_base), 0) -- canyon terrain blend of rough and smooth | 				local terblen = math.max(1 - math.abs(n_base), 0) -- canyon terrain blend of rough and smooth | ||||||
| 				local density = densitybase | 				local density = densitybase + -- add canyon terrain | ||||||
| 				+ math.abs(n_rough * terblen + n_smooth * (1 - terblen)) ^ CANEXP * CANAMP -- add canyon terrain | 				math.abs((n_rough + n_roughalt) * 0.5 * terblen + | ||||||
|  | 				(n_smooth + n_smoothalt) * 0.25 * (1 - terblen)) ^ CANEXP * CANAMP | ||||||
| 				-- other values | 				-- other values | ||||||
| 				local triv = TRIV * (1 - terblen) -- river threshold | 				local triv = TRIV * (1 - terblen) -- river threshold | ||||||
| 				local tsand = TSAND * (1 - terblen) -- sand threshold | 				local tsand = TSAND * (1 - terblen) -- sand threshold | ||||||
| @@ -495,15 +529,9 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 						if y > YWAT and under[si] ~= 0 then | 						if y > YWAT and under[si] ~= 0 then | ||||||
| 							local fnoise = n_fissure -- noise for flower colours | 							local fnoise = n_fissure -- noise for flower colours | ||||||
| 							if under[si] == 1 then | 							if under[si] == 1 then | ||||||
| 								if math.random(121) == 2 then | 								data[viu] = c_wsicydirt | ||||||
| 									data[viu] = c_snowblock | 								if math.random(DRYCHA) == 2 then | ||||||
| 								elseif math.random(121) == 2 then | 									data[vi] = c_dryshrub | ||||||
| 									data[viu] = c_wsfreshice |  | ||||||
| 								else |  | ||||||
| 									data[viu] = c_wsdrygrass |  | ||||||
| 									if math.random(DRYCHA) == 2 then |  | ||||||
| 										data[vi] = c_dryshrub |  | ||||||
| 									end |  | ||||||
| 								end | 								end | ||||||
| 							elseif under[si] == 2 then | 							elseif under[si] == 2 then | ||||||
| 								data[viu] = c_dirtsnow | 								data[viu] = c_dirtsnow | ||||||
| @@ -573,11 +601,11 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 								and biome >= 4 then | 								and biome >= 4 then | ||||||
| 									data[vi] = c_wsgoldengrass | 									data[vi] = c_wsgoldengrass | ||||||
| 								end | 								end | ||||||
| 							elseif under[si] == 11 and n_temp > HITET then -- riverbank | 							elseif under[si] == 11 and n_temp > HITET then -- hot biome riverbank | ||||||
| 								if math.random(PAPCHA) == 2 then | 								if math.random(PAPCHA) == 2 then | ||||||
| 									watershed_papyrus(x, y, z, area, data) | 									watershed_papyrus(x, y, z, area, data) | ||||||
| 								end | 								end | ||||||
| 							elseif under[si] == 12 then -- iceberg | 							elseif under[si] == 12 and n_humid > LOHUT then -- snowy iceberg | ||||||
| 								data[vi] = c_snowblock | 								data[vi] = c_snowblock | ||||||
| 							end | 							end | ||||||
| 						end | 						end | ||||||
| @@ -587,13 +615,7 @@ minetest.register_on_generated(function(minp, maxp, seed) | |||||||
| 				elseif y == y1 + 1 then -- plane of nodes above chunk | 				elseif y == y1 + 1 then -- plane of nodes above chunk | ||||||
| 					if density < 0 and y >= YWAT + 1 and under[si] ~= 0 then -- if air above fine materials | 					if density < 0 and y >= YWAT + 1 and under[si] ~= 0 then -- if air above fine materials | ||||||
| 						if under[si] == 1 then -- add surface nodes to chunk top layer | 						if under[si] == 1 then -- add surface nodes to chunk top layer | ||||||
| 							if math.random(121) == 2 then | 							data[viu] = c_wsicydirt | ||||||
| 								data[viu] = c_dirtsnow |  | ||||||
| 							elseif math.random(121) == 2 then |  | ||||||
| 								data[viu] = c_ice |  | ||||||
| 							else |  | ||||||
| 								data[viu] = c_wsdrygrass |  | ||||||
| 							end |  | ||||||
| 						elseif under[si] == 2 then | 						elseif under[si] == 2 then | ||||||
| 							data[viu] = c_dirtsnow | 							data[viu] = c_dirtsnow | ||||||
| 						elseif under[si] == 3 then | 						elseif under[si] == 3 then | ||||||
|   | |||||||
							
								
								
									
										19
									
								
								nodes.lua
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								nodes.lua
									
									
									
									
									
								
							| @@ -24,6 +24,7 @@ minetest.register_node("watershed:acaciatree", { | |||||||
| 	description = "WS Acacia Tree", | 	description = "WS Acacia Tree", | ||||||
| 	tiles = {"watershed_acaciatreetop.png", "watershed_acaciatreetop.png", "watershed_acaciatree.png"}, | 	tiles = {"watershed_acaciatreetop.png", "watershed_acaciatreetop.png", "watershed_acaciatree.png"}, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
|  | 	is_ground_content = false, | ||||||
| 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| @@ -44,6 +45,7 @@ minetest.register_node("watershed:pinetree", { | |||||||
| 	description = "WS Pine Tree", | 	description = "WS Pine Tree", | ||||||
| 	tiles = {"watershed_pinetreetop.png", "watershed_pinetreetop.png", "watershed_pinetree.png"}, | 	tiles = {"watershed_pinetreetop.png", "watershed_pinetreetop.png", "watershed_pinetree.png"}, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
|  | 	is_ground_content = false, | ||||||
| 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | 	groups = {tree=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| @@ -69,6 +71,18 @@ minetest.register_node("watershed:dirt", { | |||||||
| 	sounds = default.node_sound_dirt_defaults(), | 	sounds = default.node_sound_dirt_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | minetest.register_node("watershed:icydirt", { | ||||||
|  | 	description = "WS Icy Dirt", | ||||||
|  | 	tiles = {"watershed_icydirt.png"}, | ||||||
|  | 	is_ground_content = false, | ||||||
|  | 	groups = {crumbly=1}, | ||||||
|  | 	drop = "default:dirt", | ||||||
|  | 	sounds = default.node_sound_dirt_defaults({ | ||||||
|  | 		footstep = {name="default_snow_footstep", gain=0.15}, | ||||||
|  | 		dug = {name="default_snow_footstep", gain=0.45}, | ||||||
|  | 	}), | ||||||
|  | }) | ||||||
|  |  | ||||||
| minetest.register_node("watershed:grass", { | minetest.register_node("watershed:grass", { | ||||||
| 	description = "WS Grass", | 	description = "WS Grass", | ||||||
| 	tiles = {"default_grass.png", "default_dirt.png", "default_dirt.png^default_grass_side.png"}, | 	tiles = {"default_grass.png", "default_dirt.png", "default_dirt.png^default_grass_side.png"}, | ||||||
| @@ -139,7 +153,7 @@ minetest.register_node("watershed:drygrass", { | |||||||
| 	description = "WS Dry Grass", | 	description = "WS Dry Grass", | ||||||
| 	tiles = {"watershed_drygrass.png"}, | 	tiles = {"watershed_drygrass.png"}, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| 	groups = {crumbly=3,soil=1}, | 	groups = {crumbly=1,soil=1}, | ||||||
| 	drop = "default:dirt", | 	drop = "default:dirt", | ||||||
| 	sounds = default.node_sound_dirt_defaults({ | 	sounds = default.node_sound_dirt_defaults({ | ||||||
| 		footstep = {name="default_grass_footstep", gain=0.4}, | 		footstep = {name="default_grass_footstep", gain=0.4}, | ||||||
| @@ -150,7 +164,7 @@ minetest.register_node("watershed:permafrost", { | |||||||
| 	description = "WS Permafrost", | 	description = "WS Permafrost", | ||||||
| 	tiles = {"watershed_permafrost.png"}, | 	tiles = {"watershed_permafrost.png"}, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| 	groups = {crumbly=2}, | 	groups = {crumbly=1}, | ||||||
| 	drop = "default:dirt", | 	drop = "default:dirt", | ||||||
| 	sounds = default.node_sound_dirt_defaults(), | 	sounds = default.node_sound_dirt_defaults(), | ||||||
| }) | }) | ||||||
| @@ -194,6 +208,7 @@ minetest.register_node("watershed:luxoreoff", { | |||||||
| 	description = "WS Lux Ore Off", | 	description = "WS Lux Ore Off", | ||||||
| 	tiles = {"watershed_luxore.png"}, | 	tiles = {"watershed_luxore.png"}, | ||||||
| 	light_source = 14, | 	light_source = 14, | ||||||
|  | 	is_ground_content = false, | ||||||
| 	groups = {cracky=3}, | 	groups = {cracky=3}, | ||||||
| 	drop = "watershed:luxcrystal 8", | 	drop = "watershed:luxcrystal 8", | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = default.node_sound_glass_defaults(), | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								textures/watershed_icydirt.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								textures/watershed_icydirt.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 746 B | 
		Reference in New Issue
	
	Block a user