36 #ifndef vtkPolarAxesActor_h
37 #define vtkPolarAxesActor_h
43 #include "vtkRenderingAnnotationModule.h"
48 VTK_ABI_NAMESPACE_BEGIN
82 virtual void SetPole(
double,
double,
double);
83 vtkGetVector3Macro(Pole,
double);
91 vtkSetMacro(Log,
bool);
92 vtkGetMacro(Log,
bool);
93 vtkBooleanMacro(Log,
bool);
101 vtkSetClampMacro(RequestedNumberOfRadialAxes,
vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_RADIAL_AXES);
110 vtkSetClampMacro(RequestedNumberOfPolarAxes,
vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_POLAR_AXES);
120 vtkSetMacro(AutoSubdividePolarAxis,
bool);
122 vtkGetMacro(AutoSubdividePolarAxis,
bool);
123 void AutoSubdividePolarAxisOn();
124 void AutoSubdividePolarAxisOff();
133 virtual
void SetNumberOfPolarAxisTicks(
int);
134 int GetNumberOfPolarAxisTicks();
143 vtkGetVectorMacro(
Range,
double, 2);
151 virtual
void SetMinimumRadius(
double);
152 vtkGetMacro(MinimumRadius,
double);
160 virtual
void SetMaximumRadius(
double);
161 vtkGetMacro(MaximumRadius,
double);
169 virtual
void SetMinimumAngle(
double);
170 vtkGetMacro(MinimumAngle,
double);
178 virtual
void SetMaximumAngle(
double);
179 vtkGetMacro(MaximumAngle,
double);
188 vtkSetClampMacro(SmallestVisiblePolarAngle,
double, 0., 5.);
189 vtkGetMacro(SmallestVisiblePolarAngle,
double);
200 vtkGetMacro(TickLocation,
int);
207 vtkSetMacro(RadialUnits,
bool);
208 vtkGetMacro(RadialUnits,
bool);
218 vtkSetMacro(ScreenSize,
double);
219 vtkGetMacro(ScreenSize,
double);
228 vtkSetVector2Macro(PolarTitleOffset,
double);
229 vtkGetVectorMacro(PolarTitleOffset,
double, 2);
238 vtkSetVector2Macro(RadialTitleOffset,
double);
239 vtkGetVectorMacro(RadialTitleOffset,
double, 2);
247 vtkGetMacro(PolarLabelOffset,
double);
248 vtkSetMacro(PolarLabelOffset,
double);
256 vtkGetMacro(PolarExponentOffset,
double);
257 vtkSetMacro(PolarExponentOffset,
double);
274 vtkSetStringMacro(PolarAxisTitle);
275 vtkGetStringMacro(PolarAxisTitle);
282 vtkSetStringMacro(PolarLabelFormat);
283 vtkGetStringMacro(PolarLabelFormat);
288 VTK_EXPONENT_BOTTOM = 0,
289 VTK_EXPONENT_EXTERN = 1,
290 VTK_EXPONENT_LABELS = 2
307 vtkSetStringMacro(RadialAngleFormat);
308 vtkGetStringMacro(RadialAngleFormat);
323 vtkSetMacro(EnableDistanceLOD,
bool);
324 vtkGetMacro(EnableDistanceLOD,
bool);
332 vtkSetClampMacro(DistanceLODThreshold,
double, 0.0, 1.0);
333 vtkGetMacro(DistanceLODThreshold,
double);
341 vtkSetMacro(EnableViewAngleLOD,
bool);
342 vtkGetMacro(EnableViewAngleLOD,
bool);
350 vtkSetClampMacro(ViewAngleLODThreshold,
double, 0., 1.);
351 vtkGetMacro(ViewAngleLODThreshold,
double);
359 vtkSetMacro(PolarAxisVisibility,
bool);
360 vtkGetMacro(PolarAxisVisibility,
bool);
361 vtkBooleanMacro(PolarAxisVisibility,
bool);
369 vtkSetMacro(DrawRadialGridlines,
bool);
370 vtkGetMacro(DrawRadialGridlines,
bool);
371 vtkBooleanMacro(DrawRadialGridlines,
bool);
379 vtkSetMacro(DrawPolarArcsGridlines,
bool);
380 vtkGetMacro(DrawPolarArcsGridlines,
bool);
381 vtkBooleanMacro(DrawPolarArcsGridlines,
bool);
389 vtkSetMacro(PolarTitleVisibility,
bool);
390 vtkGetMacro(PolarTitleVisibility,
bool);
391 vtkBooleanMacro(PolarTitleVisibility,
bool);
396 VTK_TITLE_BOTTOM = 0,
406 vtkSetClampMacro(RadialAxisTitleLocation,
int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
407 vtkGetMacro(RadialAxisTitleLocation,
int);
416 vtkSetClampMacro(PolarAxisTitleLocation,
int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
417 vtkGetMacro(PolarAxisTitleLocation,
int);
425 vtkSetMacro(PolarLabelVisibility,
bool);
426 vtkGetMacro(PolarLabelVisibility,
bool);
427 vtkBooleanMacro(PolarLabelVisibility,
bool);
437 vtkSetMacro(ArcTicksOriginToPolarAxis,
bool);
438 vtkGetMacro(ArcTicksOriginToPolarAxis,
bool);
439 vtkBooleanMacro(ArcTicksOriginToPolarAxis,
bool);
449 vtkSetMacro(RadialAxesOriginToPolarAxis,
bool);
450 vtkGetMacro(RadialAxesOriginToPolarAxis,
bool);
451 vtkBooleanMacro(RadialAxesOriginToPolarAxis,
bool);
459 vtkSetMacro(PolarTickVisibility,
bool);
460 vtkGetMacro(PolarTickVisibility,
bool);
461 vtkBooleanMacro(PolarTickVisibility,
bool);
469 vtkSetMacro(AxisTickVisibility,
bool);
470 vtkGetMacro(AxisTickVisibility,
bool);
471 vtkBooleanMacro(AxisTickVisibility,
bool);
479 vtkSetMacro(AxisMinorTickVisibility,
bool);
480 vtkGetMacro(AxisMinorTickVisibility,
bool);
481 vtkBooleanMacro(AxisMinorTickVisibility,
bool);
489 vtkSetMacro(AxisTickMatchesPolarAxes,
bool);
490 vtkGetMacro(AxisTickMatchesPolarAxes,
bool);
491 vtkBooleanMacro(AxisTickMatchesPolarAxes,
bool);
499 vtkSetMacro(ArcTickVisibility,
bool);
500 vtkGetMacro(ArcTickVisibility,
bool);
501 vtkBooleanMacro(ArcTickVisibility,
bool);
509 vtkSetMacro(ArcMinorTickVisibility,
bool);
510 vtkGetMacro(ArcMinorTickVisibility,
bool);
511 vtkBooleanMacro(ArcMinorTickVisibility,
bool);
519 vtkSetMacro(ArcTickMatchesRadialAxes,
bool);
520 vtkGetMacro(ArcTickMatchesRadialAxes,
bool);
521 vtkBooleanMacro(ArcTickMatchesRadialAxes,
bool);
530 vtkSetMacro(ArcMajorTickSize,
double);
531 vtkGetMacro(ArcMajorTickSize,
double);
540 vtkSetMacro(PolarAxisMajorTickSize,
double);
541 vtkGetMacro(PolarAxisMajorTickSize,
double);
550 vtkSetMacro(LastRadialAxisMajorTickSize,
double);
551 vtkGetMacro(LastRadialAxisMajorTickSize,
double);
559 vtkSetMacro(PolarAxisTickRatioSize,
double);
560 vtkGetMacro(PolarAxisTickRatioSize,
double);
568 vtkSetMacro(LastAxisTickRatioSize,
double);
569 vtkGetMacro(LastAxisTickRatioSize,
double);
577 vtkSetMacro(ArcTickRatioSize,
double);
578 vtkGetMacro(ArcTickRatioSize,
double);
586 vtkSetMacro(TickRatioRadiusSize,
double);
587 vtkGetMacro(TickRatioRadiusSize,
double);
595 vtkSetMacro(PolarAxisMajorTickThickness,
double);
596 vtkGetMacro(PolarAxisMajorTickThickness,
double);
604 vtkSetMacro(LastRadialAxisMajorTickThickness,
double);
605 vtkGetMacro(LastRadialAxisMajorTickThickness,
double);
613 vtkSetMacro(ArcMajorTickThickness,
double);
614 vtkGetMacro(ArcMajorTickThickness,
double);
622 vtkSetMacro(PolarAxisTickRatioThickness,
double);
623 vtkGetMacro(PolarAxisTickRatioThickness,
double);
631 vtkSetMacro(LastAxisTickRatioThickness,
double);
632 vtkGetMacro(LastAxisTickRatioThickness,
double);
640 vtkSetMacro(ArcTickRatioThickness,
double);
641 vtkGetMacro(ArcTickRatioThickness,
double);
649 vtkSetMacro(DeltaRangeMajor,
double);
650 vtkGetMacro(DeltaRangeMajor,
double);
658 vtkSetMacro(DeltaRangeMinor,
double);
659 vtkGetMacro(DeltaRangeMinor,
double);
668 vtkSetMacro(RequestedDeltaRangePolarAxes,
double);
669 vtkGetMacro(RequestedDeltaRangePolarAxes,
double);
677 vtkSetMacro(DeltaAngleMajor,
double);
678 vtkGetMacro(DeltaAngleMajor,
double);
686 vtkSetMacro(DeltaAngleMinor,
double);
687 vtkGetMacro(DeltaAngleMinor,
double);
696 vtkSetMacro(RequestedDeltaAngleRadialAxes,
double);
697 vtkGetMacro(RequestedDeltaAngleRadialAxes,
double);
707 vtkSetMacro(RadialAxesVisibility,
bool);
708 vtkGetMacro(RadialAxesVisibility,
bool);
709 vtkBooleanMacro(RadialAxesVisibility,
bool);
717 vtkSetMacro(RadialTitleVisibility,
bool);
718 vtkGetMacro(RadialTitleVisibility,
bool);
719 vtkBooleanMacro(RadialTitleVisibility,
bool);
727 vtkSetMacro(PolarArcsVisibility,
bool);
728 vtkGetMacro(PolarArcsVisibility,
bool);
729 vtkBooleanMacro(PolarArcsVisibility,
bool);
820 vtkSetVector6Macro(Bounds,
double);
823 double& xmin,
double& xmax,
double& ymin,
double& ymax,
double& zmin,
double& zmax);
832 vtkSetClampMacro(Ratio,
double, 0.001, 100.0);
833 vtkGetMacro(Ratio,
double);
841 vtkSetClampMacro(PolarArcResolutionPerDegree,
double, VTK_MINIMUM_POLAR_ARC_RESOLUTION_PER_DEG,
842 VTK_MAXIMUM_POLAR_ARC_RESOLUTION_PER_DEG);
843 vtkGetMacro(PolarArcResolutionPerDegree,
double);
895 void AutoComputeTicksProperties();
900 double ComputeIdealStep(
int subDivsRequired,
double rangeLength,
int maxSubDivs = 1000);
905 void BuildArcTicks();
911 void StoreTicksPtsFromParamEllipse(
912 double a,
double angleEllipseRad,
double tickSize,
vtkPoints* tickPts);
917 void BuildPolarAxisLabelsArcs();
922 void BuildPolarAxisLabelsArcsLog();
927 void BuildLabelsLog();
929 void BuildPolarArcsLog();
934 std::
string FindExponentAndAdjustValues(
std::list<
double>& valuesList);
946 double FSign(
double,
double);
959 static
double ComputeEllipseAngle(
double angleInDegrees,
double ratio);
973 double Pole[3] = { 0.0, 0.0, 0.0 };
978 int NumberOfRadialAxes = 0;
984 int RequestedNumberOfRadialAxes = 0;
989 int NumberOfPolarAxes = 5;
995 int RequestedNumberOfPolarAxes = 5;
1005 double PolarArcResolutionPerDegree = 0.2;
1015 double DeltaRangeMinor = 0.5;
1020 double DeltaRangeMajor = 1.0;
1025 bool AutoSubdividePolarAxis =
false;
1030 double DeltaRangePolarAxes = 0.0;
1036 double RequestedDeltaRangePolarAxes = 0.0;
1041 double DeltaAngleMinor = 22.5;
1046 double DeltaAngleMajor = 45.0;
1051 double DeltaAngleRadialAxes = 45.0;
1057 double RequestedDeltaAngleRadialAxes = 45.0;
1062 double MinimumRadius = 0.0;
1067 double MaximumRadius = 1.0;
1077 double MinimumAngle = 0.0;
1082 double MaximumAngle = 90.0;
1087 double SmallestVisiblePolarAngle = 0.5;
1123 char* PolarAxisTitle =
nullptr;
1124 char* PolarLabelFormat =
nullptr;
1130 char* RadialAngleFormat =
nullptr;
1135 bool RadialUnits =
true;
1140 bool EnableDistanceLOD =
true;
1145 double DistanceLODThreshold = 0.7;
1150 bool EnableViewAngleLOD =
true;
1156 double ViewAngleLODThreshold = 0.3;
1162 bool PolarAxisVisibility =
true;
1163 bool PolarTitleVisibility =
true;
1164 bool PolarLabelVisibility =
true;
1179 bool PolarTickVisibility =
true;
1187 bool ArcTicksOriginToPolarAxis =
true;
1195 bool RadialAxesOriginToPolarAxis =
true;
1200 bool AxisTickVisibility =
true, AxisMinorTickVisibility =
false;
1205 bool AxisTickMatchesPolarAxes =
true;
1210 bool ArcTickVisibility =
true, ArcMinorTickVisibility =
false;
1215 bool ArcTickMatchesRadialAxes =
true;
1220 double PolarAxisMajorTickSize = 0.0, LastRadialAxisMajorTickSize = 0.0, ArcMajorTickSize = 0.0;
1225 double PolarAxisTickRatioSize = 0.3, LastAxisTickRatioSize = 0.3, ArcTickRatioSize = 0.3;
1230 double TickRatioRadiusSize = 0.02;
1235 double PolarAxisMajorTickThickness = 1.0, LastRadialAxisMajorTickThickness = 1.0,
1236 ArcMajorTickThickness = 1.0;
1241 double PolarAxisTickRatioThickness = 0.5, LastAxisTickRatioThickness = 0.5,
1242 ArcTickRatioThickness = 0.5;
1248 bool RadialAxesVisibility =
true;
1249 bool RadialTitleVisibility =
true;
1255 int RadialAxisTitleLocation = VTK_TITLE_BOTTOM;
1260 int PolarAxisTitleLocation = VTK_TITLE_BOTTOM;
1271 bool PolarArcsVisibility =
true;
1276 bool DrawRadialGridlines =
true;
1281 bool DrawPolarArcsGridlines =
true;
1344 double TitleScale = -1.0;
1349 double LabelScale = -1.0;
1354 double ScreenSize = 10.0;
1360 double PolarTitleOffset[2] = { 20.0, 10.0 }, RadialTitleOffset[2] = { 20.0, 0.0 };
1361 double PolarLabelOffset = 10.0, PolarExponentOffset = 5.0;
1365 static constexpr
int VTK_MAXIMUM_NUMBER_OF_POLAR_AXES = 20;
1366 static constexpr
int VTK_MAXIMUM_NUMBER_OF_RADIAL_AXES = 50;
1367 static constexpr
double VTK_MINIMUM_POLAR_ARC_RESOLUTION_PER_DEG = 0.05;
1368 static constexpr
double VTK_MAXIMUM_POLAR_ARC_RESOLUTION_PER_DEG = 100.0;
1374 VTK_ABI_NAMESPACE_END
represents an object (geometry & properties) in a rendered scene
Create an axis with tick marks and labels.
a virtual camera for 3D rendering
a simple class to control print indentation
represent and manipulate 3D points
create an actor of a polar axes -
vtkSmartPointer< vtkCamera > Camera
Camera attached to the polar axes system.
vtkNew< vtkPoints > ArcMinorTickPts
Keep the arc minor ticks vtkPoints instances.
virtual void SetPolarAxisProperty(vtkProperty *)
Get/Set polar axis actor properties.
void CalculateBounds()
Calculate bounds based on maximum radius and angular sector.
vtkSmartPointer< vtkTextProperty > PolarAxisTitleTextProperty
Text properties of polar axis title and labels.
void GetBounds(double bounds[6])
Explicitly specify the region in space around which to draw the bounds.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkProperty * GetPolarAxisProperty()
Get/Set polar axis actor properties.
vtkSmartPointer< vtkProperty > PolarAxisProperty
General properties of polar axis Behavior may be override by polar axis ticks 's actor property.
vtkNew< vtkAxisActor > PolarAxis
Control variables for polar axis.
bool GetUse2DMode()
Enable/Disable labels 2D mode (always facing the camera).
vtkNew< vtkActor > ArcTickActor
vtk object for arc Ticks
virtual void SetLastRadialAxisTextProperty(vtkTextProperty *p)
Set/Get the last radial axis text property.
virtual void SetLastRadialAxisProperty(vtkProperty *p)
Get/Set last radial axis actor properties.
virtual void SetSecondaryPolarArcsProperty(vtkProperty *p)
Get/Set secondary polar arcs actors property.
vtkNew< vtkPolyData > SecondaryPolarArcs
Structures for secondary polar arcs.
virtual void SetSecondaryRadialAxesProperty(vtkProperty *p)
Get/Set secondary radial axes actors properties.
vtkSmartPointer< vtkTextProperty > SecondaryRadialAxesTextProperty
Text properties of secondary radial axes.
vtkProperty * GetPolarArcsProperty()
Get/Set principal polar arc actor property.
void GetBounds(double &xmin, double &xmax, double &ymin, double &ymax, double &zmin, double &zmax)
Explicitly specify the region in space around which to draw the bounds.
vtkProperty * GetSecondaryPolarArcsProperty()
Get/Set secondary polar arcs actors property.
vtkSmartPointer< vtkProperty > LastRadialAxisProperty
General properties of last radial axis.
vtkNew< vtkPolyDataMapper > ArcTickPolyDataMapper
vtk object for arc Ticks
virtual void SetPole(double[3])
Explicitly specify the coordinate of the pole.
vtkNew< vtkActor > PolarArcsActor
vtkNew< vtkPolyData > ArcTickPolyData
vtk object for arc Ticks
void CreateRadialAxes(int axisCount)
Create requested number of type X axes.
vtkProperty * GetSecondaryRadialAxesProperty()
Get/Set secondary radial axes actors properties.
vtkTextProperty * GetPolarAxisTitleTextProperty()
Set/Get the polar axis title text property.
vtkSmartPointer< vtkTextProperty > LastRadialAxisTextProperty
Text properties of last radial axis.
vtkNew< vtkPolyData > PolarArcs
void BuildRadialAxes(vtkViewport *viewport=nullptr)
Build requested number of radial axes with respect to specified pole.
virtual void SetPolarAxisTitleTextProperty(vtkTextProperty *p)
Set/Get the polar axis title text property.
vtkNew< vtkPoints > ArcMajorTickPts
Keep the arc major ticks vtkPoints instances.
bool CheckMembersConsistency()
Check consistency of vtkPolarAxesActor members.
vtkProperty * GetLastRadialAxisProperty()
Get/Set last radial axis actor properties.
vtkTextProperty * GetSecondaryRadialAxesTextProperty()
Set/Get the secondary radial axes text property.
vtkSmartPointer< vtkTextProperty > PolarAxisLabelTextProperty
Text properties of polar axis title and labels.
virtual void SetSecondaryRadialAxesTextProperty(vtkTextProperty *p)
Set/Get the secondary radial axes text property.
int RenderOverlay(vtkViewport *) override
Draw the polar axes.
vtkSmartPointer< vtkProperty > SecondaryRadialAxesProperty
General properties of radial axes.
vtkNew< vtkPolyData > ArcMinorTickPolyData
vtk object for arc Ticks
void SetCommonAxisAttributes(vtkAxisActor *)
Send attributes which are common to all axes, both polar and radial.
double * GetBounds() override
Explicitly specify the region in space around which to draw the bounds.
vtkTextProperty * GetPolarAxisLabelTextProperty()
Set/Get the polar axis labels text property.
static vtkPolarAxesActor * New()
Instantiate object with label format "6.3g" and the number of labels per axis set to 3.
vtkNew< vtkActor > ArcMinorTickActor
vtk object for arc Ticks
virtual void SetPole(double, double, double)
Explicitly specify the coordinate of the pole.
vtkTextProperty * GetLastRadialAxisTextProperty()
Set/Get the last radial axis text property.
void SetUse2DMode(bool enable)
Enable/Disable labels 2D mode (always facing the camera).
int RenderOpaqueGeometry(vtkViewport *) override
Draw the polar axes.
void SetPolarAxisAttributes(vtkAxisActor *)
Set properties specific to PolarAxis.
void ReleaseGraphicsResources(vtkWindow *) override
Release any graphics resources that are being consumed by this actor.
vtkNew< vtkPolyDataMapper > PolarArcsMapper
int RenderTranslucentPolygonalGeometry(vtkViewport *) override
Draw the polar axes.
~vtkPolarAxesActor() override
vtkNew< vtkPolyDataMapper > ArcMinorTickPolyDataMapper
vtk object for arc Ticks
virtual void SetPolarAxisLabelTextProperty(vtkTextProperty *p)
Set/Get the polar axis labels text property.
vtkNew< vtkActor > SecondaryPolarArcsActor
Structures for secondary polar arcs.
vtkNew< vtkPolyDataMapper > SecondaryPolarArcsMapper
Structures for secondary polar arcs.
void BuildAxes(vtkViewport *)
Build the axes.
virtual void SetPolarArcsProperty(vtkProperty *p)
Get/Set principal polar arc actor property.
map vtkPolyData to graphics primitives
concrete dataset represents vertices, lines, polygons, and triangle strips
represent surface properties of a geometric object
a vtkAbstractArray subclass for strings
represent text properties.
record modification and/or execution time
abstract specification for Viewports
window superclass for vtkRenderWindow
auto Range(IterablePtr iterable, Options &&... opts) -> typename detail::IterableTraits< typename detail::StripPointers< IterablePtr >::type >::RangeType
Generate an iterable STL proxy object for a VTK container.
#define VTK_DEPRECATED_IN_9_3_0(reason)