我想在C++中使用vtkImageData渲染一个简单的图像。我知道vtkImageDataGeometryFilter可以完成这项工作,但我想知道是否有其他方法可以在不使用PolyData的情况下获得相同的结果?这是我的代码,但我在渲染时阅读时发生了访问冲突,我不知道为什么...
vtkSmartPointer<vtkImageData> imageData =
vtkSmartPointer<vtkImageData>::New();
imageData->SetExtent(0, 5, 0, 5, 0, 1);
imageData->SetSpacing(1, 1, 1);
imageData->SetOrigin(0, 0, 0);
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
imageData->SetScalarComponentFromFloat(i,j,0,0,0);
}
}
vtkSmartPointer<vtkImageActor> imageActor =
vtkSmartPointer<vtkImageActor>::New();
imageActor->SetInputData(imageData);
vtkSmartPointer<vtkRenderer> renderer =
vtkSmartPointer<vtkRenderer>::New();
vtkSmartPointer<vtkRenderWindow> renderWindow =
vtkSmartPointer<vtkRenderWindow>::New();
renderWindow->AddRenderer(renderer);
vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor =
vtkSmartPointer<vtkRenderWindowInteractor>::New();
renderWindowInteractor->SetRenderWindow(renderWindow);
renderer->AddActor(imageActor);
renderWindow->Render();
renderWindowInteractor->Start();
提前感谢您的帮助^^
1条答案
按热度按时间cbeh67ev1#
终于找到了bug,
imageData->AllocateScalars(VTK_FLOAT, 3);
行不见了。下面的代码显示一个绿色正方形: