VTK  9.2.5
vtkHyperTreeGridAxisReflection.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkHyperTreeGridAxisReflection.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
35 #ifndef vtkHyperTreeGridAxisReflection_h
36 #define vtkHyperTreeGridAxisReflection_h
37 
38 #include "vtkFiltersHyperTreeModule.h" // For export macro
40 
41 class vtkHyperTreeGrid;
42 
43 class VTKFILTERSHYPERTREE_EXPORT vtkHyperTreeGridAxisReflection : public vtkHyperTreeGridAlgorithm
44 {
45 public:
48  void PrintSelf(ostream& os, vtkIndent indent) override;
49 
54  {
55  USE_X_MIN = 0,
56  USE_Y_MIN = 1,
57  USE_Z_MIN = 2,
58  USE_X_MAX = 3,
59  USE_Y_MAX = 4,
60  USE_Z_MAX = 5,
61  USE_X = 6,
62  USE_Y = 7,
63  USE_Z = 8
64  };
65 
67 
70  vtkSetClampMacro(Plane, int, 0, 8);
71  vtkGetMacro(Plane, int);
72  void SetPlaneToX() { this->SetPlane(USE_X); }
73  void SetPlaneToY() { this->SetPlane(USE_Y); }
74  void SetPlaneToZ() { this->SetPlane(USE_Z); }
75  void SetPlaneToXMin() { this->SetPlane(USE_X_MIN); }
76  void SetPlaneToYMin() { this->SetPlane(USE_Y_MIN); }
77  void SetPlaneToZMin() { this->SetPlane(USE_Z_MIN); }
78  void SetPlaneToXMax() { this->SetPlane(USE_X_MAX); }
79  void SetPlaneToYMax() { this->SetPlane(USE_Y_MAX); }
80  void SetPlaneToZMax() { this->SetPlane(USE_Z_MAX); }
82 
84 
88  vtkSetMacro(Center, double);
89  vtkGetMacro(Center, double);
91 
92 protected:
95 
100 
105 
109  int Plane;
110 
115  double Center;
116 
117 private:
119  void operator=(const vtkHyperTreeGridAxisReflection&) = delete;
120 };
121 
122 #endif /* vtkHyperTreeGridAxisReflection */
general representation of visualization data
Superclass for algorithms that produce a hyper tree grid as output.
void SetPlaneToY()
Set the normal of the plane to use as mirror.
double Center
Position of the plane relative to given axis Only used if the reflection plane is X,...
int FillOutputPortInformation(int, vtkInformation *) override
For this algorithm the output is a vtkHyperTreeGrid instance.
int ProcessTrees(vtkHyperTreeGrid *, vtkDataObject *) override
Main routine to extract cells based on reflectioned value.
void SetPlaneToZMax()
Set the normal of the plane to use as mirror.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
void SetPlaneToYMin()
Set the normal of the plane to use as mirror.
void SetPlaneToX()
Set the normal of the plane to use as mirror.
void SetPlaneToXMax()
Set the normal of the plane to use as mirror.
void SetPlaneToXMin()
Set the normal of the plane to use as mirror.
~vtkHyperTreeGridAxisReflection() override
void SetPlaneToZMin()
Set the normal of the plane to use as mirror.
void SetPlaneToYMax()
Set the normal of the plane to use as mirror.
static vtkHyperTreeGridAxisReflection * New()
int Plane
Required type of plane reflection.
void SetPlaneToZ()
Set the normal of the plane to use as mirror.
AxisReflectionPlane
Specify unique identifiers of available reflection planes.
A dataset containing a grid of vtkHyperTree instances arranged as a rectilinear grid.
a simple class to control print indentation
Definition: vtkIndent.h:119
Store vtkAlgorithm input/output information.