Как отобразить облако точек в vtk разными цветами?

#python #vtk

#python #vtk

Вопрос:

У меня есть облако точек, которое я хочу визуализировать в vtk. Я хочу видеть их разными цветами в зависимости от некоторых условий. Я использую python.

Любые предложения о том, как это сделать?

Большое спасибо

Ответ №1:

Вот пример, который задает цвет точки на основе значения оси z.

 import vtk
from numpy import random

class VtkPointCloud:

    def __init__(self, zMin=-10.0, zMax=10.0, maxNumPoints=1e6):
        self.maxNumPoints = maxNumPoints
        self.vtkPolyData = vtk.vtkPolyData()
        self.clearPoints()
        mapper = vtk.vtkPolyDataMapper()
        mapper.SetInputData(self.vtkPolyData)
        mapper.SetColorModeToDefault()
        mapper.SetScalarRange(zMin, zMax)
        mapper.SetScalarVisibility(1)
        self.vtkActor = vtk.vtkActor()
        self.vtkActor.SetMapper(mapper)

    def addPoint(self, point):
        if self.vtkPoints.GetNumberOfPoints() < self.maxNumPoints:
            pointId = self.vtkPoints.InsertNextPoint(point[:])
            self.vtkDepth.InsertNextValue(point[2])
            self.vtkCells.InsertNextCell(1)
            self.vtkCells.InsertCellPoint(pointId)
        else:
            r = random.randint(0, self.maxNumPoints)
            self.vtkPoints.SetPoint(r, point[:])
        self.vtkCells.Modified()
        self.vtkPoints.Modified()
        self.vtkDepth.Modified()

    def clearPoints(self):
        self.vtkPoints = vtk.vtkPoints()
        self.vtkCells = vtk.vtkCellArray()
        self.vtkDepth = vtk.vtkDoubleArray()
        self.vtkDepth.SetName('DepthArray')
        self.vtkPolyData.SetPoints(self.vtkPoints)
        self.vtkPolyData.SetVerts(self.vtkCells)
        self.vtkPolyData.GetPointData().SetScalars(self.vtkDepth)
        self.vtkPolyData.GetPointData().SetActiveScalars('DepthArray')

pointCloud = VtkPointCloud()
for k in xrange(1000):
    point = 20*(random.rand(3)-0.5)
    pointCloud.addPoint(point)
pointCloud.addPoint([0,0,0])
pointCloud.addPoint([0,0,0])
pointCloud.addPoint([0,0,0])
pointCloud.addPoint([0,0,0])

# Renderer
renderer = vtk.vtkRenderer()
renderer.AddActor(pointCloud.vtkActor)
renderer.SetBackground(.2, .3, .4)
renderer.ResetCamera()

# Render Window
renderWindow = vtk.vtkRenderWindow()
renderWindow.AddRenderer(renderer)

# Interactor
renderWindowInteractor = vtk.vtkRenderWindowInteractor()
renderWindowInteractor.SetRenderWindow(renderWindow)

# Begin Interaction
renderWindow.Render()
renderWindowInteractor.Start()
  

Комментарии:

1. Текущий стабильный API (6.2.0) нуждается: mapper.SetInputData(self.vtkPolyData)

2. есть идеи, как установить цвет, указанный тремя значениями r, g, b?

3. @TurboWhale этот пример vtk.org/Wiki/VTK/Examples/Python/TriangleColoredPoints должно помочь. Вы должны создавать vtkUnsignedCharArray с 3 помощью компонентов и использовать InsertNextTuple3 для добавления нужных вам цветов. Далее вы так SetScalars же, как в примере выше, и меняете SetActiveScalars в соответствии с именем вашего массива цветов (или SetActiveScalars вообще удаляете вызов).

4. Есть ли какая-либо возможность добавить несколько точек за один раз и избежать повторения, скажем, 60 тыс. точек и вызова addPoint каждый раз? Я нашел vtkPoints::InsertPoints в ссылке на класс C , но не смог использовать его в python. Заранее спасибо.