48#ifndef vtkImplicitAnnulusRepresentation_h
49#define vtkImplicitAnnulusRepresentation_h
52#include "vtkInteractionWidgetsModule.h"
56VTK_ABI_NAMESPACE_BEGIN
69#define VTK_MAX_ANNULUS_RESOLUTION 2048
149 vtkGetMacro(AlongXAxis,
bool);
150 vtkBooleanMacro(AlongXAxis,
bool);
152 vtkGetMacro(AlongYAxis,
bool);
153 vtkBooleanMacro(AlongYAxis,
bool);
155 vtkGetMacro(AlongZAxis,
bool);
156 vtkBooleanMacro(AlongZAxis,
bool);
167 vtkGetMacro(DrawAnnulus,
bool);
168 vtkBooleanMacro(DrawAnnulus,
bool);
180 vtkGetMacro(Resolution,
int);
190 vtkSetMacro(Tubing,
bool);
191 vtkGetMacro(Tubing,
bool);
192 vtkBooleanMacro(Tubing,
bool);
200 vtkSetMacro(ScaleEnabled,
bool);
201 vtkGetMacro(ScaleEnabled,
bool);
202 vtkBooleanMacro(ScaleEnabled,
bool);
288 vtkSetClampMacro(BumpDistance,
double, 0.000001, 1);
289 vtkGetMacro(BumpDistance,
double);
342 struct AxisHandleRepresentation
353 struct RadiusHandleRepresentation
361 vtkImplicitAnnulusRepresentation(
const vtkImplicitAnnulusRepresentation&) =
delete;
362 void operator=(
const vtkImplicitAnnulusRepresentation&) =
delete;
364 void HighlightAnnulus(
bool highlight);
365 void HighlightCenterHandle(
bool highlight);
366 void HighlightAxis(
bool highlight);
367 void HighlightInnerRadiusHandle(
bool highlight);
368 void HighlightOuterRadiusHandle(
bool highlight);
372 double X,
double Y,
const vtkVector3d& p1,
const vtkVector3d& p2,
const vtkVector3d& vpn);
373 void TranslateAnnulus(
const vtkVector3d& p1,
const vtkVector3d& p2);
375 void TranslateCenter(
const vtkVector3d& p1,
const vtkVector3d& p2);
376 void TranslateCenterOnAxis(
const vtkVector3d& p1,
const vtkVector3d& p2);
377 void ScaleRadii(
const vtkVector3d& p1,
const vtkVector3d& p2);
378 void AdjustOuterRadius(
double x,
double y,
const vtkVector3d& point);
379 void AdjustInnerRadius(
double x,
double y,
const vtkVector3d& point);
380 void Scale(
const vtkVector3d& p1,
const vtkVector3d& p2,
double X,
double Y);
387 vtkNew<vtkAnnulus> Annulus;
389 InteractionStateType RepresentationState = InteractionStateType::Outside;
392 vtkVector3d LastEventPosition;
395 double BumpDistance = 0.01;
398 bool AlongXAxis =
false;
399 bool AlongYAxis =
false;
400 bool AlongZAxis =
false;
403 int Resolution = 128;
405 bool ScaleEnabled =
true;
407 vtkNew<vtkPolyData> AnnulusPD;
408 vtkNew<vtkPolyDataMapper> AnnulusMapper;
409 vtkNew<vtkActor> AnnulusActor;
410 bool DrawAnnulus =
true;
413 RadiusHandleRepresentation InnerRadiusRepresentation;
414 RadiusHandleRepresentation OuterRadiusRepresentation;
418 AxisHandleRepresentation LowerAxisRepresentation;
419 AxisHandleRepresentation UpperAxisRepresentation;
422 vtkNew<vtkSphereSource> CenterHandleSource;
423 vtkNew<vtkPolyDataMapper> CenterHandleMapper;
424 vtkNew<vtkActor> CenterHandleActor;
427 vtkNew<vtkCellPicker> Picker;
428 vtkNew<vtkCellPicker> AnnulusPicker;
432 vtkNew<vtkProperty> AxisProperty;
433 vtkNew<vtkProperty> SelectedAxisProperty;
434 vtkNew<vtkProperty> AnnulusProperty;
435 vtkNew<vtkProperty> SelectedAnnulusProperty;
436 vtkNew<vtkProperty> RadiusHandleProperty;
437 vtkNew<vtkProperty> SelectedRadiusHandleProperty;
438 vtkNew<vtkProperty> CenterHandleProperty;
439 vtkNew<vtkProperty> SelectedCenterHandleProperty;
441 vtkNew<vtkBox> BoundingBox;
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
vtkTypeBool HasTranslucentPolygonalGeometry() override
Methods supporting the rendering process.
void SetAlongYAxis(bool)
Force the annulus widget to be aligned with one of the x-y-z axes.
void UpdatePlacement()
Satisfies the superclass API.
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()
void SetDrawAnnulus(bool draw)
Enable/disable the drawing of the annulus.
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 SetAlongZAxis(bool)
Force the annulus widget to be aligned with one of the x-y-z axes.
void SetOuterRadius(double r)
Set/Get the annulus outer radius.
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...
void SetInteractionColor(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.
double GetOuterRadius() const
Set/Get the annulus outer radius.
vtkImplicitAnnulusRepresentation()
void BumpAnnulus(int dir, double factor)
Translate the annulus in the direction of the view vector by the specified BumpDistance.
void GetPolyData(vtkPolyData *pd)
Grab the polydata that defines the annulus.
void SetAxis(double x, double y, double z)
Set/Get the axis of rotation for the annulus.
void SetForegroundColor(double c[3])
Set the color of all the widgets handles (edges, axis, selected annulus) and their color during inter...
double GetInnerRadius() const
Set/Get the annulus inner radius.
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.
void SetAlongXAxis(bool)
Force the annulus widget to be aligned with one of the x-y-z axes.
void SetInnerRadius(double r)
Set/Get the annulus inner radius.
~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.
double * GetAxis() const
Set/Get the axis of rotation for the annulus.
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(...)