00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00029 #ifndef __vtkSphereHandleRepresentation_h
00030 #define __vtkSphereHandleRepresentation_h
00031
00032 #include "vtkHandleRepresentation.h"
00033 #include "vtkSphereSource.h"
00034
00035 class vtkSphereSource;
00036 class vtkProperty;
00037 class vtkActor;
00038 class vtkPolyDataMapper;
00039 class vtkCellPicker;
00040
00041 class VTK_WIDGETS_EXPORT vtkSphereHandleRepresentation
00042 : public vtkHandleRepresentation
00043 {
00044 public:
00046 static vtkSphereHandleRepresentation *New();
00047
00049
00050 vtkTypeMacro(vtkSphereHandleRepresentation,vtkHandleRepresentation);
00051 void PrintSelf(ostream& os, vtkIndent indent);
00053
00055
00060 virtual void SetWorldPosition(double p[3]);
00061 virtual void SetDisplayPosition(double p[3]);
00063
00065
00071 vtkSetMacro(TranslationMode,int);
00072 vtkGetMacro(TranslationMode,int);
00073 vtkBooleanMacro(TranslationMode,int);
00075
00076 void SetSphereRadius(double);
00077 double GetSphereRadius();
00078
00080
00081 void SetProperty(vtkProperty*);
00082 void SetSelectedProperty(vtkProperty*);
00083 vtkGetObjectMacro(Property,vtkProperty);
00084 vtkGetObjectMacro(SelectedProperty,vtkProperty);
00086
00088
00092 vtkSetClampMacro(HotSpotSize,double,0.0,1.0);
00093 vtkGetMacro(HotSpotSize,double);
00095
00098 virtual void SetHandleSize(double size);
00099
00101
00103 virtual double *GetBounds();
00104 virtual void BuildRepresentation();
00105 virtual void StartWidgetInteraction(double eventPos[2]);
00106 virtual void WidgetInteraction(double eventPos[2]);
00107 virtual int ComputeInteractionState(int X, int Y, int modify=0);
00108 virtual void PlaceWidget(double bounds[6]);
00110
00112
00113 virtual void ShallowCopy(vtkProp *prop);
00114 virtual void DeepCopy(vtkProp *prop);
00115 virtual void GetActors(vtkPropCollection *);
00116 virtual void ReleaseGraphicsResources(vtkWindow *);
00117 virtual int RenderOpaqueGeometry(vtkViewport *viewport);
00118 virtual int RenderTranslucentPolygonalGeometry(vtkViewport *viewport);
00119 virtual int HasTranslucentPolygonalGeometry();
00121
00122 protected:
00123 vtkSphereHandleRepresentation();
00124 ~vtkSphereHandleRepresentation();
00125
00126
00127 vtkActor *Actor;
00128 vtkPolyDataMapper *Mapper;
00129 vtkSphereSource *Sphere;
00130 void Highlight(int highlight);
00131
00132
00133 vtkCellPicker *CursorPicker;
00134 double LastPickPosition[3];
00135 double LastEventPosition[2];
00136
00137
00138 int ConstraintAxis;
00139 void Translate(double *p1, double *p2);
00140 void Scale(double *p1, double *p2, double eventPos[2]);
00141 void MoveFocus(double *p1, double *p2);
00142 void SizeBounds();
00143
00144
00145
00146 vtkProperty *Property;
00147 vtkProperty *SelectedProperty;
00148 void CreateDefaultProperties();
00149
00150
00151 double HotSpotSize;
00152 int DetermineConstraintAxis(int constraint, double *x);
00153 int WaitingForMotion;
00154 int WaitCount;
00155
00156
00157 double CurrentHandleSize;
00158
00159
00160 int TranslationMode;
00161
00162 private:
00163 vtkSphereHandleRepresentation(const vtkSphereHandleRepresentation&);
00164 void operator=(const vtkSphereHandleRepresentation&);
00165 };
00166
00167 #endif