1

Petrel で TriangleMesh から FractureNetwork を作成する際に問題が発生しています。描画すると、個々の三角形がすべて表示されます。これはソリッドになると思います。いくつかの三角形は接続されているように見えますが、すべてではありません。何か足りないのでしょうか、それとも FractureNetwork をしっかりと見せるための秘訣はありますか?

TriangleMesh はソリッドで、3D ウィンドウで Wireframe をオンにすると正しく表示されます。リンクは、FractureNetwork の横に TriangleMesh があるイメージを示しています。

http://www.flickr.com/photos/65551984@N07/5981436871/

4

1 に答える 1

1

問題は、三角形の生成に使用されるインデックスの順序にあったようです。

次のコードを使用してフラクチャ ネットワークを生成すると、三角形がシェーディングされます。

    public static void Test()
    {
        Point3[] vertices = new Point3[9];
        IndexedTriangle[] triangles = new IndexedTriangle[8];

        vertices[0] = new Point3(0, 100, 0);
        vertices[1] = new Point3(50, 100, 5);
        vertices[2] = new Point3(100, 100, 10);
        vertices[3] = new Point3(0, 50, 15);
        vertices[4] = new Point3(50, 50, 20);
        vertices[5] = new Point3(100, 50, 25);
        vertices[6] = new Point3(0, 0, 30);
        vertices[7] = new Point3(50, 0, 35);
        vertices[8] = new Point3(100, 0, 40);

        triangles[0] = new IndexedTriangle(0, 1, 3);
        triangles[1] = new IndexedTriangle(1, 3, 4);
        triangles[2] = new IndexedTriangle(1, 2, 4);
        triangles[3] = new IndexedTriangle(2, 4, 5);
        triangles[4] = new IndexedTriangle(3, 4, 6);
        triangles[5] = new IndexedTriangle(4, 6, 7);
        triangles[6] = new IndexedTriangle(4, 5, 7);
        triangles[7] = new IndexedTriangle(5, 7, 8);

        IndexedTriangleMesh triangleMesh = new IndexedTriangleMesh(triangles, vertices, null);

        TriangleMesh triMesh = null;
        using (ITransaction trans = Slb.Ocean.Core.DataManager.NewTransaction())
        {
            Project proj = PetrelProject.PrimaryProject;
            trans.Lock(proj);
            string colName = "TringleMeshes";
            Collection collection = Collection.NullObject;
            collection = proj.CreateCollection(colName);

            trans.Lock(collection);

            DomainObjectExtensionRoot root = DomainObjectExtensionRoot.GetInstance();
            trans.Lock(root);

            triMesh = root.CreateTriangleMesh("TestMesh", Domain.ELEVATION_DEPTH, collection, "Test", "");
            trans.Lock(triMesh);
            triMesh.IndexedTriangleMeshes = new IndexedTriangleMesh[] { triangleMesh };
            triMesh.Color = Color.Blue;
            trans.Commit();
        }

        Project project = PetrelProject.PrimaryProject;


        FractureNetwork fractureNetwork;                  

        using (ITransaction trans = Slb.Ocean.Core.DataManager.NewTransaction())
        {
            trans.Lock(project);

            fractureNetwork = project.CreateFractureNetwork("FractureNetwork", Domain.ELEVATION_DEPTH);

            fractureNetwork.CreateFracturePatches(triMesh.IndexedTriangleMeshes);

            trans.Commit();
        }

    }

ただし、インデックスの順序を変更すると、フラクチャ ネットワークは強固になります。

    public static void Test()
    {
        Point3[] vertices = new Point3[9];
        IndexedTriangle[] triangles = new IndexedTriangle[8];

        vertices[0] = new Point3(0, 100, 0);
        vertices[1] = new Point3(50, 100, 5);
        vertices[2] = new Point3(100, 100, 10);
        vertices[3] = new Point3(0, 50, 15);
        vertices[4] = new Point3(50, 50, 20);
        vertices[5] = new Point3(100, 50, 25);
        vertices[6] = new Point3(0, 0, 30);
        vertices[7] = new Point3(50, 0, 35);
        vertices[8] = new Point3(100, 0, 40);

        triangles[0] = new IndexedTriangle(0, 1, 3);
        triangles[1] = new IndexedTriangle(1, 4, 3); // switched order of last two values
        triangles[2] = new IndexedTriangle(1, 2, 4);
        triangles[3] = new IndexedTriangle(2, 5, 4); // switched order of last two values
        triangles[4] = new IndexedTriangle(3, 4, 6);
        triangles[5] = new IndexedTriangle(4, 7, 6); // switched order of last two values
        triangles[6] = new IndexedTriangle(4, 5, 7);
        triangles[7] = new IndexedTriangle(5, 8, 7); // switched order of last two values

        IndexedTriangleMesh triangleMesh = new IndexedTriangleMesh(triangles, vertices, null);

        TriangleMesh triMesh = null;
        using (ITransaction trans = Slb.Ocean.Core.DataManager.NewTransaction())
        {
            Project proj = PetrelProject.PrimaryProject;
            trans.Lock(proj);
            string colName = "TringleMeshes";
            Collection collection = Collection.NullObject;
            collection = proj.CreateCollection(colName);

            trans.Lock(collection);

            DomainObjectExtensionRoot root = DomainObjectExtensionRoot.GetInstance();
            trans.Lock(root);

            triMesh = root.CreateTriangleMesh("TestMesh", Domain.ELEVATION_DEPTH, collection, "Test", "");
            trans.Lock(triMesh);
            triMesh.IndexedTriangleMeshes = new IndexedTriangleMesh[] { triangleMesh };
            triMesh.Color = Color.Blue;
            trans.Commit();
        }

        Project project = PetrelProject.PrimaryProject;


        FractureNetwork fractureNetwork;                  

        using (ITransaction trans = Slb.Ocean.Core.DataManager.NewTransaction())
        {
            trans.Lock(project);

            fractureNetwork = project.CreateFractureNetwork("FractureNetwork", Domain.ELEVATION_DEPTH);

            fractureNetwork.CreateFracturePatches(triMesh.IndexedTriangleMeshes);

            trans.Commit();
        }

    }

画像はhttp://www.flickr.com/photos/65551984@N07/5987611731/で見ることができます

于 2011-07-29T16:42:10.270 に答える