Medical Imaging Interaction Toolkit  2023.12.00
Medical Imaging Interaction Toolkit
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
vtkPointSetSlicer.h
Go to the documentation of this file.
1 /*============================================================================
2 
3 The Medical Imaging Interaction Toolkit (MITK)
4 
5 Copyright (c) German Cancer Research Center (DKFZ)
6 All rights reserved.
7 
8 Use of this source code is governed by a 3-clause BSD license that can be
9 found in the LICENSE file.
10 
11 ============================================================================*/
12 
13 #ifndef _VTKPOINTSETSLICER_H_
14 #define _VTKPOINTSETSLICER_H_
15 
16 #include <iostream>
17 
18 #include "vtkVersion.h"
19 
20 class vtkCutter;
21 class vtkPlane;
22 class vtkPointLocator;
23 class vtkCell;
24 class vtkDataArray;
25 class vtkCellArray;
26 class vtkPointData;
27 class vtkCellData;
28 
29 #include "mitkCommon.h"
30 
31 #include "vtkPolyDataAlgorithm.h"
32 
33 class vtkPointSetSlicer : public vtkPolyDataAlgorithm
34 {
35 public:
36  vtkTypeMacro(vtkPointSetSlicer, vtkPolyDataAlgorithm);
37 
38  void PrintSelf(std::ostream &os, vtkIndent indent) override;
39 
40  // Description:
41  // Construct with user-specified implicit function; initial value of 0.0; and
42  // generating cut scalars turned off.
43  static vtkPointSetSlicer *New();
44 
45  // Description:
46  // Override GetMTime because we delegate to vtkContourValues and refer to
47  // vtkImplicitFunction.
48  vtkMTimeType GetMTime() override;
49 
50  // Description
51  // Specify the implicit function to perform the cutting.
52  virtual void SetSlicePlane(vtkPlane *);
53  vtkGetObjectMacro(SlicePlane, vtkPlane);
54 
55  // Description:
56  // If this flag is enabled, then the output scalar values will be
57  // interpolated from the implicit function values, and not the input scalar
58  // data.
62 
63  // Description:
64  // Specify a spatial locator for merging points. By default,
65  // an instance of vtkMergePoints is used.
66  void SetLocator(vtkPointLocator *locator);
67  vtkGetObjectMacro(Locator, vtkPointLocator);
68 
69  // Description:
70  // Create default locator. Used to create one when none is specified. The
71  // locator is used to merge coincident points.
72  void CreateDefaultLocator();
73 
74 protected:
75  vtkPointSetSlicer(vtkPlane *cf = nullptr);
76  ~vtkPointSetSlicer() override;
77 
78  int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override;
79  int RequestUpdateExtent(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override;
80  int FillInputPortInformation(int port, vtkInformation *info) override;
81 
82  void UnstructuredGridCutter(vtkDataSet *input, vtkPolyData *output);
83 
84  void ContourUnstructuredGridCell(vtkCell *cell,
85  vtkDataArray *cellScalars,
86  vtkPointLocator *locator,
87  vtkCellArray *verts,
88  vtkCellArray *lines,
89  vtkCellArray *polys,
90  vtkPointData *inPd,
91  vtkPointData *outPd,
92  vtkCellData *inCd,
93  vtkIdType cellId,
94  vtkCellData *outCd);
95 
96  vtkPlane *SlicePlane;
97  vtkCutter *Cutter;
98 
99  vtkPointLocator *Locator;
101 
102 private:
103  vtkPointSetSlicer(const vtkPointSetSlicer &); // Not implemented.
104  void operator=(const vtkPointSetSlicer &); // Not implemented.
105 
106  static int edges[12][2];
107 
108  typedef int EDGE_LIST;
109  typedef struct
110  {
111  EDGE_LIST edges[8];
112  } POLY_CASES;
113 
114  static POLY_CASES polyCases[256];
115 };
116 
117 #endif /* _VTKPOINTSETSLICER_H_ */
vtkPointSetSlicer
Definition: vtkPointSetSlicer.h:33
vtkPointSetSlicer::GenerateCutScalars
int GenerateCutScalars
Definition: vtkPointSetSlicer.h:100
vtkPointSetSlicer::vtkBooleanMacro
vtkBooleanMacro(GenerateCutScalars, int)
vtkPointSetSlicer::CreateDefaultLocator
void CreateDefaultLocator()
vtkPointSetSlicer::PrintSelf
void PrintSelf(std::ostream &os, vtkIndent indent) override
vtkPointSetSlicer::Locator
vtkPointLocator * Locator
Definition: vtkPointSetSlicer.h:99
vtkPointSetSlicer::SetSlicePlane
virtual void SetSlicePlane(vtkPlane *)
vtkPointSetSlicer::SetLocator
void SetLocator(vtkPointLocator *locator)
vtkPointSetSlicer::RequestData
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
vtkPointSetSlicer::vtkGetObjectMacro
vtkGetObjectMacro(SlicePlane, vtkPlane)
vtkPointSetSlicer::FillInputPortInformation
int FillInputPortInformation(int port, vtkInformation *info) override
vtkPointSetSlicer::vtkSetMacro
vtkSetMacro(GenerateCutScalars, int)
vtkPointSetSlicer::vtkTypeMacro
vtkTypeMacro(vtkPointSetSlicer, vtkPolyDataAlgorithm)
vtkPointSetSlicer::Cutter
vtkCutter * Cutter
Definition: vtkPointSetSlicer.h:97
vtkPointSetSlicer::GetMTime
vtkMTimeType GetMTime() override
vtkPointSetSlicer::SlicePlane
vtkPlane * SlicePlane
Definition: vtkPointSetSlicer.h:96
vtkPointSetSlicer::~vtkPointSetSlicer
~vtkPointSetSlicer() override
mitkCommon.h
vtkPointSetSlicer::ContourUnstructuredGridCell
void ContourUnstructuredGridCell(vtkCell *cell, vtkDataArray *cellScalars, vtkPointLocator *locator, vtkCellArray *verts, vtkCellArray *lines, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd)
vtkPointSetSlicer::UnstructuredGridCutter
void UnstructuredGridCutter(vtkDataSet *input, vtkPolyData *output)
vtkPointSetSlicer::RequestUpdateExtent
int RequestUpdateExtent(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
vtkPointSetSlicer::vtkGetMacro
vtkGetMacro(GenerateCutScalars, int)
vtkPointSetSlicer::New
static vtkPointSetSlicer * New()
vtkPointSetSlicer::vtkPointSetSlicer
vtkPointSetSlicer(vtkPlane *cf=nullptr)