mirror of
https://github.com/minetest/minetest.git
synced 2025-01-20 21:11:37 +01:00
Rotate meshnode normals correctly instead of recalculating
This commit is contained in:
parent
21437090b8
commit
3c5e0d10fc
@ -1673,8 +1673,6 @@ void MapblockMeshGenerator::drawMeshNode()
|
|||||||
modified = false;
|
modified = false;
|
||||||
if (modified) {
|
if (modified) {
|
||||||
recalculateBoundingBox(mesh);
|
recalculateBoundingBox(mesh);
|
||||||
// FIXME: we should rotate the normals too, instead of recalculating
|
|
||||||
meshmanip->recalculateNormals(mesh, true, false);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
warningstream << "drawMeshNode(): missing mesh" << std::endl;
|
warningstream << "drawMeshNode(): missing mesh" << std::endl;
|
||||||
|
@ -249,10 +249,14 @@ static void rotateMesh(scene::IMesh *mesh, float degrees)
|
|||||||
float c = std::cos(degrees);
|
float c = std::cos(degrees);
|
||||||
float s = std::sin(degrees);
|
float s = std::sin(degrees);
|
||||||
auto rotator = [c, s] (video::S3DVertex *vertex) {
|
auto rotator = [c, s] (video::S3DVertex *vertex) {
|
||||||
float u = vertex->Pos.*U;
|
auto rotate_vec = [c, s] (v3f &vec) {
|
||||||
float v = vertex->Pos.*V;
|
float u = vec.*U;
|
||||||
vertex->Pos.*U = c * u - s * v;
|
float v = vec.*V;
|
||||||
vertex->Pos.*V = s * u + c * v;
|
vec.*U = c * u - s * v;
|
||||||
|
vec.*V = s * u + c * v;
|
||||||
|
};
|
||||||
|
rotate_vec(vertex->Pos);
|
||||||
|
rotate_vec(vertex->Normal);
|
||||||
};
|
};
|
||||||
applyToMesh(mesh, rotator);
|
applyToMesh(mesh, rotator);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user