Difference between revisions of "Map generator/settings"

From Luanti Wiki
Jump to navigation Jump to search
 
(2 intermediate revisions by the same user not shown)
Line 1: Line 1:
{{inaccurate}}
+
[https://dev.luanti.org/Mapgen/ This page has been moved to the new Luanti Developer Wiki!]
{{incomplete}}
 
{{outdated}}
 
 
 
Settings for the [[Map Generator|map generator]] can be made in the [[minetest.conf]] file. You can choose different generators, enable dungeons, create flat maps and many more.
 
 
 
Example settings can be found in the [https://github.com/minetest/minetest/blob/master/minetest.conf.example#L334 minetest.conf.example] file.
 
 
 
== Parameter overview ==
 
*<code>mg_name</code>: Type of main map generator
 
*<code>mg_flags</code>: A comma-seperated list of words (see below), each of them modifies the main map.
 
 
 
=== Available map generators ===
 
* <code>v6</code> - based on perlin noise (current default map generator)
 
* <code>v7</code> - based on perlin noise (successor of v6); currently in development
 
* <code>indev</code> - like v6 but with experimental features (e.g. floating islands)
 
* <code>math</code> - collection of geometrical shapes and fractals (not in latest stable version yet)
 
* <code>singlenode</code> - entire map is filled with [[air]]
 
 
 
=== Available flags ===
 
*<code>trees</code> - enables [[Biomes#Forest|forests]]
 
*<code>caves</code> - enables caves
 
*<code>flat</code> - renders the entire surface of the map with the same level (no hills, cliffs, or oceans)
 
*<code>v6_biome_blend</code> - if provided, the transition between two biomes is “smooth” (i.e. dithered) instead of hard (sudden).
 
*<code>dungeons</code> - enables [[Biomes#Dungeons|dungeons]]
 
*<code>nolight</code> - disables the [[Day/night cycle|day/night cycle]]. The entire map will be unlit (though crafted lights still work)
 
 
 
== v6 and v7 specific options ==
 
These noise attributes are used for map generation parameters, such as ''mgv6_np_beach'', ''mgv7_np_heat'', and ''mgindev_np_terrain_higher''. Those parameters are used by v6 and v7. An example usage would be ''mgv6_np_apple_trees = 0, 1, (100, 100, 100), 342902, 3, 0.45''. These numbers are used in the order of: Offset, scale, (spread factor), seed offset, number of octaves, persistence.
 
 
 
=== v6 biome options ===
 
*<code>mgv6_np_terrain_base</code>
 
*<code>mgv6_np_terrain_higher</code>
 
*<code>mgv6_np_steepness</code>
 
*<code>mgv6_np_height_select</code>
 
*<code>mgv6_np_mud</code>
 
*<code>mgv6_np_beach</code>
 
*<code>mgv6_np_biome</code>
 
*<code>mgv6_np_cave</code>
 
*<code>mgv6_np_humidity</code>
 
*<code>mgv6_np_trees</code>
 
*<code>mgv6_np_apple_trees</code>
 
 
 
=== v7 biome options ===
 
*<code>mgv7_np_terrain</code>
 
*<code>mgv7_np_bgroup</code>
 
*<code>mgv7_np_heat</code>
 
*<code>mgv7_np_humidity</code>
 
 
 
== v6 specific options ==
 
*<code>mgv6_freq_desert</code>
 
*<code>mgv6_freq_beach</code>
 
 
 
*<code>mgv6_spflags</code> = jungles/nojungles enables or disables [[Biomes#Jungle|jungles]]
 
 
 
== v6/v7 biome parameter description ==
 
=== Offset and Scale ===
 
Offset and scale should be left alone unless you know what you are doing, these define the average value and amplitude of the noise value output.
 
0, 1 is standard and matches the older Lua perlin functions whose scale and offset are always set to 0 and 1.
 
0, 1 means the noise value has an average value of 0 and varies very roughly between -1 and 1, although depending on octaves and persistence the output can occasionally be as large as -2 to 2.
 
 
 
=== Spread factor ===
 
Written as (x,y,z) e.g. (250,250,250). Those numbers are in nodes (or meters) and very roughly define the maximum scale of that perlin structure. So the spread factor of the biome perlin noise is very roughly the maximum size in nodes of the biomes. To make biomes twice as big try (500, 500, 500). These three numbers enable setting the maximum structure scale independently for x y and z. So you could create biomes stretched in the z direction by using (250, 250, 500).
 
 
 
=== Seed and Seeddiff ===
 
A perlin function needs a 'seed', this is just any old random whole number that acts as a seed to 'grow' a particular noise pattern, same seed same noise pattern.
 
 
 
Seeddiff = seed difference. Perlin functions that use 'seeddiff' instead of 'seed' are 'world dependant'. The value used as a seed is worldseed + seeddiff. Seeddiff creates perlin functions with different patterns but they also remain world dependant, meaning in different worlds you get different patterns but also in the same world you get the same pattern.
 
 
 
=== Number of octaves ===
 
More octaves means more details and more calculation.
 
 
 
=== Persistence ===
 
Persistence defines how strong the details are visible, it does not add more of them. A low persistence will cause the terrain to be smooth, a high (max. 1) causes strong ups and downs.
 
 
 
== math specific options ==
 
*<code>mg_mathgenerator</code> - select the type of map to be generated
 
Available types are:
 
*<code>sphere</code>: A sphere of radius 100.
 
*<code>mandelbox</code>: A mandelbox.
 
*<code>mengersponge</code>: A huge Menger sponge.
 
 
 
== indev specific options ==
 
*<code>mgindev_np_terrain_base</code>
 
*<code>mgindev_np_terrain_higher</code>
 
*<code>mgindev_np_steepness</code>
 
*<code>mgindev_np_mud</code>
 
*<code>mgindev_np_float_islands1</code>
 
*<code>mgindev_np_float_islands2</code>
 
*<code>mgindev_np_float_islands3</code>
 
*<code>mgindev_np_biome</code>
 
*<code>mgindev_float_islands</code> - Configure floating islands. A non-zero integer sets the minimum height of floating islands. A value of <code>0</code> disables the floating islands completely.
 

Latest revision as of 17:20, 15 December 2024