Generate beaches
This commit is contained in:
parent
d376148ca1
commit
75821c6889
@ -125,7 +125,7 @@ HeightPoint ground_height(u64 seed, v2s16 p2d)
|
|||||||
hp.ma = (4)*BS;
|
hp.ma = (4)*BS;
|
||||||
/*hp.gh = BS*base_rock_level_2d(seed, p2d);
|
/*hp.gh = BS*base_rock_level_2d(seed, p2d);
|
||||||
hp.ma = BS*get_mud_add_amount(seed, p2d);*/
|
hp.ma = BS*get_mud_add_amount(seed, p2d);*/
|
||||||
hp.have_sand = mapgen::get_have_sand(seed, p2d);
|
hp.have_sand = mapgen::get_have_beach(seed, p2d);
|
||||||
if(hp.gh > BS*WATER_LEVEL)
|
if(hp.gh > BS*WATER_LEVEL)
|
||||||
hp.tree_amount = mapgen::tree_amount_2d(seed, p2d);
|
hp.tree_amount = mapgen::tree_amount_2d(seed, p2d);
|
||||||
else
|
else
|
||||||
|
@ -1268,14 +1268,14 @@ double get_mud_add_amount(u64 seed, v2s16 p)
|
|||||||
seed+91013, 3, 0.55));
|
seed+91013, 3, 0.55));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool get_have_sand(u64 seed, v2s16 p2d)
|
bool get_have_beach(u64 seed, v2s16 p2d)
|
||||||
{
|
{
|
||||||
// Determine whether to have sand here
|
// Determine whether to have sand here
|
||||||
double sandnoise = noise2d_perlin(
|
double sandnoise = noise2d_perlin(
|
||||||
0.5+(float)p2d.X/500, 0.5+(float)p2d.Y/500,
|
0.5+(float)p2d.X/500, 0.5+(float)p2d.Y/500,
|
||||||
seed+59420, 3, 0.50);
|
seed+59420, 3, 0.50);
|
||||||
|
|
||||||
return (sandnoise > -0.15);
|
return (sandnoise > 0.15);
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 get_blockseed(u64 seed, v3s16 p)
|
u32 get_blockseed(u64 seed, v3s16 p)
|
||||||
@ -1769,17 +1769,20 @@ void make_block(BlockMakeData *data)
|
|||||||
// Randomize mud amount
|
// Randomize mud amount
|
||||||
s16 mud_add_amount = get_mud_add_amount(data->seed, p2d) / 2.0;
|
s16 mud_add_amount = get_mud_add_amount(data->seed, p2d) / 2.0;
|
||||||
|
|
||||||
if(mud_add_amount <= 0){
|
|
||||||
mud_add_amount = 1 - mud_add_amount;
|
|
||||||
addnode = MapNode(c_gravel);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Find ground level
|
// Find ground level
|
||||||
s16 surface_y = find_stone_level(vmanip, p2d, ndef);
|
s16 surface_y = find_stone_level(vmanip, p2d, ndef);
|
||||||
// Handle area not found
|
// Handle area not found
|
||||||
if(surface_y == vmanip.m_area.MinEdge.Y - 1)
|
if(surface_y == vmanip.m_area.MinEdge.Y - 1)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if(mud_add_amount <= 0){
|
||||||
|
mud_add_amount = 1 - mud_add_amount;
|
||||||
|
addnode = MapNode(c_gravel);
|
||||||
|
} else if(get_have_beach(data->seed, p2d) &&
|
||||||
|
surface_y + mud_add_amount <= WATER_LEVEL+2){
|
||||||
|
addnode = MapNode(c_sand);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
If topmost node is grass, change it to mud.
|
If topmost node is grass, change it to mud.
|
||||||
It might be if it was flown to there from a neighboring
|
It might be if it was flown to there from a neighboring
|
||||||
@ -2367,7 +2370,7 @@ void make_block(BlockMakeData *data)
|
|||||||
// Node position
|
// Node position
|
||||||
v2s16 p2d(x,z);
|
v2s16 p2d(x,z);
|
||||||
{
|
{
|
||||||
bool possibly_have_sand = get_have_sand(data->seed, p2d);
|
bool possibly_have_sand = get_have_beach(data->seed, p2d);
|
||||||
bool have_sand = false;
|
bool have_sand = false;
|
||||||
u32 current_depth = 0;
|
u32 current_depth = 0;
|
||||||
bool air_detected = false;
|
bool air_detected = false;
|
||||||
|
@ -49,7 +49,7 @@ namespace mapgen
|
|||||||
/*
|
/*
|
||||||
These are used by FarMesh
|
These are used by FarMesh
|
||||||
*/
|
*/
|
||||||
bool get_have_sand(u64 seed, v2s16 p2d);
|
bool get_have_beach(u64 seed, v2s16 p2d);
|
||||||
double tree_amount_2d(u64 seed, v2s16 p);
|
double tree_amount_2d(u64 seed, v2s16 p);
|
||||||
|
|
||||||
struct BlockMakeData
|
struct BlockMakeData
|
||||||
|
Loading…
x
Reference in New Issue
Block a user