在OpenGL中在地形上行走(使用高度图制作)

时间:2013-08-10 10:20:38

标签: c++ opengl

要在地形上行走物体,目前我正在保持相机和物体固定,并根据按下的键盘按钮移动地形(使用glTranslatef)。我能够轻松地沿x轴和z轴移动,但是当我沿着y轴移动时,我遇到了很多麻烦。以下是代码的基本部分:

我创建了一个名为Terrain的类,它使用bmp文件在不同的点获取高度。基本代码是:

float Terrain::getHeight(int x, int z) {
    return hs[z][x];
}

Terrain* loadTerrain(const char* filename, float height) {
    Image* image = loadBMP(filename);
    Terrain* t = new Terrain(image->width, image->height);
    for (int y = 0; y < image->height; y++) {
        for (int x = 0; x < image->width; x++) {
            unsigned char color = (unsigned char) image->pixels[3
                    * (y * image->width + x)];
            float h = height * ((color / 255.0f) - 0.5f);
            t->setHeight(x, y, h);

        }
    }

    delete image;
    t->computeNormals();
    return t;
}

所以基本上我把它们全部存储在一个数组中,并且可以随时使用x和z。这是我的drawTerrain代码,它采用三个浮点值xx,yy和zz,并且基本上使用glTranslatef来转换xx和zz方向的地形(我还没有用过yy)。

void drawTerrain(float xx, float yy, float zz, float aangle) {
    float yyy;
    glPushMatrix();
    glTranslatef(0.0f, 0.0f, 0.0f);
    glRotatef(-aangle, 0.0f, 1.0f, 0.0f);
    glTranslatef(xx, yy, zz);

    GLfloat ambientColor[] = { 0.4f, 0.4f, 0.4f, 1.0f };
    glLightModelfv(GL_LIGHT_MODEL_AMBIENT, ambientColor);

    GLfloat lightColor0[] = { 0.6f, 0.6f, 0.6f, 1.0f };
    GLfloat lightPos0[] = { -0.5f, 0.8f, 0.1f, 0.0f };
    glLightfv(GL_LIGHT0, GL_DIFFUSE, lightColor0);
    glLightfv(GL_LIGHT0, GL_POSITION, lightPos0);
    glEnable(GL_TEXTURE_2D);
    glBindTexture(GL_TEXTURE_2D, _textureId1);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);

    float scale = 50.0f / max(_terrain->width() - 1, _terrain->length() - 1);
    glScalef(scale, scale, scale);
    glTranslatef(-(float) (_terrain->width() - 1) / 2, 0.0f,
            -(float) (_terrain->length() - 1) / 2);

    glColor3f(1.0f, 1.0f, 1.0f);
    for (int z = 0; z < _terrain->length() - 1; z++) {
        //Makes OpenGL draw a triangle at every three consecutive vertices
        glBegin(GL_TRIANGLE_STRIP);
        for (int x = 0; x < _terrain->width(); x += 2) {
            /*if (x == 0 && z == 0)
             glTexCoord2f(0.0f, 0.0f);
             if (x == _terrain->width() - 1 && z == 0)
             glTexCoord2f(1.0f, 0.0f);
             if (x == 0 && z == _terrain->length() - 1)
             glTexCoord2f(0.0f, 1.0f);
             if (x == _terrain->width() - 1 && z == _terrain->length() - 1)
             glTexCoord2f(1.0f, 1.0f);*/
            Vec3f normal = _terrain->getNormal(x, z);
            glNormal3f(normal[0], normal[1], normal[2]);
            glTexCoord2f((float) x / _terrain->width(),
                    (float) z / _terrain->length());
            glVertex3f(x, _terrain->getHeight(x, z), z);
            normal = _terrain->getNormal(x, z + 1);
            glNormal3f(normal[0], normal[1], normal[2]);
            glTexCoord2f((float) x / _terrain->width(),
                    (float) (z + 1) / _terrain->length());
            glVertex3f(x, _terrain->getHeight(x, z + 1), z + 1);
            glNormal3f(normal[0], normal[1], normal[2]);
            glTexCoord2f((float) (x + 1) / _terrain->width(),
                    (float) z / _terrain->length());
            glVertex3f(x + 1, _terrain->getHeight(x + 1, z), z);
            glNormal3f(normal[0], normal[1], normal[2]);
            glTexCoord2f((float) (x + 1) / _terrain->width(),
                    (float) (z + 1) / _terrain->length());
            glVertex3f(x + 1, _terrain->getHeight(x + 1, z + 1), z + 1);

        }
        //_y = (float) _terrain->getHeight((int) (_x * max(_terrain->width() - 1, _terrain->length() - 1) / 50.0f), (int) (_z * max(_terrain->width() - 1, _terrain->length() - 1) / 50.0f));
        glEnd();
    }

所以为了向y方向翻译,我尝试使用以下代码:

float xxx,yyy,zzz;
xxx = (float) (_terrain->width() - 1) / (2 * scale);
xxx -= xx / scale;
zzz = (float) (_terrain->length() - 1) / (2 * scale);
zzz -= zz / scale;
yyy = scale * _terrain->getHeight(xxx,zzz);
glTranslatef(0.0f,yyy,0.0f);

但是翻译仍然没有根据高度工作,并且y翻译也看起来不连续(因为我正在转换整数和浮点值)。任何人都可以修复此代码,或建议其他方法,以便我可以正确地在地形上行走一个对象?感谢。

0 个答案:

没有答案