1

我一直在尝试在 OpenGL 中创建一个过山车模拟器,它使用一系列 gluLookAt 调用来使相机“乘坐”过山车。过山车本身基于带有坐标数组中控制点的 b 样条曲线。b0(u)、b1(u) 等是 b 样条曲线的混合函数,bprime0(u) 等是它们的导数。这是我的代码的相关部分:

for (int i = 0; i <= 10; i++){
        for (float u = 0; u <= 1.1; u+=0.1){

            x = (b0(u)*coords[(i)%10].x + b1(u)*coords[(i+1)%10].x
                + b2(u)*coords[(i+2)%10].x + b3(u)*coords[(i+3)%10].x)*2.0f;
            y = (b0(u)*coords[(i)%10].y + b1(u)*coords[(i+1)%10].y
                + b2(u)*coords[(i+2)%10].y + b3(u)*coords[(i+3)%10].y)*2.0f;
            z = (b0(u)*coords[(i)%10].z + b1(u)*coords[(i+1)%10].z
                + b2(u)*coords[(i+2)%10].z + b3(u)*coords[(i+3)%10].z)*2.0f;

            xprime = (bprime0(u)*coords[(i)%10].x + bprime1(u)*coords[(i+1)%10].x
                    + bprime2(u)*coords[(i+2)%10].x + bprime3(u)*coords[(i+3)%10].x)*-2.0f;
            yprime = (b0(u)*coords[(i)%10].y + bprime1(u)*coords[(i+1)%10].y
                    + bprime2(u)*coords[(i+2)%10].y + bprime3(u)*coords[(i+3)%10].y)*-2.0f;
            zprime = (b0(u)*coords[(i)%10].z + bprime1(u)*coords[(i+1)%10].z
                    + bprime2(u)*coords[(i+2)%10].z + bprime3(u)*coords[(i+3)%10].z)*-2.0f;

            Coords nvector = {xprime,yprime,zprime};
            float magn = sqrt(nvector.x*nvector.x+nvector.y*nvector.y+nvector.z*nvector.z);
            nvector.x= nvector.x/magn;
            nvector.y= nvector.y/magn;
            nvector.z= nvector.z/magn;

            glLoadIdentity();
            if (rotateCam == 1){
                theta+=0.0001;
                if (theta > 360) {
                    theta = 0;
                }
                gluLookAt(20*cos(theta),15,20*sin(theta),0,0,0,0,1,0);
                }//if
            else{
                printf("%f\t%f\t%f\n", x+xprime,y+yprime,z+zprime);
                gluLookAt(x,y+1,z,x+xprime,y+yprime,z+zprime,0,1,0);
            }//else

        }//for
}//for

空格键切换 'rotateCam' 变量,它应该在两种查看模式之间切换;一个围绕过山车环绕相机(“if”语句)和一个骑过山车(“else”语句)。

事情是这样的:盘旋模式工作正常,模式之间的切换工作正常,但相机在“骑行”模式下总是静止的。printf 语句显示 x、xprime、y、yprime 等都随着每个计时器滴答而变化,但相机从不移动。

如果需要更多代码,请告诉我。

4

1 回答 1

0

gluLookAt不定位 cemera,它只会将其旋转到正确的角度。在此之后,您也可以翻译它。所以这应该可以解决问题:

gluLookAt(x,y+1,z,x+xprime,y+yprime,z+zprime,0,1,0);
gluTranslated(x,y+1,z);
于 2012-11-21T03:04:59.920 回答