1

我构建了一个快速的 python 脚本,它读取波前 .obj 文件并将顶点和面输出到文件。我有另一个 C++ 函数,它读取这些文件并创建基于这些文件的网格。

我遇到的问题是,有时这可以完美地工作,而其他时候却不是那么好 - 使用相同的网格。例如,我启动我的 PhysX 程序,并创建 10 个相同网格的相同对象,其中一些看起来像这样:

普通网格

和其他看起来像这样:

破碎的网格

以下 C++ 是加载顶点和三角形的代码:

bool ModelLoader::LoadVertexFile(const std::string& fileLocation)
{
    std::ifstream file(fileLocation);
    if (!file) {
        std::cerr << "Failed to load vertex data\n";
        return false;
    }

    float x, y, z;
    vertexArray.clear();

    while (file >> x >> y >> z)
    {
        vertexArray.push_back(PhysicsEngine::PxVec3(x, y, z));
    }
    return true;
}

bool ModelLoader::LoadTrianglesFile(const std::string& fileLocation)
{
    std::ifstream file(fileLocation);
    if (!file) {
        std::cerr << "Failed to load vertex data\n";
        return false;
    }

    int x;
    triangleArray.clear();
    while (file >> x)
    {
        triangleArray.push_back(x);
    }
    return true;
}

这是创建构建网格的代码

   CustomObject(const PxTransform& pose = PxTransform(PxIdentity), string vertfile = "", string trigfile = "") :
        StaticActor(pose)
    {

        modelLoader = new ModelLoader();
        if(!modelLoader->LoadVertexFile(vertfile))
            throw new Exception("Failed to load VertexFile.");
        if(!modelLoader->LoadTrianglesFile(trigfile))
            throw new Exception("Failed to load TrianglesFile.");

        PxTriangleMeshDesc mesh_desc;
        mesh_desc.points.count = (PxU32)modelLoader->vertexArray.size();
        mesh_desc.points.stride = sizeof(PxVec3);
        mesh_desc.points.data = &modelLoader->vertexArray.front();
        mesh_desc.triangles.count = (PxU32)modelLoader->triangleArray.size();
        mesh_desc.triangles.stride = 3 * sizeof(PxU32);
        mesh_desc.triangles.data = &modelLoader->triangleArray.front();

        CreateShape(PxTriangleMeshGeometry(CookMesh(mesh_desc)));
    }

因此,如果有人可以帮助我找出问题所在,将不胜感激

4

0 回答 0