43#ifndef vtkPolarAxesActor_h
44#define vtkPolarAxesActor_h
49#include "vtkRenderingAnnotationModule.h"
55VTK_ABI_NAMESPACE_BEGIN
89 virtual void SetPole(
double,
double,
double);
90 vtkGetVector3Macro(Pole,
double);
98 vtkSetMacro(Log,
bool);
99 vtkGetMacro(Log,
bool);
100 vtkBooleanMacro(Log,
bool);
108 vtkSetClampMacro(RequestedNumberOfRadialAxes,
vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_RADIAL_AXES);
117 vtkSetClampMacro(RequestedNumberOfPolarAxes,
vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_POLAR_AXES);
126 vtkSetVector2Macro(Range,
double);
127 vtkGetVectorMacro(Range,
double, 2);
136 vtkGetMacro(MinimumRadius,
double);
145 vtkGetMacro(MaximumRadius,
double);
154 vtkGetMacro(MinimumAngle,
double);
163 vtkGetMacro(MaximumAngle,
double);
172 vtkSetClampMacro(SmallestVisiblePolarAngle,
double, 0., 5.);
173 vtkGetMacro(SmallestVisiblePolarAngle,
double);
184 vtkGetMacro(TickLocation,
int);
191 vtkSetMacro(RadialUnits,
bool);
192 vtkGetMacro(RadialUnits,
bool);
202 vtkSetMacro(ScreenSize,
double);
203 vtkGetMacro(ScreenSize,
double);
212 vtkSetVector2Macro(PolarTitleOffset,
double);
213 vtkGetVectorMacro(PolarTitleOffset,
double, 2);
222 vtkSetVector2Macro(RadialTitleOffset,
double);
223 vtkGetVectorMacro(RadialTitleOffset,
double, 2);
231 vtkGetMacro(PolarLabelOffset,
double);
232 vtkSetMacro(PolarLabelOffset,
double);
240 vtkGetMacro(PolarExponentOffset,
double);
241 vtkSetMacro(PolarExponentOffset,
double);
258 vtkSetStringMacro(PolarAxisTitle);
259 vtkGetStringMacro(PolarAxisTitle);
266 vtkSetStringMacro(PolarLabelFormat);
267 vtkGetStringMacro(PolarLabelFormat);
272 VTK_EXPONENT_BOTTOM = 0,
273 VTK_EXPONENT_EXTERN = 1,
274 VTK_EXPONENT_LABELS = 2
291 vtkSetStringMacro(RadialAngleFormat);
292 vtkGetStringMacro(RadialAngleFormat);
307 vtkSetMacro(EnableDistanceLOD,
bool);
308 vtkGetMacro(EnableDistanceLOD,
bool);
316 vtkSetClampMacro(DistanceLODThreshold,
double, 0.0, 1.0);
317 vtkGetMacro(DistanceLODThreshold,
double);
325 vtkSetMacro(EnableViewAngleLOD,
bool);
326 vtkGetMacro(EnableViewAngleLOD,
bool);
334 vtkSetClampMacro(ViewAngleLODThreshold,
double, 0., 1.);
335 vtkGetMacro(ViewAngleLODThreshold,
double);
343 vtkSetMacro(PolarAxisVisibility,
bool);
344 vtkGetMacro(PolarAxisVisibility,
bool);
345 vtkBooleanMacro(PolarAxisVisibility,
bool);
353 vtkSetMacro(DrawRadialGridlines,
bool);
354 vtkGetMacro(DrawRadialGridlines,
bool);
355 vtkBooleanMacro(DrawRadialGridlines,
bool);
363 vtkSetMacro(DrawPolarArcsGridlines,
bool);
364 vtkGetMacro(DrawPolarArcsGridlines,
bool);
365 vtkBooleanMacro(DrawPolarArcsGridlines,
bool);
373 vtkSetMacro(PolarTitleVisibility,
bool);
374 vtkGetMacro(PolarTitleVisibility,
bool);
375 vtkBooleanMacro(PolarTitleVisibility,
bool);
380 VTK_TITLE_BOTTOM = 0,
390 vtkSetClampMacro(RadialAxisTitleLocation,
int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
391 vtkGetMacro(RadialAxisTitleLocation,
int);
400 vtkSetClampMacro(PolarAxisTitleLocation,
int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
401 vtkGetMacro(PolarAxisTitleLocation,
int);
409 vtkSetMacro(PolarLabelVisibility,
bool);
410 vtkGetMacro(PolarLabelVisibility,
bool);
411 vtkBooleanMacro(PolarLabelVisibility,
bool);
421 vtkSetMacro(ArcTicksOriginToPolarAxis,
bool);
422 vtkGetMacro(ArcTicksOriginToPolarAxis,
bool);
423 vtkBooleanMacro(ArcTicksOriginToPolarAxis,
bool);
433 vtkSetMacro(RadialAxesOriginToPolarAxis,
bool);
434 vtkGetMacro(RadialAxesOriginToPolarAxis,
bool);
435 vtkBooleanMacro(RadialAxesOriginToPolarAxis,
bool);
443 vtkSetMacro(PolarTickVisibility,
bool);
444 vtkGetMacro(PolarTickVisibility,
bool);
445 vtkBooleanMacro(PolarTickVisibility,
bool);
453 vtkSetMacro(AxisTickVisibility,
bool);
454 vtkGetMacro(AxisTickVisibility,
bool);
455 vtkBooleanMacro(AxisTickVisibility,
bool);
463 vtkSetMacro(AxisMinorTickVisibility,
bool);
464 vtkGetMacro(AxisMinorTickVisibility,
bool);
465 vtkBooleanMacro(AxisMinorTickVisibility,
bool);
473 vtkSetMacro(AxisTickMatchesPolarAxes,
bool);
474 vtkGetMacro(AxisTickMatchesPolarAxes,
bool);
475 vtkBooleanMacro(AxisTickMatchesPolarAxes,
bool);
483 vtkSetMacro(ArcTickVisibility,
bool);
484 vtkGetMacro(ArcTickVisibility,
bool);
485 vtkBooleanMacro(ArcTickVisibility,
bool);
493 vtkSetMacro(ArcMinorTickVisibility,
bool);
494 vtkGetMacro(ArcMinorTickVisibility,
bool);
495 vtkBooleanMacro(ArcMinorTickVisibility,
bool);
503 vtkSetMacro(ArcTickMatchesRadialAxes,
bool);
504 vtkGetMacro(ArcTickMatchesRadialAxes,
bool);
505 vtkBooleanMacro(ArcTickMatchesRadialAxes,
bool);
514 vtkSetMacro(ArcMajorTickSize,
double);
515 vtkGetMacro(ArcMajorTickSize,
double);
524 vtkSetMacro(PolarAxisMajorTickSize,
double);
525 vtkGetMacro(PolarAxisMajorTickSize,
double);
534 vtkSetMacro(LastRadialAxisMajorTickSize,
double);
535 vtkGetMacro(LastRadialAxisMajorTickSize,
double);
543 vtkSetMacro(PolarAxisTickRatioSize,
double);
544 vtkGetMacro(PolarAxisTickRatioSize,
double);
552 vtkSetMacro(LastAxisTickRatioSize,
double);
553 vtkGetMacro(LastAxisTickRatioSize,
double);
561 vtkSetMacro(ArcTickRatioSize,
double);
562 vtkGetMacro(ArcTickRatioSize,
double);
570 vtkSetMacro(TickRatioRadiusSize,
double);
571 vtkGetMacro(TickRatioRadiusSize,
double);
579 vtkSetMacro(PolarAxisMajorTickThickness,
double);
580 vtkGetMacro(PolarAxisMajorTickThickness,
double);
588 vtkSetMacro(LastRadialAxisMajorTickThickness,
double);
589 vtkGetMacro(LastRadialAxisMajorTickThickness,
double);
597 vtkSetMacro(ArcMajorTickThickness,
double);
598 vtkGetMacro(ArcMajorTickThickness,
double);
606 vtkSetMacro(PolarAxisTickRatioThickness,
double);
607 vtkGetMacro(PolarAxisTickRatioThickness,
double);
615 vtkSetMacro(LastAxisTickRatioThickness,
double);
616 vtkGetMacro(LastAxisTickRatioThickness,
double);
624 vtkSetMacro(ArcTickRatioThickness,
double);
625 vtkGetMacro(ArcTickRatioThickness,
double);
633 vtkSetMacro(DeltaRangeMajor,
double);
634 vtkGetMacro(DeltaRangeMajor,
double);
642 vtkSetMacro(DeltaRangeMinor,
double);
643 vtkGetMacro(DeltaRangeMinor,
double);
652 vtkSetMacro(RequestedDeltaRangePolarAxes,
double);
653 vtkGetMacro(RequestedDeltaRangePolarAxes,
double);
661 vtkSetMacro(DeltaAngleMajor,
double);
662 vtkGetMacro(DeltaAngleMajor,
double);
670 vtkSetMacro(DeltaAngleMinor,
double);
671 vtkGetMacro(DeltaAngleMinor,
double);
680 vtkSetMacro(RequestedDeltaAngleRadialAxes,
double);
681 vtkGetMacro(RequestedDeltaAngleRadialAxes,
double);
691 vtkSetMacro(RadialAxesVisibility,
bool);
692 vtkGetMacro(RadialAxesVisibility,
bool);
693 vtkBooleanMacro(RadialAxesVisibility,
bool);
701 vtkSetMacro(RadialTitleVisibility,
bool);
702 vtkGetMacro(RadialTitleVisibility,
bool);
703 vtkBooleanMacro(RadialTitleVisibility,
bool);
711 vtkSetMacro(PolarArcsVisibility,
bool);
712 vtkGetMacro(PolarArcsVisibility,
bool);
713 vtkBooleanMacro(PolarArcsVisibility,
bool);
804 vtkSetVector6Macro(Bounds,
double);
807 double& xmin,
double& xmax,
double& ymin,
double& ymax,
double& zmin,
double& zmax);
816 vtkSetClampMacro(Ratio,
double, 0.001, 100.0);
817 vtkGetMacro(Ratio,
double);
825 vtkSetClampMacro(PolarArcResolutionPerDegree,
double, VTK_MINIMUM_POLAR_ARC_RESOLUTION_PER_DEG,
826 VTK_MAXIMUM_POLAR_ARC_RESOLUTION_PER_DEG);
827 vtkGetMacro(PolarArcResolutionPerDegree,
double);
887 double a,
double angleEllipseRad,
double tickSize,
vtkPoints* tickPts);
948 double Pole[3] = { 0.0, 0.0, 0.0 };
953 int NumberOfRadialAxes = 0;
959 int RequestedNumberOfRadialAxes = 0;
964 int NumberOfPolarAxes = 5;
970 int RequestedNumberOfPolarAxes = 5;
980 double PolarArcResolutionPerDegree = 0.2;
985 double Range[2] = { 0.0, 10.0 };
990 double DeltaRangeMinor = 0.5;
995 double DeltaRangeMajor = 1.0;
1000 double DeltaRangePolarAxes = 0.0;
1006 double RequestedDeltaRangePolarAxes = 0.0;
1011 double DeltaAngleMinor = 22.5;
1016 double DeltaAngleMajor = 45.0;
1021 double DeltaAngleRadialAxes = 45.0;
1027 double RequestedDeltaAngleRadialAxes = 45.0;
1032 double MinimumRadius = 0.0;
1037 double MaximumRadius = 1.0;
1047 double MinimumAngle = 0.0;
1052 double MaximumAngle = 90.0;
1057 double SmallestVisiblePolarAngle = 0.5;
1093 char* PolarAxisTitle =
nullptr;
1094 char* PolarLabelFormat =
nullptr;
1100 char* RadialAngleFormat =
nullptr;
1105 bool RadialUnits =
true;
1110 bool EnableDistanceLOD =
true;
1115 double DistanceLODThreshold = 0.7;
1120 bool EnableViewAngleLOD =
true;
1126 double ViewAngleLODThreshold = 0.3;
1132 bool PolarAxisVisibility =
true;
1133 bool PolarTitleVisibility =
true;
1134 bool PolarLabelVisibility =
true;
1149 bool PolarTickVisibility =
true;
1157 bool ArcTicksOriginToPolarAxis =
true;
1165 bool RadialAxesOriginToPolarAxis =
true;
1170 bool AxisTickVisibility =
true, AxisMinorTickVisibility =
false;
1175 bool AxisTickMatchesPolarAxes =
true;
1180 bool ArcTickVisibility =
true, ArcMinorTickVisibility =
false;
1185 bool ArcTickMatchesRadialAxes =
true;
1190 double PolarAxisMajorTickSize = 0.0, LastRadialAxisMajorTickSize = 0.0, ArcMajorTickSize = 0.0;
1195 double PolarAxisTickRatioSize = 0.3, LastAxisTickRatioSize = 0.3, ArcTickRatioSize = 0.3;
1200 double TickRatioRadiusSize = 0.02;
1205 double PolarAxisMajorTickThickness = 1.0, LastRadialAxisMajorTickThickness = 1.0,
1206 ArcMajorTickThickness = 1.0;
1211 double PolarAxisTickRatioThickness = 0.5, LastAxisTickRatioThickness = 0.5,
1212 ArcTickRatioThickness = 0.5;
1218 bool RadialAxesVisibility =
true;
1219 bool RadialTitleVisibility =
true;
1225 int RadialAxisTitleLocation = VTK_TITLE_BOTTOM;
1230 int PolarAxisTitleLocation = VTK_TITLE_BOTTOM;
1241 bool PolarArcsVisibility =
true;
1246 bool DrawRadialGridlines =
true;
1251 bool DrawPolarArcsGridlines =
true;
1314 double TitleScale = -1.0;
1319 double LabelScale = -1.0;
1324 double ScreenSize = 10.0;
1330 double PolarTitleOffset[2] = { 20.0, 10.0 }, RadialTitleOffset[2] = { 20.0, 0.0 };
1331 double PolarLabelOffset = 10.0, PolarExponentOffset = 5.0;
1335 static constexpr int VTK_MAXIMUM_NUMBER_OF_POLAR_AXES = 20;
1336 static constexpr int VTK_MAXIMUM_NUMBER_OF_RADIAL_AXES = 50;
1337 static constexpr double VTK_MINIMUM_POLAR_ARC_RESOLUTION_PER_DEG = 0.05;
1338 static constexpr double VTK_MAXIMUM_POLAR_ARC_RESOLUTION_PER_DEG = 100.0;
1344VTK_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
Allocate and hold a VTK object.
represent and manipulate 3D points
create an actor of a polar axes -
vtkSmartPointer< vtkCamera > Camera
Camera attached to the polar axes system.
vtkProperty * GetLastRadialAxisProperty()
Get/Set last radial axis actor properties.
virtual void SetCamera(vtkCamera *)
Set/Get the camera to perform scaling and translation of the vtkPolarAxesActor.
double * GetBounds() override
Explicitly specify the region in space around which to draw the bounds.
vtkTextProperty * GetLastRadialAxisTextProperty()
Set/Get the last radial axis text property.
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.
vtkTextProperty * GetSecondaryRadialAxesTextProperty()
Set/Get the secondary radial axes text property.
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 AutoScale(vtkViewport *viewport)
Automatically rescale titles and labels NB: Current implementation only for perspective projections.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
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.
void BuildPolarAxisLabelsArcs()
Build polar axis labels and arcs with respect to specified pole.
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.
void StoreTicksPtsFromParamEllipse(double a, double angleEllipseRad, double tickSize, vtkPoints *tickPts)
Init tick point located on an ellipse at angleEllipseRad angle and according to "a" major radius.
vtkTextProperty * GetPolarAxisTitleTextProperty()
Set/Get the polar axis title text property.
virtual void SetMinimumRadius(double)
Set/Get the minimal radius of the polar coordinates.
virtual void ComputeDeltaAngleRadialAxes(vtkIdType)
Compute delta angle of radial axes.
vtkSmartPointer< vtkTextProperty > SecondaryRadialAxesTextProperty
Text properties of secondary radial axes.
static vtkPolarAxesActor * New()
Instantiate object with label format "6.3g" and the number of labels per axis set to 3.
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.
vtkCamera * GetCamera()
Set/Get the camera to perform scaling and translation of the vtkPolarAxesActor.
void GetSignificantPartFromValues(vtkStringArray *valuesStr, std::list< double > &valuesList)
Yield a string array with the float part of each values.
vtkSmartPointer< vtkProperty > LastRadialAxisProperty
General properties of last radial axis.
vtkNew< vtkPolyDataMapper > ArcTickPolyDataMapper
vtk object for arc Ticks
virtual void SetMinimumAngle(double)
Set/Get the minimum radius of the polar coordinates (in degrees).
vtkProperty * GetPolarArcsProperty()
Get/Set principal polar arc actor property.
virtual void SetPole(double[3])
Explicitly specify the coordinate of the pole.
vtkNew< vtkActor > PolarArcsActor
void BuildLabelsLog()
Define label values.
vtkNew< vtkPolyData > ArcTickPolyData
vtk object for arc Ticks
void BuildArcTicks()
Build Arc ticks.
void CreateRadialAxes(int axisCount)
Create requested number of type X axes.
double FSign(double, double)
Convenience methods.
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.
double ComputeIdealStep(int subDivsRequired, double rangeLength, int maxSubDivs=1000)
return a step attempting to be as rounded as possible according to input parameters
static double ComputeEllipseAngle(double angleInDegrees, double ratio)
convert section angle to an angle applied to ellipse equation.
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 * GetSecondaryPolarArcsProperty()
Get/Set secondary polar arcs actors property.
vtkSmartPointer< vtkTextProperty > PolarAxisLabelTextProperty
Text properties of polar axis title and labels.
void BuildPolarAxisLabelsArcsLog()
Build labels and arcs with log scale axis.
virtual void SetSecondaryRadialAxesTextProperty(vtkTextProperty *p)
Set/Get the secondary radial axes text property.
int RenderOverlay(vtkViewport *) override
Draw the polar axes.
virtual void ComputeDeltaRangePolarAxes(vtkIdType)
Compute delta range of 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.
vtkProperty * GetSecondaryRadialAxesProperty()
Get/Set secondary radial axes actors properties.
virtual void SetMaximumRadius(double)
Set/Get the maximum radius of the polar coordinates.
double FFix(double)
Convenience methods.
vtkNew< vtkActor > ArcMinorTickActor
vtk object for arc Ticks
virtual void SetPole(double, double, double)
Explicitly specify the coordinate of the pole.
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
std::string FindExponentAndAdjustValues(std::list< double > &valuesList)
Find a common exponent for label values.
virtual void SetMaximumAngle(double)
Set/Get the maximum radius of the polar coordinates (in degrees).
vtkTextProperty * GetPolarAxisLabelTextProperty()
Set/Get the polar axis labels text property.
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.
vtkProperty * GetPolarAxisProperty()
Get/Set polar axis actor properties.
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
Hold a reference to a vtkObjectBase instance.
a vtkAbstractArray subclass for strings
represent text properties.
record modification and/or execution time
abstract specification for Viewports
window superclass for vtkRenderWindow