如何在 vtk 中初始化三角形网格

问题描述

我需要根据我拥有的点列表在 vtk 上创建一个三角形网格。这些点存储在 sphere 下,这是一个 nx9 numpy 数组,其中每一行代表组成一个三角形的三个点。现在我正在这样做:

points = vtk.vtkPoints()
triangles = vtk.vtkCellArray()
polydata = vtk.vtkpolyData()

for i in range(len(sphere)):
    points.InsertNextPoint(sphere[i][:3])
    points.InsertNextPoint(sphere[i][3:6])
    points.InsertNextPoint(sphere[i][6:9])

    triangle = vtk.vtkTriangle()
    triangle.GetPointIds().SetId(0,0)
    triangle.GetPointIds().SetId(1,1)
    triangle.GetPointIds().SetId(2,2)

    triangles.InsertNextCell(triangle)

polydata.SetPoints(points)
polydata.Setpolys(triangles)

这不能正确识别每个三角形。我该如何解决这个问题?

解决方法

每个 InsertNextPoint 返回一个 vtkIdType。这些是应该进入三角形 SetID 的第二个参数的数字。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...