Crafter/mods/nether/biomes.lua

234 lines
6.3 KiB
Lua
Raw Normal View History

2020-04-20 03:51:06 -04:00
minetest.register_biome({
name = "Nether",
node_top = "air",
depth_top = 0,
node_filler = "air",
depth_filler = 0,
node_riverbed = "air",
depth_riverbed= 0,
node_cave_liquid = "air",
2020-04-20 03:51:06 -04:00
node_stone = "air",
2020-04-20 12:13:32 -04:00
node_water = nil,
2020-04-20 03:51:06 -04:00
node_dungeon = "air",
node_dungeon_alt = "air",
node_dungeon_stair = "air",
vertical_blend = 0,
2020-04-20 18:40:45 -04:00
y_max = -10033,
y_min = -20113,
2020-04-20 03:51:06 -04:00
heat_point = -100,
humidity_point = -100,
})
2020-04-22 16:55:54 -04:00
--[[
minetest.register_decoration({
name = "Nether Eternal Fire",
deco_type = "simple",
place_on = {"nether:netherrack"},
sidelen = 16,
fill_ratio = 0.03,
biomes = {"Nether"},
y_max = -10033,
y_min = -15000,
decoration = "fire:fire",
height = 1,
})
]]--
2020-04-20 03:51:06 -04:00
--this is from https://github.com/paramat/lvm_example/blob/master/init.lua
--hi paramat :D
-- Set the 3D noise parameters for the terrain.
local np_terrain = {
offset = 0,
scale = 1,
spread = {x = 384, y = 192, z = 384},
2020-05-15 08:00:13 -04:00
seed = tonumber(minetest.get_mapgen_setting("seed")) or math.random(0,999999999),
2020-04-20 03:51:06 -04:00
octaves = 5,
persist = 0.63,
lacunarity = 2.0,
--flags = ""
}
2020-05-07 07:42:52 -04:00
minetest.register_decoration({
name = "nether:tree",
deco_type = "schematic",
place_on = {"nether:netherrack"},
sidelen = 16,
noise_params = {
offset = 0.024,
scale = 0.015,
spread = {x = 250, y = 250, z = 250},
seed = 2,
octaves = 3,
persist = 0.66
},
--biomes = {},
y_max = -10000,
y_min = -15000,
schematic = nethertreeSchematic,
flags = "place_center_x, place_center_z",
rotation = "random",
spawn_by = "air",
num_spawn_by = 1,
})
2020-04-20 03:51:06 -04:00
-- Set singlenode mapgen (air nodes only).
-- Disable the engine lighting calculation since that will be done for a
-- mapchunk of air nodes and will be incorrect after we place nodes.
--minetest.set_mapgen_params({mgname = "singlenode", flags = "nolight"})
-- Get the content IDs for the nodes used.
local c_sandstone = minetest.get_content_id("nether:netherrack")
local c_bedrock = minetest.get_content_id("nether:bedrock")
local c_air = minetest.get_content_id("air")
local c_lava = minetest.get_content_id("nether:lava")
-- Initialize noise object to nil. It will be created once only during the
-- generation of the first mapchunk, to minimise memory use.
local nobj_terrain = nil
-- Localise noise buffer table outside the loop, to be re-used for all
-- mapchunks, therefore minimising memory use.
local nvals_terrain = {}
-- Localise data buffer table outside the loop, to be re-used for all
-- mapchunks, therefore minimising memory use.
local data = {}
-- On generated function.
-- 'minp' and 'maxp' are the minimum and maximum positions of the mapchunk that
-- define the 3D volume.
local sidelen
local permapdims3d
local vm
local emin
local emax
local area
local vi
local density_noise
local density_gradient
2020-04-20 03:51:06 -04:00
minetest.register_on_generated(function(minp, maxp, seed)
--nether starts at -10033 y
2020-04-20 18:40:45 -04:00
if maxp.y > -10033 or maxp.y < -20033 then
2020-04-20 03:51:06 -04:00
return
end
-- Start time of mapchunk generation.
--local t0 = os.clock()
-- Noise stuff.
-- Side length of mapchunk.
sidelen = maxp.x - minp.x + 1
2020-04-20 03:51:06 -04:00
-- Required dimensions of the 3D noise perlin map.
permapdims3d = {x = sidelen, y = sidelen, z = sidelen}
2020-04-20 03:51:06 -04:00
-- Create the perlin map noise object once only, during the generation of
-- the first mapchunk when 'nobj_terrain' is 'nil'.
nobj_terrain = minetest.get_perlin_map(np_terrain, permapdims3d) --nobj_terrain or
-- Create a flat array of noise values from the perlin map, with the
-- minimum point being 'minp'.
-- Set the buffer parameter to use and reuse 'nvals_terrain' for this.
nobj_terrain:get3dMap_flat(minp, nvals_terrain)
-- Voxelmanip stuff.
-- Load the voxelmanip with the result of engine mapgen. Since 'singlenode'
-- mapgen is used this will be a mapchunk of air nodes.
vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
2020-04-20 03:51:06 -04:00
-- 'area' is used later to get the voxelmanip indexes for positions.
area = VoxelArea:new{MinEdge = emin, MaxEdge = emax}
2020-04-20 03:51:06 -04:00
-- Get the content ID data from the voxelmanip in the form of a flat array.
-- Set the buffer parameter to use and reuse 'data' for this.
vm:get_data(data)
-- Generation loop.
-- Noise index for the flat array of noise values.
2020-04-20 03:51:06 -04:00
-- Process the content IDs in 'data'.
-- The most useful order is a ZYX loop because:
-- 1. This matches the order of the 3D noise flat array.
-- 2. This allows a simple +1 incrementing of the voxelmanip index along x
-- rows.
-- rows.
local ni = 1
2020-04-20 03:51:06 -04:00
for z = minp.z, maxp.z do
for y = minp.y, maxp.y do
-- Voxelmanip index for the flat array of content IDs.
-- Initialise to first node in this x row.
vi = area:index(minp.x, y, z)
2020-04-20 03:51:06 -04:00
for x = minp.x, maxp.x do
-- Consider a 'solidness' value for each node,
-- let's call it 'density', where
-- density = density noise + density gradient.
density_noise = nvals_terrain[ni]
2020-04-20 03:51:06 -04:00
-- Density gradient is a value that is 0 at water level (y = 1)
-- and falls in value with increasing y. This is necessary to
-- create a 'world surface' with only solid nodes deep underground
-- and only air high above water level.
-- Here '128' determines the typical maximum height of the terrain.
density_gradient = (1 - y) / 128
2020-04-20 03:51:06 -04:00
--print(density_noise, density_gradient)
-- Place solid nodes when 'density' > 0.
--if density_noise + density_gradient > 0 then
2020-04-20 18:40:45 -04:00
if density_noise > 0 and y ~= -10033 and y ~= -20112 then
2020-04-20 03:51:06 -04:00
data[vi] = c_sandstone
2020-04-20 18:40:45 -04:00
-- create bedrock layer
elseif y == -10033 or y == -20112 then
2020-04-20 03:51:06 -04:00
data[vi] = c_bedrock
--elseif y <= 1 then
-- data[vi] = c_water
2020-05-07 07:42:52 -04:00
--elseif y > -15000 then
--data[vi] = c_air
elseif y <= -15000 then
2020-04-20 03:51:06 -04:00
data[vi] = c_lava
end
-- Increment noise index.
ni = ni + 1
-- Increment voxelmanip index along x row.
-- The voxelmanip index increases by 1 when
-- moving by 1 node in the +x direction.
vi = vi + 1
end
end
end
2020-05-07 07:42:52 -04:00
2020-04-20 03:51:06 -04:00
-- After processing, write content ID data back to the voxelmanip.
vm:set_data(data)
-- Calculate lighting for what has been created.
--vm:calc_lighting()
2020-04-20 05:30:07 -04:00
minetest.generate_ores(vm)
2020-05-07 07:42:52 -04:00
minetest.generate_decorations(vm)
2020-04-22 16:55:54 -04:00
--minetest.generate_decorations(vm)
2020-04-20 03:51:06 -04:00
vm:set_lighting({day=7,night=7}, minp, maxp)
-- Write what has been created to the world.
vm:write_to_map()
-- Liquid nodes were placed so set them flowing.
--vm:update_liquids()
-- Print generation time of this mapchunk.
--local chugent = math.ceil((os.clock() - t0) * 1000)
--print ("[lvm_example] Mapchunk generation time " .. chugent .. " ms")
end)