29#ifndef vtkImplicitAnnulusRepresentation_h
30#define vtkImplicitAnnulusRepresentation_h
33#include "vtkInteractionWidgetsModule.h"
37VTK_ABI_NAMESPACE_BEGIN
50#define VTK_MAX_ANNULUS_RESOLUTION 2048
83 void GetCenter(
double xyz[3]) const;
92 void SetAxis(
double x,
double y,
double z);
93 void SetAxis(
double a[3]);
95 void GetAxis(
double a[3]) const;
105 void SetInnerRadius(
double r);
106 double GetInnerRadius() const;
116 void SetOuterRadius(
double r);
117 double GetOuterRadius() const;
129 void SetAlongXAxis(
bool);
130 vtkGetMacro(AlongXAxis,
bool);
131 vtkBooleanMacro(AlongXAxis,
bool);
132 void SetAlongYAxis(
bool);
133 vtkGetMacro(AlongYAxis,
bool);
134 vtkBooleanMacro(AlongYAxis,
bool);
135 void SetAlongZAxis(
bool);
136 vtkGetMacro(AlongZAxis,
bool);
137 vtkBooleanMacro(AlongZAxis,
bool);
147 void SetDrawAnnulus(
bool draw);
148 vtkGetMacro(DrawAnnulus,
bool);
149 vtkBooleanMacro(DrawAnnulus,
bool);
161 vtkGetMacro(Resolution,
int);
171 vtkSetMacro(Tubing,
bool);
172 vtkGetMacro(Tubing,
bool);
173 vtkBooleanMacro(Tubing,
bool);
181 vtkSetMacro(ScaleEnabled,
bool);
182 vtkGetMacro(ScaleEnabled,
bool);
183 vtkBooleanMacro(ScaleEnabled,
bool);
196 void UpdatePlacement();
230 void SetInteractionColor(
double,
double,
double);
269 vtkSetClampMacro(BumpDistance,
double, 0.000001, 1);
270 vtkGetMacro(BumpDistance,
double);
300 InteractionStateType::TranslatingCenter);
323 struct AxisHandleRepresentation
334 struct RadiusHandleRepresentation
345 void HighlightAnnulus(
bool highlight);
346 void HighlightCenterHandle(
bool highlight);
347 void HighlightAxis(
bool highlight);
348 void HighlightInnerRadiusHandle(
bool highlight);
349 void HighlightOuterRadiusHandle(
bool highlight);
359 void AdjustOuterRadius(
double x,
double y,
const vtkVector3d& point);
360 void AdjustInnerRadius(
double x,
double y,
const vtkVector3d& point);
370 InteractionStateType RepresentationState = InteractionStateType::Outside;
376 double BumpDistance = 0.01;
379 bool AlongXAxis =
false;
380 bool AlongYAxis =
false;
381 bool AlongZAxis =
false;
384 int Resolution = 128;
386 bool ScaleEnabled =
true;
391 bool DrawAnnulus =
true;
394 RadiusHandleRepresentation InnerRadiusRepresentation;
395 RadiusHandleRepresentation OuterRadiusRepresentation;
399 AxisHandleRepresentation LowerAxisRepresentation;
400 AxisHandleRepresentation UpperAxisRepresentation;
represents an object (geometry & properties) in a rendered scene
implicit function for a annulus
implicit function for a bounding box
ray-cast cell picker for all kinds of Prop3Ds
defining the representation for a vtkImplicitAnnulusWidget
vtkTypeBool HasTranslucentPolygonalGeometry() override
Methods supporting the rendering process.
void PushAnnulus(double distance)
Push the annulus the distance specified along the view vector.
void PlaceWidget(double bounds[6]) override
Methods to interface with the vtkImplicitAnnulusWidget.
static vtkImplicitAnnulusRepresentation * New()
double * GetBounds() override
Methods supporting the rendering process.
void GetAnnulus(vtkAnnulus *annulus) const
void BuildRepresentation() override
Methods to interface with the vtkImplicitAnnulusWidget.
void PrintSelf(ostream &os, vtkIndent indent) override
Standard methods for instances of this class.
void SetHandleColor(double c[3])
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
void SetInteractionColor(double c[3])
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
void SetForegroundColor(double, double, double)
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
double * GetCenter() const
Get the center of the annulus representation.
vtkImplicitAnnulusRepresentation()
void BumpAnnulus(int dir, double factor)
Translate the annulus in the direction of the view vector by the specified BumpDistance.
void SetForegroundColor(double c[3])
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
void ReleaseGraphicsResources(vtkWindow *) override
Methods supporting the rendering process.
void RegisterPickers() override
Register internal Pickers in the Picking Manager.
int RenderTranslucentPolygonalGeometry(vtkViewport *) override
Methods supporting the rendering process.
int RenderOpaqueGeometry(vtkViewport *) override
Methods supporting the rendering process.
void SetCenter(double x[3])
Get the center of the annulus representation.
virtual void SetRepresentationState(InteractionStateType)
Sets the visual appearance of the representation based on the state it is in.
~vtkImplicitAnnulusRepresentation() override
void SetCenter(double x, double y, double z)
Get the center of the annulus representation.
int ComputeInteractionState(int X, int Y, int modify=0) override
Methods to interface with the vtkImplicitAnnulusWidget.
void EndWidgetInteraction(double newEventPos[2]) override
Methods to interface with the vtkImplicitAnnulusWidget.
void WidgetInteraction(double newEventPos[2]) override
Methods to interface with the vtkImplicitAnnulusWidget.
void SetHandleColor(double, double, double)
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
void GetActors(vtkPropCollection *pc) override
Methods supporting the rendering process.
void StartWidgetInteraction(double eventPos[2]) override
Methods to interface with the vtkImplicitAnnulusWidget.
a simple class to control print indentation
create a line defined by two end points
Allocate and hold a VTK object.
map vtkPolyData to graphics primitives
concrete dataset represents vertices, lines, polygons, and triangle strips
represent surface properties of a geometric object
create a polygonal sphere centered at the origin
filter that generates tubes around lines
abstract specification for Viewports
window superclass for vtkRenderWindow
#define VTK_MAX_ANNULUS_RESOLUTION
#define VTK_SIZEHINT(...)