101 #ifndef vtkBorderRepresentation_h
102 #define vtkBorderRepresentation_h
106 #include "vtkInteractionWidgetsModule.h"
147 vtkViewportCoordinateMacro(Position2);
184 vtkSetClampMacro(ShowVerticalBorder,
int, BORDER_OFF, BORDER_ACTIVE);
185 vtkGetMacro(ShowVerticalBorder,
int);
194 vtkSetClampMacro(ShowHorizontalBorder,
int, BORDER_OFF, BORDER_ACTIVE);
195 vtkGetMacro(ShowHorizontalBorder,
int);
224 vtkSetClampMacro(ShowPolygonBackground,
int, BORDER_OFF, BORDER_ACTIVE);
225 vtkGetMacro(ShowPolygonBackground,
int);
267 vtkSetVector2Macro(MinimumNormalizedViewportSize,
double);
268 vtkGetVector2Macro(MinimumNormalizedViewportSize,
double);
279 vtkSetVector2Macro(MinimumSize,
int);
280 vtkGetVector2Macro(MinimumSize,
int);
281 vtkSetVector2Macro(MaximumSize,
int);
282 vtkGetVector2Macro(MaximumSize,
int);
293 vtkSetClampMacro(Tolerance,
int, 1, 10);
294 vtkGetMacro(Tolerance,
int);
302 vtkGetVectorMacro(SelectionPoint,
double, 2);
340 vtkGetMacro(WindowLocation,
int);
359 #if !defined(VTK_LEGACY_REMOVE)
364 vtkSetClampMacro(InteractionState,
int, 0, AdjustingE3);
402 "SetBWActorDisplayOverlay is deprecated. Use "
403 "SetBWActorDisplayOverlayEdges or SetBWActorDisplayOverlayPolygon instead.")
404 void SetBWActorDisplayOverlay(
bool);
406 void SetBWActorDisplayOverlayEdges(
bool);
407 void SetBWActorDisplayOverlayPolygon(
bool);
414 vtkSetVector3Macro(BorderColor,
double);
415 vtkGetVector3Macro(BorderColor,
double);
424 vtkGetMacro(BorderThickness,
float);
436 vtkSetClampMacro(CornerRadiusStrength,
double, 0.0, 1.0);
437 vtkGetMacro(CornerRadiusStrength,
double);
446 vtkSetClampMacro(CornerResolution,
int, 0, 1000);
447 vtkGetMacro(CornerResolution,
int);
455 vtkSetVector3Macro(PolygonColor,
double);
456 vtkGetVector3Macro(PolygonColor,
double);
464 vtkSetClampMacro(PolygonOpacity,
double, 0.0, 1.0);
465 vtkGetMacro(PolygonOpacity,
double);
472 void SetPolygonRGBA(
double rgba[4]);
473 void SetPolygonRGBA(
double r,
double g,
double b,
double a);
478 void GetPolygonRGBA(
double rgba[4]);
479 void GetPolygonRGBA(
double& r,
double& g,
double& b,
double& a);
487 int ShowVerticalBorder = BORDER_ON;
488 int ShowHorizontalBorder = BORDER_ON;
489 int ShowPolygonBackground = BORDER_ON;
496 double SelectionPoint[2] = { 0.0, 0.0 };
503 int WindowLocation = AnyLocation;
517 double StartPosition[2];
533 double MinimumNormalizedViewportSize[2] = { 0.0, 0.0 };
534 int MinimumSize[2] = { 1, 1 };
538 double BorderColor[3] = { 1.0, 1.0, 1.0 };
539 float BorderThickness = 1.0;
540 double CornerRadiusStrength = 0.0;
541 int CornerResolution = 20;
544 double PolygonColor[3] = { 1.0, 1.0, 1.0 };
545 double PolygonOpacity = 0.0;
a actor that draws 2D data
represent a vtkBorderWidget
virtual void GetSize(double size[2])
Subclasses should implement these methods.
static vtkBorderRepresentation * New()
Instantiate this class.
int RenderTranslucentPolygonalGeometry(vtkViewport *) override
These methods are necessary to make this representation behave as a vtkProp.
virtual int GetShowBorderMinValue()
Specify when and if the border should appear.
vtkNew< vtkPolyDataMapper2D > BWMapperEdges
void SetShowPolygonToOn()
Specify when and if the border's polygon background should appear.
vtkNew< vtkActor2D > BWActorPolygon
void SetShowBorderToActive()
Specify when and if the border should appear.
void WidgetInteraction(double eventPos[2]) override
Subclasses should implement these methods.
void GetActors2D(vtkPropCollection *) override
These methods are necessary to make this representation behave as a vtkProp.
void SetShowPolygonToOff()
Specify when and if the border's polygon background should appear.
virtual void SetWindowLocation(int enumLocation)
Set the representation position, by enumeration ( AnyLocation = 0, LowerLeftCorner,...
vtkNew< vtkCoordinate > PositionCoordinate
void ComputeRoundCorners()
Create all 4 round corners with the specified radius and resolution.
vtkNew< vtkCoordinate > Position2Coordinate
virtual void NegotiateLayout()
vtkTypeBool HasTranslucentPolygonalGeometry() override
These methods are necessary to make this representation behave as a vtkProp.
int ComputeInteractionState(int X, int Y, int modify=0) override
Subclasses should implement these methods.
void SetShowBorderToOn()
Specify when and if the border should appear.
InteractionStateType
Define the various states that the representation can be in.
virtual void SetShowBorder(int border)
Specify when and if the border should appear.
void StartWidgetInteraction(double eventPos[2]) override
Subclasses should implement these methods.
vtkNew< vtkTransform > BWTransform
int RenderOpaqueGeometry(vtkViewport *) override
These methods are necessary to make this representation behave as a vtkProp.
virtual int GetShowPolygon()
Specify when and if the border's polygon background should appear.
virtual int GetShowBorderMaxValue()
Specify when and if the border should appear.
void PrintSelf(ostream &os, vtkIndent indent) override
Define standard methods.
vtkNew< vtkPoints > BWPoints
virtual void UpdateWindowLocation()
void SetShowPolygonToActive()
Specify when and if the border's polygon background should appear.
vtkNew< vtkPolyDataMapper2D > BWMapperPolygon
int RenderOverlay(vtkViewport *) override
These methods are necessary to make this representation behave as a vtkProp.
void BuildRepresentation() override
Subclasses should implement these methods.
virtual void SetShowPolygon(int border)
Specify when and if the border's polygon background should appear.
void ComputeOneRoundCorner(vtkCellArray *polys, vtkPoints *points, const double radius, vtkIdType xPt, vtkIdType yPt, const double startAngle)
Create a quarter circle centered in point[idCenterX].x, point[idCenterY].y), of radius 'radius' with ...
virtual int GetShowBorder()
Specify when and if the border should appear.
vtkNew< vtkPolyData > PolyDataEdges
vtkNew< vtkActor2D > BWActorEdges
vtkNew< vtkTransformPolyDataFilter > BWTransformFilter
vtkNew< vtkPolyData > BWPolyData
void SetShowBorderToOff()
Specify when and if the border should appear.
vtkNew< vtkPolyData > PolyDataPolygon
void ReleaseGraphicsResources(vtkWindow *) override
These methods are necessary to make this representation behave as a vtkProp.
vtkMTimeType GetMTime() override
Return the MTime of this object.
virtual void UpdateShowBorder()
object to represent cell connectivity
a simple class to control print indentation
Allocate and hold a VTK object.
represent and manipulate 3D points
draw vtkPolyData onto the image plane
concrete dataset represents vertices, lines, polygons, and triangle strips
represent surface properties of a 2D image
abstract specification for Viewports
window superclass for vtkRenderWindow
struct Position_t Position
#define VTK_DEPRECATED_IN_9_2_0(reason)
vtkTypeUInt32 vtkMTimeType