【问题标题】:Calculating OpenGL Face Normals of Polygon计算多边形的OpenGL面法线
【发布时间】:2014-09-30 20:44:07
【问题描述】:

我正在尝试为从点多边形文件创建的多边形添加光照。我的问题是,从点创建向量时,我只会点亮多边形的某个部分,然后如果我反转法线的计算(从 A.x - C.x 到 C.x - A.x),它会点亮之前未点亮的部分。代码和图片如下。

 h_vector V1;//= (p2 - p1);
    // A = 0 B = 1 C = 2 D =3
    V1.x = vertices[1].x - vertices[0].x;
    V1.y = vertices[1].y - vertices[0].y;
    V1.z = vertices[1].z - vertices[0].z;


    h_vector V2;// = (p3 - p1);

    V2.x = vertices[3].x - vertices[0].x;
    V2.y = vertices[3].y - vertices[0].y;
    V2.z = vertices[3].z - vertices[0].z;
    /*

    h_vector V1;//= (p2 - p1);
    V1.x = vertices[0].x - vertices[1].x;
    V1.y = vertices[0].y - vertices[1].y;
    V1.z = vertices[0].z - vertices[1].z;


    h_vector V2;// = (p3 - p1);

    V2.x = vertices[0].x - vertices[3].x;
    V2.y = vertices[0].y - vertices[3].y;
    V2.z = vertices[0].z - vertices[3].z;
    */

    surfaceNormal.x = (V1.y*V2.z) - (V1.z-V2.y);
    surfaceNormal.y = - ( (V2.z * V1.x) - (V2.x * V1.z) );
    surfaceNormal.z = (V1.x-V2.y) - (V1.y-V2.x);
    float normalize = sqrtf((pow(surfaceNormal.x,2) + pow(surfaceNormal.y,2) + pow(surfaceNormal.z,2)));

    surfaceNormal.x = surfaceNormal.x/normalize;
     surfaceNormal.y = surfaceNormal.y/normalize;
     surfaceNormal.z = surfaceNormal.z/normalize;

【问题讨论】:

  • 问题似乎是人脸剔除,而不是法线,但在结束之前需要查看其余代码。不相关,但可以以更简单的方式进行法线计算。

标签: c opengl 3d normals


【解决方案1】:

这个叉积代码严重损坏:

surfaceNormal.x = (V1.y*V2.z) - (V1.z-V2.y);
surfaceNormal.y = - ( (V2.z * V1.x) - (V2.x * V1.z) );
surfaceNormal.z = (V1.x-V2.y) - (V1.y-V2.x);

括号内的表达式都应该有一个乘法运算符,但在上面的代码中,其中一半是减法。

叉积计算应该是:

surfaceNormal.x = V1.y * V2.z - V1.z * V2.y;
surfaceNormal.y = V1.z * V2.x - V1.x * V2.z;
surfaceNormal.z = V1.x * V2.y - V1.y * V2.x;

您可能想研究使用矩阵/向量库。如果您进行一些搜索,其中有许多是免费的。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-05-15
    • 2014-09-05
    • 1970-01-01
    • 2013-11-13
    • 1970-01-01
    • 2013-10-24
    • 2011-08-11
    • 2018-02-15
    相关资源
    最近更新 更多