VTK  9.4.20250406
vtkPolarAxesActor.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
43#ifndef vtkPolarAxesActor_h
44#define vtkPolarAxesActor_h
45
46#include "vtkActor.h"
47#include "vtkAxisActor.h" // access to enum values
48#include "vtkNew.h" // used for vtkNew
49#include "vtkRenderingAnnotationModule.h" // For export macro
50#include "vtkSmartPointer.h" // used for vtkSmartPointer
51#include "vtkWrappingHints.h" // For VTK_MARSHALAUTO
52#include <list> // To process exponent list as reference
53#include <string> // used for ivar
54
55VTK_ABI_NAMESPACE_BEGIN
56class vtkCamera;
57class vtkPolyData;
59class vtkProperty;
60class vtkStringArray;
61class vtkTextProperty;
62
63class VTKRENDERINGANNOTATION_EXPORT VTK_MARSHALAUTO vtkPolarAxesActor : public vtkActor
64{
65public:
67 void PrintSelf(ostream& os, vtkIndent indent) override;
68
74
76
80 int RenderOverlay(vtkViewport*) override;
83
85
88 virtual void SetPole(double[3]);
89 virtual void SetPole(double, double, double);
90 vtkGetVector3Macro(Pole, double);
92
94
98 vtkSetMacro(Log, bool);
99 vtkGetMacro(Log, bool);
100 vtkBooleanMacro(Log, bool);
102
104
108 vtkSetClampMacro(RequestedNumberOfRadialAxes, vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_RADIAL_AXES);
109 vtkGetMacro(RequestedNumberOfRadialAxes, vtkIdType);
111
113
117 vtkSetClampMacro(RequestedNumberOfPolarAxes, vtkIdType, 0, VTK_MAXIMUM_NUMBER_OF_POLAR_AXES);
118 vtkGetMacro(RequestedNumberOfPolarAxes, vtkIdType);
120
122
126 vtkSetVector2Macro(Range, double);
127 vtkGetVectorMacro(Range, double, 2);
129
131
135 virtual void SetMinimumRadius(double);
136 vtkGetMacro(MinimumRadius, double);
138
140
144 virtual void SetMaximumRadius(double);
145 vtkGetMacro(MaximumRadius, double);
147
149
153 virtual void SetMinimumAngle(double);
154 vtkGetMacro(MinimumAngle, double);
156
158
162 virtual void SetMaximumAngle(double);
163 vtkGetMacro(MaximumAngle, double);
165
167
172 vtkSetClampMacro(SmallestVisiblePolarAngle, double, 0., 5.);
173 vtkGetMacro(SmallestVisiblePolarAngle, double);
175
177
184 vtkGetMacro(TickLocation, int);
186
188
191 vtkSetMacro(RadialUnits, bool);
192 vtkGetMacro(RadialUnits, bool);
194
196
202 vtkSetMacro(ScreenSize, double);
203 vtkGetMacro(ScreenSize, double);
205
207
212 vtkSetVector2Macro(PolarTitleOffset, double);
213 vtkGetVectorMacro(PolarTitleOffset, double, 2);
215
217
222 vtkSetVector2Macro(RadialTitleOffset, double);
223 vtkGetVectorMacro(RadialTitleOffset, double, 2);
225
227
231 vtkGetMacro(PolarLabelOffset, double);
232 vtkSetMacro(PolarLabelOffset, double);
234
236
240 vtkGetMacro(PolarExponentOffset, double);
241 vtkSetMacro(PolarExponentOffset, double);
243
245
249 virtual void SetCamera(vtkCamera*);
252
254
258 vtkSetStringMacro(PolarAxisTitle);
259 vtkGetStringMacro(PolarAxisTitle);
261
263
266 vtkSetStringMacro(PolarLabelFormat);
267 vtkGetStringMacro(PolarLabelFormat);
269
271 {
272 VTK_EXPONENT_BOTTOM = 0,
273 VTK_EXPONENT_EXTERN = 1,
274 VTK_EXPONENT_LABELS = 2
275 };
276
278
283 vtkSetClampMacro(ExponentLocation, int, VTK_EXPONENT_BOTTOM, VTK_EXPONENT_LABELS);
284 vtkGetMacro(ExponentLocation, int);
286
288
291 vtkSetStringMacro(RadialAngleFormat);
292 vtkGetStringMacro(RadialAngleFormat);
294
301
303
307 vtkSetMacro(EnableDistanceLOD, bool);
308 vtkGetMacro(EnableDistanceLOD, bool);
310
312
316 vtkSetClampMacro(DistanceLODThreshold, double, 0.0, 1.0);
317 vtkGetMacro(DistanceLODThreshold, double);
319
321
325 vtkSetMacro(EnableViewAngleLOD, bool);
326 vtkGetMacro(EnableViewAngleLOD, bool);
328
330
334 vtkSetClampMacro(ViewAngleLODThreshold, double, 0., 1.);
335 vtkGetMacro(ViewAngleLODThreshold, double);
337
339
343 vtkSetMacro(PolarAxisVisibility, bool);
344 vtkGetMacro(PolarAxisVisibility, bool);
345 vtkBooleanMacro(PolarAxisVisibility, bool);
347
349
353 vtkSetMacro(DrawRadialGridlines, bool);
354 vtkGetMacro(DrawRadialGridlines, bool);
355 vtkBooleanMacro(DrawRadialGridlines, bool);
357
359
363 vtkSetMacro(DrawPolarArcsGridlines, bool);
364 vtkGetMacro(DrawPolarArcsGridlines, bool);
365 vtkBooleanMacro(DrawPolarArcsGridlines, bool);
367
369
373 vtkSetMacro(PolarTitleVisibility, bool);
374 vtkGetMacro(PolarTitleVisibility, bool);
375 vtkBooleanMacro(PolarTitleVisibility, bool);
377
379 {
380 VTK_TITLE_BOTTOM = 0,
381 VTK_TITLE_EXTERN = 1
382 };
383
385
390 vtkSetClampMacro(RadialAxisTitleLocation, int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
391 vtkGetMacro(RadialAxisTitleLocation, int);
393
395
400 vtkSetClampMacro(PolarAxisTitleLocation, int, VTK_TITLE_BOTTOM, VTK_TITLE_EXTERN);
401 vtkGetMacro(PolarAxisTitleLocation, int);
403
405
409 vtkSetMacro(PolarLabelVisibility, bool);
410 vtkGetMacro(PolarLabelVisibility, bool);
411 vtkBooleanMacro(PolarLabelVisibility, bool);
413
415
421 vtkSetMacro(ArcTicksOriginToPolarAxis, bool);
422 vtkGetMacro(ArcTicksOriginToPolarAxis, bool);
423 vtkBooleanMacro(ArcTicksOriginToPolarAxis, bool);
425
427
433 vtkSetMacro(RadialAxesOriginToPolarAxis, bool);
434 vtkGetMacro(RadialAxesOriginToPolarAxis, bool);
435 vtkBooleanMacro(RadialAxesOriginToPolarAxis, bool);
437
439
443 vtkSetMacro(PolarTickVisibility, bool);
444 vtkGetMacro(PolarTickVisibility, bool);
445 vtkBooleanMacro(PolarTickVisibility, bool);
447
449
453 vtkSetMacro(AxisTickVisibility, bool);
454 vtkGetMacro(AxisTickVisibility, bool);
455 vtkBooleanMacro(AxisTickVisibility, bool);
457
459
463 vtkSetMacro(AxisMinorTickVisibility, bool);
464 vtkGetMacro(AxisMinorTickVisibility, bool);
465 vtkBooleanMacro(AxisMinorTickVisibility, bool);
467
469
473 vtkSetMacro(AxisTickMatchesPolarAxes, bool);
474 vtkGetMacro(AxisTickMatchesPolarAxes, bool);
475 vtkBooleanMacro(AxisTickMatchesPolarAxes, bool);
477
479
483 vtkSetMacro(ArcTickVisibility, bool);
484 vtkGetMacro(ArcTickVisibility, bool);
485 vtkBooleanMacro(ArcTickVisibility, bool);
487
489
493 vtkSetMacro(ArcMinorTickVisibility, bool);
494 vtkGetMacro(ArcMinorTickVisibility, bool);
495 vtkBooleanMacro(ArcMinorTickVisibility, bool);
497
499
503 vtkSetMacro(ArcTickMatchesRadialAxes, bool);
504 vtkGetMacro(ArcTickMatchesRadialAxes, bool);
505 vtkBooleanMacro(ArcTickMatchesRadialAxes, bool);
507
509
514 vtkSetMacro(ArcMajorTickSize, double);
515 vtkGetMacro(ArcMajorTickSize, double);
517
519
524 vtkSetMacro(PolarAxisMajorTickSize, double);
525 vtkGetMacro(PolarAxisMajorTickSize, double);
527
529
534 vtkSetMacro(LastRadialAxisMajorTickSize, double);
535 vtkGetMacro(LastRadialAxisMajorTickSize, double);
537
539
543 vtkSetMacro(PolarAxisTickRatioSize, double);
544 vtkGetMacro(PolarAxisTickRatioSize, double);
546
548
552 vtkSetMacro(LastAxisTickRatioSize, double);
553 vtkGetMacro(LastAxisTickRatioSize, double);
555
557
561 vtkSetMacro(ArcTickRatioSize, double);
562 vtkGetMacro(ArcTickRatioSize, double);
564
566
570 vtkSetMacro(TickRatioRadiusSize, double);
571 vtkGetMacro(TickRatioRadiusSize, double);
573
575
579 vtkSetMacro(PolarAxisMajorTickThickness, double);
580 vtkGetMacro(PolarAxisMajorTickThickness, double);
582
584
588 vtkSetMacro(LastRadialAxisMajorTickThickness, double);
589 vtkGetMacro(LastRadialAxisMajorTickThickness, double);
591
593
597 vtkSetMacro(ArcMajorTickThickness, double);
598 vtkGetMacro(ArcMajorTickThickness, double);
600
602
606 vtkSetMacro(PolarAxisTickRatioThickness, double);
607 vtkGetMacro(PolarAxisTickRatioThickness, double);
609
611
615 vtkSetMacro(LastAxisTickRatioThickness, double);
616 vtkGetMacro(LastAxisTickRatioThickness, double);
618
620
624 vtkSetMacro(ArcTickRatioThickness, double);
625 vtkGetMacro(ArcTickRatioThickness, double);
627
629
633 vtkSetMacro(DeltaRangeMajor, double);
634 vtkGetMacro(DeltaRangeMajor, double);
636
638
642 vtkSetMacro(DeltaRangeMinor, double);
643 vtkGetMacro(DeltaRangeMinor, double);
645
647
652 vtkSetMacro(RequestedDeltaRangePolarAxes, double);
653 vtkGetMacro(RequestedDeltaRangePolarAxes, double);
655
657
661 vtkSetMacro(DeltaAngleMajor, double);
662 vtkGetMacro(DeltaAngleMajor, double);
664
666
670 vtkSetMacro(DeltaAngleMinor, double);
671 vtkGetMacro(DeltaAngleMinor, double);
673
675
680 vtkSetMacro(RequestedDeltaAngleRadialAxes, double);
681 vtkGetMacro(RequestedDeltaAngleRadialAxes, double);
683
684 //------------------------------------------------
685
687
691 vtkSetMacro(RadialAxesVisibility, bool);
692 vtkGetMacro(RadialAxesVisibility, bool);
693 vtkBooleanMacro(RadialAxesVisibility, bool);
695
697
701 vtkSetMacro(RadialTitleVisibility, bool);
702 vtkGetMacro(RadialTitleVisibility, bool);
703 vtkBooleanMacro(RadialTitleVisibility, bool);
705
707
711 vtkSetMacro(PolarArcsVisibility, bool);
712 vtkGetMacro(PolarArcsVisibility, bool);
713 vtkBooleanMacro(PolarArcsVisibility, bool);
715
717
720 void SetUse2DMode(bool enable);
723
725
731
733
739
741
747
749
755
757
763
765
771
773
779
781
787
789
795
797
804 vtkSetVector6Macro(Bounds, double);
805 double* GetBounds() override;
807 double& xmin, double& xmax, double& ymin, double& ymax, double& zmin, double& zmax);
808 void GetBounds(double bounds[6]);
810
812
816 vtkSetClampMacro(Ratio, double, 0.001, 100.0);
817 vtkGetMacro(Ratio, double);
819
821
825 vtkSetClampMacro(PolarArcResolutionPerDegree, double, VTK_MINIMUM_POLAR_ARC_RESOLUTION_PER_DEG,
826 VTK_MAXIMUM_POLAR_ARC_RESOLUTION_PER_DEG);
827 vtkGetMacro(PolarArcResolutionPerDegree, double);
829
830protected:
833
838
844
849
854
859
863 void CreateRadialAxes(int axisCount);
864
870 void BuildRadialAxes(vtkViewport* viewport = nullptr);
871
875 double ComputeIdealStep(int subDivsRequired, double rangeLength, int maxSubDivs = 1000);
876
881
887 double a, double angleEllipseRad, double tickSize, vtkPoints* tickPts);
888
893
898
903
905
909 std::string FindExponentAndAdjustValues(std::list<double>& valuesList);
910
914 void GetSignificantPartFromValues(vtkStringArray* valuesStr, std::list<double>& valuesList);
915
917
920 double FFix(double);
921 double FSign(double, double);
923
928 void AutoScale(vtkViewport* viewport);
929
934 static double ComputeEllipseAngle(double angleInDegrees, double ratio);
935
940
948 double Pole[3] = { 0.0, 0.0, 0.0 };
949
953 int NumberOfRadialAxes = 0;
954
959 int RequestedNumberOfRadialAxes = 0;
960
964 int NumberOfPolarAxes = 5;
965
970 int RequestedNumberOfPolarAxes = 5;
971
975 double Ratio = 1.0;
976
980 double PolarArcResolutionPerDegree = 0.2;
981
985 double Range[2] = { 0.0, 10.0 };
986
990 double DeltaRangeMinor = 0.5;
991
995 double DeltaRangeMajor = 1.0;
996
1000 double DeltaRangePolarAxes = 0.0;
1001
1006 double RequestedDeltaRangePolarAxes = 0.0;
1007
1011 double DeltaAngleMinor = 22.5;
1012
1016 double DeltaAngleMajor = 45.0;
1017
1021 double DeltaAngleRadialAxes = 45.0;
1022
1027 double RequestedDeltaAngleRadialAxes = 45.0;
1028
1032 double MinimumRadius = 0.0;
1033
1037 double MaximumRadius = 1.0;
1038
1042 bool Log = false;
1043
1047 double MinimumAngle = 0.0;
1048
1052 double MaximumAngle = 90.0;
1053
1057 double SmallestVisiblePolarAngle = 0.5;
1058
1059 // Structures for principal polar arc
1063
1065
1072
1077
1082
1086 vtkSmartPointer<vtkAxisActor>* RadialAxes = nullptr;
1087
1089
1093 char* PolarAxisTitle = nullptr;
1094 char* PolarLabelFormat = nullptr;
1096
1100 char* RadialAngleFormat = nullptr;
1101
1105 bool RadialUnits = true;
1106
1110 bool EnableDistanceLOD = true;
1111
1115 double DistanceLODThreshold = 0.7;
1116
1120 bool EnableViewAngleLOD = true;
1121
1126 double ViewAngleLODThreshold = 0.3;
1127
1129
1132 bool PolarAxisVisibility = true;
1133 bool PolarTitleVisibility = true;
1134 bool PolarLabelVisibility = true;
1136
1145
1149 bool PolarTickVisibility = true;
1150
1157 bool ArcTicksOriginToPolarAxis = true;
1158
1165 bool RadialAxesOriginToPolarAxis = true;
1166
1170 bool AxisTickVisibility = true, AxisMinorTickVisibility = false;
1171
1175 bool AxisTickMatchesPolarAxes = true;
1176
1180 bool ArcTickVisibility = true, ArcMinorTickVisibility = false;
1181
1185 bool ArcTickMatchesRadialAxes = true;
1186
1190 double PolarAxisMajorTickSize = 0.0, LastRadialAxisMajorTickSize = 0.0, ArcMajorTickSize = 0.0;
1191
1195 double PolarAxisTickRatioSize = 0.3, LastAxisTickRatioSize = 0.3, ArcTickRatioSize = 0.3;
1196
1200 double TickRatioRadiusSize = 0.02;
1201
1205 double PolarAxisMajorTickThickness = 1.0, LastRadialAxisMajorTickThickness = 1.0,
1206 ArcMajorTickThickness = 1.0;
1207
1211 double PolarAxisTickRatioThickness = 0.5, LastAxisTickRatioThickness = 0.5,
1212 ArcTickRatioThickness = 0.5;
1213
1215
1218 bool RadialAxesVisibility = true;
1219 bool RadialTitleVisibility = true;
1221
1225 int RadialAxisTitleLocation = VTK_TITLE_BOTTOM;
1226
1230 int PolarAxisTitleLocation = VTK_TITLE_BOTTOM;
1231
1236 int ExponentLocation = VTK_EXPONENT_LABELS;
1237
1241 bool PolarArcsVisibility = true;
1242
1246 bool DrawRadialGridlines = true;
1247
1251 bool DrawPolarArcsGridlines = true;
1252
1257
1262
1264
1274
1276
1282
1287
1292
1298
1303
1308
1310
1314 double TitleScale = -1.0;
1315
1319 double LabelScale = -1.0;
1320
1324 double ScreenSize = 10.0;
1325
1327
1330 double PolarTitleOffset[2] = { 20.0, 10.0 }, RadialTitleOffset[2] = { 20.0, 0.0 };
1331 double PolarLabelOffset = 10.0, PolarExponentOffset = 5.0;
1333
1334private:
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;
1339
1340 vtkPolarAxesActor(const vtkPolarAxesActor&) = delete;
1341 void operator=(const vtkPolarAxesActor&) = delete;
1342};
1343
1344VTK_ABI_NAMESPACE_END
1345#endif
represents an object (geometry & properties) in a rendered scene
Definition vtkActor.h:151
Create an axis with tick marks and labels.
a virtual camera for 3D rendering
Definition vtkCamera.h:151
a simple class to control print indentation
Definition vtkIndent.h:108
Allocate and hold a VTK object.
Definition vtkNew.h:167
represent and manipulate 3D points
Definition vtkPoints.h:139
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.
void BuildPolarArcsLog()
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
Definition vtkViewport.h:66
window superclass for vtkRenderWindow
Definition vtkWindow.h:48
int vtkIdType
Definition vtkType.h:332
#define VTK_MARSHALAUTO