0

我需要一个计算曲面和顶点法线的 C# 代码片段。一种表面是三角形的 3D 闭合网格。所需的代码片段必须能够使用顶点集和三角形索引。这些现在可以使用了。3D网格物体表面不光滑,需要进行平滑处理。

你可以帮帮我吗。

4

1 回答 1

7

听起来您正在尝试显示 3D 网格并通过插值表面法线(例如在Phong shading中)应用平滑的着色外观,并且您需要先计算法线。这与平滑网格本身的表面不同,因为这意味着改变其顶点的位置。

曲面法线可以通过获取三角形两条边的向量叉积来计算。

至于代码,我不知道有任何 C# 示例,但这里有一个 C++ 中的示例,应该很容易移植。它取自流行的 OpenGL NeHe 教程

void calcNormal(float v[3][3], float out[3])                // Calculates Normal For A Quad Using 3 Points
{
    float v1[3],v2[3];                      // Vector 1 (x,y,z) & Vector 2 (x,y,z)
    static const int x = 0;                     // Define X Coord
    static const int y = 1;                     // Define Y Coord
    static const int z = 2;                     // Define Z Coord

    // Finds The Vector Between 2 Points By Subtracting
    // The x,y,z Coordinates From One Point To Another.

    // Calculate The Vector From Point 1 To Point 0
    v1[x] = v[0][x] - v[1][x];                  // Vector 1.x=Vertex[0].x-Vertex[1].x
    v1[y] = v[0][y] - v[1][y];                  // Vector 1.y=Vertex[0].y-Vertex[1].y
    v1[z] = v[0][z] - v[1][z];                  // Vector 1.z=Vertex[0].y-Vertex[1].z
    // Calculate The Vector From Point 2 To Point 1
    v2[x] = v[1][x] - v[2][x];                  // Vector 2.x=Vertex[0].x-Vertex[1].x
    v2[y] = v[1][y] - v[2][y];                  // Vector 2.y=Vertex[0].y-Vertex[1].y
    v2[z] = v[1][z] - v[2][z];                  // Vector 2.z=Vertex[0].z-Vertex[1].z
    // Compute The Cross Product To Give Us A Surface Normal
    out[x] = v1[y]*v2[z] - v1[z]*v2[y];             // Cross Product For Y - Z
    out[y] = v1[z]*v2[x] - v1[x]*v2[z];             // Cross Product For X - Z
    out[z] = v1[x]*v2[y] - v1[y]*v2[x];             // Cross Product For X - Y

    ReduceToUnit(out);                      // Normalize The Vectors
}

规范化函数 ReduceToUnit()也可以在那里找到

请注意,这会计算单个三角形的表面法线。由于您没有提供有关如何存储顶点和索引的信息,因此我将由您自己推导出您需要传递给此函数的三角形集。

编辑:作为附加说明,我认为三角形的“缠绕方向”很重要。以错误的方向缠绕也会导致法线指向相反的方向。

于 2009-11-29T11:28:29.097 回答