/usr/include/vtk-5.10/vtkBorderRepresentation.h is in libvtk5-dev 5.10.1+dfsg-2.1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkBorderRepresentation.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// .NAME vtkBorderRepresentation - represent a vtkBorderWidget
// .SECTION Description
// This class is used to represent and render a vtBorderWidget. To
// use this class, you need to specify the two corners of a rectangular
// region.
//
// The class is typically subclassed so that specialized representations can
// be created. The class defines an API and a default implementation that
// the vtkBorderRepresentation interacts with to render itself in the scene.
// .SECTION Caveats
// The separation of the widget event handling (e.g., vtkBorderWidget) from
// the representation (vtkBorderRepresentation) enables users and developers
// to create new appearances for the widget. It also facilitates parallel
// processing, where the client application handles events, and remote
// representations of the widget are slaves to the client (and do not handle
// events).
// .SECTION See Also
// vtkBorderWidget vtkTextWidget
#ifndef __vtkBorderRepresentation_h
#define __vtkBorderRepresentation_h
#include "vtkWidgetRepresentation.h"
#include "vtkCoordinate.h" //Because of the viewport coordinate macro
class vtkPoints;
class vtkPolyData;
class vtkTransform;
class vtkTransformPolyDataFilter;
class vtkPolyDataMapper2D;
class vtkActor2D;
class vtkProperty2D;
class VTK_WIDGETS_EXPORT vtkBorderRepresentation : public vtkWidgetRepresentation
{
public:
// Description:
// Instantiate this class.
static vtkBorderRepresentation *New();
// Description:
// Define standard methods.
vtkTypeMacro(vtkBorderRepresentation,vtkWidgetRepresentation);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Specify opposite corners of the box defining the boundary of the
// widget. By default, these coordinates are in the normalized viewport
// coordinate system, with Position the lower left of the outline, and
// Position2 relative to Position. Note that using these methods are
// affected by the ProportionalResize flag. That is, if the aspect ratio of
// the representation is to be preserved (e.g., ProportionalResize is on),
// then the rectangle (Position,Position2) is a bounding rectangle.
vtkViewportCoordinateMacro(Position);
vtkViewportCoordinateMacro(Position2);
//BTX
enum {BORDER_OFF=0,BORDER_ON,BORDER_ACTIVE};
//ETX
// Description:
// Specify when and if the border should appear. If ShowBorder is "on",
// then the border will always appear. If ShowBorder is "off" then the
// border will never appear. If ShowBorder is "active" then the border
// will appear when the mouse pointer enters the region bounded by the
// border widget.
vtkSetClampMacro(ShowBorder,int,BORDER_OFF,BORDER_ACTIVE);
vtkGetMacro(ShowBorder,int);
void SetShowBorderToOff() {this->SetShowBorder(BORDER_OFF);}
void SetShowBorderToOn() {this->SetShowBorder(BORDER_ON);}
void SetShowBorderToActive() {this->SetShowBorder(BORDER_ACTIVE);}
// Description:
// Specify the properties of the border.
vtkGetObjectMacro(BorderProperty,vtkProperty2D);
// Description:
// Indicate whether resizing operations should keep the x-y directions
// proportional to one another. Also, if ProportionalResize is on, then
// the rectangle (Position,Position2) is a bounding rectangle, and the
// representation will be placed in the rectangle in such a way as to
// preserve the aspect ratio of the representation.
vtkSetMacro(ProportionalResize,int);
vtkGetMacro(ProportionalResize,int);
vtkBooleanMacro(ProportionalResize,int);
// Description:
// Specify a minimum and/or maximum size (in pixels) that this representation
// can take. These methods require two values: size values in the x and y
// directions, respectively.
vtkSetVector2Macro(MinimumSize,int);
vtkGetVector2Macro(MinimumSize,int);
vtkSetVector2Macro(MaximumSize,int);
vtkGetVector2Macro(MaximumSize,int);
// Description:
// The tolerance representing the distance to the widget (in pixels)
// in which the cursor is considered to be on the widget, or on a
// widget feature (e.g., a corner point or edge).
vtkSetClampMacro(Tolerance,int,1,10);
vtkGetMacro(Tolerance,int);
// Description:
// After a selection event within the region interior to the border; the
// normalized selection coordinates may be obtained.
vtkGetVectorMacro(SelectionPoint,double,2);
// Description:
// This is a modifier of the interaction state. When set, widget interaction
// allows the border (and stuff inside of it) to be translated with mouse
// motion.
vtkSetMacro(Moving,int);
vtkGetMacro(Moving,int);
vtkBooleanMacro(Moving,int);
//BTX
// Description:
// Define the various states that the representation can be in.
enum _InteractionState
{
Outside=0,
Inside,
AdjustingP0,
AdjustingP1,
AdjustingP2,
AdjustingP3,
AdjustingE0,
AdjustingE1,
AdjustingE2,
AdjustingE3
};
//ETX
// Description:
// Subclasses should implement these methods. See the superclasses'
// documentation for more information.
virtual void BuildRepresentation();
virtual void StartWidgetInteraction(double eventPos[2]);
virtual void WidgetInteraction(double eventPos[2]);
virtual void GetSize(double size[2])
{size[0]=1.0; size[1]=1.0;}
virtual int ComputeInteractionState(int X, int Y, int modify=0);
// Description:
// These methods are necessary to make this representation behave as
// a vtkProp.
virtual void GetActors2D(vtkPropCollection*);
virtual void ReleaseGraphicsResources(vtkWindow*);
virtual int RenderOverlay(vtkViewport*);
virtual int RenderOpaqueGeometry(vtkViewport*);
virtual int RenderTranslucentPolygonalGeometry(vtkViewport*);
virtual int HasTranslucentPolygonalGeometry();
protected:
vtkBorderRepresentation();
~vtkBorderRepresentation();
// Ivars
int ShowBorder;
vtkProperty2D *BorderProperty;
int ProportionalResize;
int Tolerance;
int Moving;
double SelectionPoint[2];
// Layout (position of lower left and upper right corners of border)
vtkCoordinate *PositionCoordinate;
vtkCoordinate *Position2Coordinate;
// Sometimes subclasses must negotiate with their superclasses
// to achieve the correct layout.
int Negotiated;
virtual void NegotiateLayout();
// Keep track of start position when moving border
double StartPosition[2];
// Border representation. Subclasses may use the BWTransform class
// to transform their geometry into the region surrounded by the border.
vtkPoints *BWPoints;
vtkPolyData *BWPolyData;
vtkTransform *BWTransform;
vtkTransformPolyDataFilter *BWTransformFilter;
vtkPolyDataMapper2D *BWMapper;
vtkActor2D *BWActor;
// Constraints on size
int MinimumSize[2];
int MaximumSize[2];
private:
vtkBorderRepresentation(const vtkBorderRepresentation&); //Not implemented
void operator=(const vtkBorderRepresentation&); //Not implemented
};
#endif
|