1 #include <vtkAutoInit.h>
2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
3 VTK_MODULE_INIT(vtkRenderingFreeType);
4 VTK_MODULE_INIT(vtkInteractionStyle);
5
6 #include <vtkSmartPointer.h>
7 #include <vtkSphereSource.h>
8 #include <vtkConeSource.h>
9 #include <vtkPolyDataConnectivityFilter.h>
10 #include <vtkPolyDataMapper.h>
11 #include <vtkActor.h>
12 #include <vtkProperty.h>
13 #include <vtkRenderer.h>
14 #include <vtkRenderWindow.h>
15 #include <vtkRenderWindowInteractor.h>
16 #include <vtkAppendPolyData.h>
17
18 int main(int, char *[])
19 {
20 vtkSmartPointer<vtkSphereSource> sphereSource =
21 vtkSmartPointer<vtkSphereSource>::New();
22 sphereSource->SetRadius(10);
23 sphereSource->SetThetaResolution(10);
24 sphereSource->SetPhiResolution(10);
25 sphereSource->Update();
26
27 vtkSmartPointer<vtkConeSource> coneSource =
28 vtkSmartPointer<vtkConeSource>::New();
29 coneSource->SetRadius(5);
30 coneSource->SetHeight(10);
31 coneSource->SetCenter(25,0,0);
32 coneSource->Update();
33
34 vtkSmartPointer<vtkAppendPolyData> appendFilter =
35 vtkSmartPointer<vtkAppendPolyData>::New();
36 appendFilter->AddInputData(sphereSource->GetOutput());
37 appendFilter->AddInputData(coneSource->GetOutput());
38 appendFilter->Update();
39
40 vtkSmartPointer<vtkPolyDataConnectivityFilter> connectivityFilter =
41 vtkSmartPointer<vtkPolyDataConnectivityFilter>::New();
42 connectivityFilter->SetInputData(appendFilter->GetOutput());
43 connectivityFilter->SetExtractionModeToCellSeededRegions();
44 connectivityFilter->AddSeed(100);
45 connectivityFilter->Update();
46
47 vtkSmartPointer<vtkPolyDataMapper> originalMapper =
48 vtkSmartPointer<vtkPolyDataMapper>::New();
49 originalMapper->SetInputConnection(appendFilter->GetOutputPort());
50 originalMapper->Update();
51
52 vtkSmartPointer<vtkActor> originalActor =
53 vtkSmartPointer<vtkActor>::New();
54 originalActor->SetMapper(originalMapper);
55
56 vtkSmartPointer<vtkPolyDataMapper> extractedMapper =
57 vtkSmartPointer<vtkPolyDataMapper>::New();
58 extractedMapper->SetInputConnection(connectivityFilter->GetOutputPort());
59 extractedMapper->Update();
60
61 vtkSmartPointer<vtkActor> extractedActor =
62 vtkSmartPointer<vtkActor>::New();
63 extractedActor->SetMapper(extractedMapper);
64
65 double leftViewport[4] = {0.0, 0.0, 0.5, 1.0};
66 double rightViewport[4] = {0.5, 0.0, 1.0, 1.0};
67
68 vtkSmartPointer<vtkRenderer> leftRenderer =
69 vtkSmartPointer<vtkRenderer>::New();
70 leftRenderer->SetViewport(leftViewport);
71 leftRenderer->AddActor(originalActor);
72 leftRenderer->SetBackground(0.8, 0.8, 0.8);
73
74 vtkSmartPointer<vtkRenderer> rightRenderer =
75 vtkSmartPointer<vtkRenderer>::New();
76 rightRenderer->SetViewport(rightViewport);
77 rightRenderer->AddActor(extractedActor);
78 rightRenderer->SetBackground(1.0, 1.0, 1.0);
79
80 vtkSmartPointer<vtkRenderWindow> renderWindow =
81 vtkSmartPointer<vtkRenderWindow>::New();
82 renderWindow->AddRenderer(leftRenderer);
83 renderWindow->AddRenderer(rightRenderer);
84 renderWindow->SetSize(640, 320);
85 renderWindow->Render();
86 renderWindow->SetWindowName("PolyDataConnectedCompExtract");
87
88 leftRenderer->ResetCamera();
89 rightRenderer->SetActiveCamera(leftRenderer->GetActiveCamera());
90
91 vtkSmartPointer<vtkRenderWindowInteractor> interactor =
92 vtkSmartPointer<vtkRenderWindowInteractor>::New();
93 interactor->SetRenderWindow(renderWindow);
94 interactor->Initialize();
95 interactor->Start();
96
97 return EXIT_SUCCESS;
98 }
SetExtractionModeToLargestRegion():用于提取具有最多点数的连通区域;
SetExtractionModeToAllRegions():该模式主要用于连通区域标记,配合函数ColorRegionsOn()使用,在连通区域像是的同时,生成一个名为RegionId的点属性数据。
SetExtractionModeToSpecifiedRegions():该模式用于提取一个或多个连通区域,在该模式下,需要通过AddSpecifiedRegion()来添加西药提取的区域号,区域号从零开始。
SetExtractionModeToClosestPointRegion():该模式需要使用SetClosestPoint()函数设置一个空间点坐标,执行结果为离该点最近的连通区域。
SetExtractionModeToPointSeededRegions():该模式下需要使用AddSeed()函数添加种子点,提取种子点所在的区域。
SetExtractionModeToCellSeededRegions():该模式下需要使用AddSeed()函数调价种子单元,提取种子单元所在的区域。