mirror of
https://github.com/moparisthebest/minetest
synced 2025-01-10 21:28:02 -05:00
water drawing glitch fix
This commit is contained in:
parent
6bb9de3cc6
commit
24c1ea7103
@ -820,6 +820,8 @@ void MapBlock::updateMesh(u32 daynight_ratio)
|
|||||||
// Includes current node
|
// Includes current node
|
||||||
core::map<v3s16, f32> neighbor_levels;
|
core::map<v3s16, f32> neighbor_levels;
|
||||||
core::map<v3s16, u8> neighbor_contents;
|
core::map<v3s16, u8> neighbor_contents;
|
||||||
|
core::map<v3s16, u8> neighbor_flags;
|
||||||
|
const u8 neighborflag_top_is_water = 0x01;
|
||||||
v3s16 neighbor_dirs[9] = {
|
v3s16 neighbor_dirs[9] = {
|
||||||
v3s16(0,0,0),
|
v3s16(0,0,0),
|
||||||
v3s16(0,0,1),
|
v3s16(0,0,1),
|
||||||
@ -835,7 +837,9 @@ void MapBlock::updateMesh(u32 daynight_ratio)
|
|||||||
{
|
{
|
||||||
u8 content = CONTENT_AIR;
|
u8 content = CONTENT_AIR;
|
||||||
float level = -0.5 * BS;
|
float level = -0.5 * BS;
|
||||||
|
u8 flags = 0;
|
||||||
try{
|
try{
|
||||||
|
// Check neighbor
|
||||||
v3s16 p2 = p + neighbor_dirs[i];
|
v3s16 p2 = p + neighbor_dirs[i];
|
||||||
MapNode n2 = getNodeParent(p2);
|
MapNode n2 = getNodeParent(p2);
|
||||||
|
|
||||||
@ -845,11 +849,20 @@ void MapBlock::updateMesh(u32 daynight_ratio)
|
|||||||
level = 0.5 * BS;
|
level = 0.5 * BS;
|
||||||
else if(n2.d == CONTENT_WATER)
|
else if(n2.d == CONTENT_WATER)
|
||||||
level = (-0.5 + ((float)n2.param2 + 0.5) / 8.0) * BS;
|
level = (-0.5 + ((float)n2.param2 + 0.5) / 8.0) * BS;
|
||||||
|
|
||||||
|
// Check node above neighbor.
|
||||||
|
// NOTE: This doesn't get executed if neighbor
|
||||||
|
// doesn't exist
|
||||||
|
p2.Y += 1;
|
||||||
|
n2 = getNodeParent(p2);
|
||||||
|
if(n2.d == CONTENT_WATERSOURCE || n2.d == CONTENT_WATER)
|
||||||
|
flags |= neighborflag_top_is_water;
|
||||||
}
|
}
|
||||||
catch(InvalidPositionException &e){}
|
catch(InvalidPositionException &e){}
|
||||||
|
|
||||||
neighbor_levels.insert(neighbor_dirs[i], level);
|
neighbor_levels.insert(neighbor_dirs[i], level);
|
||||||
neighbor_contents.insert(neighbor_dirs[i], content);
|
neighbor_contents.insert(neighbor_dirs[i], content);
|
||||||
|
neighbor_flags.insert(neighbor_dirs[i], flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
//float water_level = (-0.5 + ((float)n.param2 + 0.5) / 8.0) * BS;
|
//float water_level = (-0.5 + ((float)n.param2 + 0.5) / 8.0) * BS;
|
||||||
@ -916,20 +929,24 @@ void MapBlock::updateMesh(u32 daynight_ratio)
|
|||||||
{
|
{
|
||||||
v3s16 dir = side_dirs[i];
|
v3s16 dir = side_dirs[i];
|
||||||
|
|
||||||
//float neighbor_level = neighbor_levels[dir];
|
/*
|
||||||
/*if(neighbor_level > -0.5*BS + 0.001)
|
If our topside is water and neighbor's topside
|
||||||
continue;*/
|
is water, don't draw side face
|
||||||
/*if(neighbor_level > water_level - 0.1*BS)
|
*/
|
||||||
continue;*/
|
if(top_is_water &&
|
||||||
|
neighbor_flags[dir] & neighborflag_top_is_water)
|
||||||
|
continue;
|
||||||
|
|
||||||
u8 neighbor_content = neighbor_contents[dir];
|
u8 neighbor_content = neighbor_contents[dir];
|
||||||
|
|
||||||
|
// Don't draw face if neighbor is not air or water
|
||||||
if(neighbor_content != CONTENT_AIR
|
if(neighbor_content != CONTENT_AIR
|
||||||
&& neighbor_content != CONTENT_WATER)
|
&& neighbor_content != CONTENT_WATER)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
bool neighbor_is_water = (neighbor_content == CONTENT_WATER);
|
bool neighbor_is_water = (neighbor_content == CONTENT_WATER);
|
||||||
|
|
||||||
|
// Don't draw any faces if neighbor is water and top is water
|
||||||
if(neighbor_is_water == true && top_is_water == false)
|
if(neighbor_is_water == true && top_is_water == false)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -945,22 +962,37 @@ void MapBlock::updateMesh(u32 daynight_ratio)
|
|||||||
video::S3DVertex(-BS/2,0,BS/2, 0,0,0, c, 0,0),
|
video::S3DVertex(-BS/2,0,BS/2, 0,0,0, c, 0,0),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
If our topside is water, set upper border of face
|
||||||
|
at upper border of node
|
||||||
|
*/
|
||||||
if(top_is_water)
|
if(top_is_water)
|
||||||
{
|
{
|
||||||
vertices[2].Pos.Y = 0.5*BS;
|
vertices[2].Pos.Y = 0.5*BS;
|
||||||
vertices[3].Pos.Y = 0.5*BS;
|
vertices[3].Pos.Y = 0.5*BS;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
Otherwise upper position of face is corner levels
|
||||||
|
*/
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vertices[2].Pos.Y = corner_levels[side_corners[i][0]];
|
vertices[2].Pos.Y = corner_levels[side_corners[i][0]];
|
||||||
vertices[3].Pos.Y = corner_levels[side_corners[i][1]];
|
vertices[3].Pos.Y = corner_levels[side_corners[i][1]];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
If neighbor is water, lower border of face is corner
|
||||||
|
water levels
|
||||||
|
*/
|
||||||
if(neighbor_is_water)
|
if(neighbor_is_water)
|
||||||
{
|
{
|
||||||
vertices[0].Pos.Y = corner_levels[side_corners[i][1]];
|
vertices[0].Pos.Y = corner_levels[side_corners[i][1]];
|
||||||
vertices[1].Pos.Y = corner_levels[side_corners[i][0]];
|
vertices[1].Pos.Y = corner_levels[side_corners[i][0]];
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
If neighbor is not water, lower border of face is
|
||||||
|
lower border of node
|
||||||
|
*/
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vertices[0].Pos.Y = -0.5*BS;
|
vertices[0].Pos.Y = -0.5*BS;
|
||||||
|
Loading…
Reference in New Issue
Block a user