39#ifndef vtkImplicitCylinderRepresentation_h
40#define vtkImplicitCylinderRepresentation_h
42#include "vtkInteractionWidgetsModule.h"
63#define VTK_MAX_CYL_RESOLUTION 2048
90 void GetCenter(
double xyz[3]);
98 void SetAxis(
double x,
double y,
double z);
99 void SetAxis(
double a[3]);
101 void GetAxis(
double a[3]);
109 void SetRadius(
double r);
121 vtkSetClampMacro(MinRadius,
double, 0.001, 0.25);
122 vtkGetMacro(MinRadius,
double);
124 vtkGetMacro(MaxRadius,
double);
166 vtkGetMacro(Resolution,
int);
207 vtkSetVector6Macro(WidgetBounds,
double);
208 vtkGetVector6Macro(WidgetBounds,
double);
252 void UpdatePlacement(
void);
291 void SetEdgeColor(
double,
double,
double);
292 void SetEdgeColor(
double c[3]);
299 int ComputeInteractionState(
int X,
int Y,
int modify = 0) override;
300 void PlaceWidget(
double bounds[6]) override;
301 void BuildRepresentation() override;
302 void StartWidgetInteraction(
double eventPos[2]) override;
303 void WidgetInteraction(
double newEventPos[2]) override;
304 void EndWidgetInteraction(
double newEventPos[2]) override;
325 vtkSetClampMacro(BumpDistance,
double, 0.000001, 1);
326 vtkGetMacro(BumpDistance,
double);
336 void BumpCylinder(
int dir,
double factor);
344 void PushCylinder(
double distance);
369 vtkSetClampMacro(InteractionState,
int, Outside, TranslatingCenter);
378 vtkGetMacro(RepresentationState,
int);
391 vtkGetMacro(TranslationAxis,
int);
392 vtkSetClampMacro(TranslationAxis,
int, -1, 2);
421 double LastEventPosition[3];
450 double WidgetBounds[6];
501 void Rotate(
double X,
double Y,
double* p1,
double* p2,
double* vpn);
508 void Scale(
double* p1,
double* p2,
double X,
double Y);
represents an object (geometry & properties) in a rendered scene
implicit function for a bounding box
ray-cast cell picker for all kinds of Prop3Ds
implicit function for a cylinder
extract interior, boundary, non-manifold, and/or sharp edges from polygonal data
topologically and geometrically regular array of data
defining the representation for a vtkImplicitCylinderWidget
void HighlightOutline(int highlight)
vtkLineSource * LineSource
vtkProperty * SelectedOutlineProperty
void HighlightCylinder(int highlight)
void HighlightNormal(int highlight)
void TranslateCylinder(double *p1, double *p2)
vtkProperty * AxisProperty
void TranslateCenterOnAxis(double *p1, double *p2)
void ScaleRadius(double *p1, double *p2)
vtkProperty * EdgesProperty
void RegisterPickers() override
Register internal Pickers in the Picking Manager.
void AdjustRadius(double X, double Y, double *p1, double *p2)
vtkPolyDataMapper * OutlineMapper
void CreateDefaultProperties()
void TranslateOutline(double *p1, double *p2)
void SetXTranslationAxisOn()
Toggles constraint translation axis on/off.
vtkProperty * SelectedAxisProperty
void SetCenter(double x, double y, double z)
Get the center of the cylinder.
void SetZTranslationAxisOn()
Toggles constraint translation axis on/off.
vtkTubeFilter * EdgesTuber
vtkPolyDataMapper * SphereMapper
vtkPolyDataMapper * ConeMapper
vtkPolyDataMapper * LineMapper2
vtkProperty * CylinderProperty
double * GetCenter()
Get the center of the cylinder.
bool IsTranslationConstrained()
Returns true if ContrainedAxis.
vtkTypeBool OutsideBounds
static vtkImplicitCylinderRepresentation * New()
Instantiate the class.
vtkPolyDataMapper * EdgesMapper
void Rotate(double X, double Y, double *p1, double *p2, double *vpn)
int ConstrainToWidgetBounds
vtkOutlineFilter * Outline
vtkPolyDataMapper * ConeMapper2
vtkProperty * OutlineProperty
vtkTypeBool OutlineTranslation
virtual void SetRepresentationState(int)
Sets the visual appearance of the representation based on the state it is in.
void SetTranslationAxisOff()
Toggles constraint translation axis on/off.
vtkProperty * SelectedCylinderProperty
vtkPolyDataMapper * CylMapper
vtkConeSource * ConeSource2
vtkConeSource * ConeSource
void Scale(double *p1, double *p2, double X, double Y)
void SetYTranslationAxisOn()
Toggles constraint translation axis on/off.
void TranslateCenter(double *p1, double *p2)
~vtkImplicitCylinderRepresentation() override
void PrintSelf(ostream &os, vtkIndent indent) override
Standard methods for the class.
void SetCenter(double x[3])
Get the center of the cylinder.
vtkLineSource * LineSource2
vtkImplicitCylinderRepresentation()
vtkPolyDataMapper * LineMapper
vtkCellPicker * CylPicker
a simple class to control print indentation
create a line defined by two end points
map scalar values into colors via a lookup table
create wireframe outline for an arbitrary data set or composite dataset
Superclass for algorithms that produce only polydata as output.
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
void GetBounds(T a, double bds[6])
#define VTK_MAX_CYL_RESOLUTION
#define VTK_SIZEHINT(...)