gpt4 book ai didi

c++ - DirectX 9 地形生成 C++

转载 作者:行者123 更新时间:2023-11-28 06:20:06 25 4
gpt4 key购买 nike

我在生成带有四边形的平坦地形时遇到了问题,我认为四边形的位置正确但索引不正确。有人可以看看并告诉我我做错了什么或如何修复它吗?基本上显示了地形但完全错误。我认为这是指数定位,请帮助我,我们将不胜感激。

FOR 循环:

    for(int i = 0; i < NUM_VERTS; i += 4){
for(int x = 0; x < j; x ++){
for(int z = 0; z < j; z ++){
verts[i] = D3DVertex::VertexPositionNormalTexture(x, -1.0f, z+1, n, 1.0f, g, 0.0f, 0.0f);
verts[i+1] = D3DVertex::VertexPositionNormalTexture(x+1, -1.0f, z+1, n, 1.0f, g, 1.0f, 0.0f);
verts[i+2] = D3DVertex::VertexPositionNormalTexture(x, -1.0f, z, n, 1.0f, g, 0.0f, 1.0f);
verts[i+2] = D3DVertex::VertexPositionNormalTexture(x+1, -1.0f, z, n, 1.0f, g, 0.0f, 1.0f);
indices[i] = i;
indices[i+1] = i+1;
indices[i+2] = i+2;
indices[i+3] = i+2;
indices[i+4] = i+1;
indices[i+5] = i+3;
}
}
//MessageBox(NULL, L"Test", NULL, NULL);
}

最佳答案

您的最外层循环没有意义。相反,为顶点缓冲区和索引缓冲区维护两个索引,如下所示:

int iVertex = 0;
int iIndex = 0;
for(int x = 0; x < j; x ++){
for(int z = 0; z < j; z ++){
verts[iVertex ] = D3DVertex::VertexPositionNormalTexture(x, -1.0f, z+1, n, 1.0f, g, 0.0f, 0.0f);
verts[iVertex+1] = D3DVertex::VertexPositionNormalTexture(x+1, -1.0f, z+1, n, 1.0f, g, 1.0f, 0.0f);
verts[iVertex+2] = D3DVertex::VertexPositionNormalTexture(x, -1.0f, z, n, 1.0f, g, 0.0f, 1.0f);
verts[iVertex+3] = D3DVertex::VertexPositionNormalTexture(x+1, -1.0f, z, n, 1.0f, g, 0.0f, 1.0f);
indices[iIndex ] = iVertex;
indices[iIndex+1] = iVertex+1;
indices[iIndex+2] = iVertex+2;
indices[iIndex+3] = iVertex+2;
indices[iIndex+4] = iVertex+1;
indices[iIndex+5] = iVertex+3;

iVertex += 4;
iIndex += 6;
}
}

我假设您知道 xz 中的地形将从 0 延伸到 j + 1 方向。

如果只是一个平面,您也可以考虑使用单个四边形。如果您需要多个三角形,您可以考虑将三角形列表转换为三角形带。如果你想坚持三角形列表,你至少应该考虑删除重复的顶点(地形中心的每个顶点存在四次)。

关于c++ - DirectX 9 地形生成 C++,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29457985/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com