HOpCameraOrbit
Fields
float |
|
float |
|
float |
Functions
char const * |
|
int |
|
int |
|
int |
|
void |
|
bool |
|
void |
|
bool |
|
bool |
Detailed Description
-
class HOpCameraOrbit : public HBaseOperator
The HOpCameraOrbit class provides interactive orbiting of the camera around a scene.
HOpCameraOrbit implements three mouse event methods defined on the base class and maps the event information to the HOOPS routine #HC_Orbit_Camera. This operation consists of the following steps:
Left Button Down: The orbit is initiated.
Left Button Down and Drag: The camera orbits.
Left Button Up: The operation ends.
Subclassed by HOpCameraRelativeOrbit
Public Functions
-
HOpCameraOrbit(HBaseView *view, int DoRepeat = 0, int DoCapture = 1)
Constructs an HOpCameraOrbit object.
- Parameters:
view – A pointer to an HBaseView object.
DoRepeat – An integer denoting whether this is a repeatable operator. This parameter has been deprecated.
DoCapture – An integer denoting whether the mouse state should be captured, which means that all mouse events should be received after a mousedown, even if it leaves the window. This parameter has been deprecated.
-
virtual ~HOpCameraOrbit()
-
virtual char const *GetName()
- Returns:
A pointer to a character string denoting the name of the operator which is ‘HOpCameraOrbit’.
-
virtual int OnLButtonDown(HEventInfo &hevent)
OnLButtonDown draws a bounding box around the scene, records the mouse position, and maps the mouse position to spherical coordinates.
- Parameters:
hevent – An HEventInfo object containing information about the current event.
- Returns:
An HOperatorReturn indicating the status of the event.
-
virtual int OnLButtonDownAndMove(HEventInfo &hevent)
OnLButtonDownAndMove records points as the mouse is moved, maps the points to spherical coordinates, and calculates the appropriate values for #HC_Orbit_Camera and #HC_Roll_Camera. It also updates the position of the default light depending on if you have set the light to follow the camera.
- Parameters:
hevent – An HEventInfo object containing information about the current event.
- Returns:
An HOperatorReturn indicating the status of the event.
-
virtual int OnLButtonUp(HEventInfo &hevent)
OnLButtonUp updates the scene with the most recent camera and lighting information and cleans up.
- Parameters:
hevent – An HEventInfo object containing information about the current event.
- Returns:
An HOperatorReturn indicating the status of the event.
-
inline void SetLightFollowsCamera(bool follow)
SetLightFollowsCamera sets the lights to follow the camera or to stay in one place during orbit. This has the effect of either lighting the scene during orbit or allowing the camera to move through shadow. The default is off.
- Parameters:
follow – Pass true to have the light follow the camera.
-
inline bool GetLightFollowsCamera()
- Returns:
True if the light follows the camera or false if it doesn’t.
-
inline void SetSceneBoundingBoxVis(bool vis)
SetSceneBoundingBoxVis controls whether a bounding box denoting the scene extents should be drawn during a camera orbit.
- Parameters:
vis – Pass true if you want HOOPS to draw the bounding box or false if you don’t.
-
inline bool GetSceneBoundingBoxVis()
- Returns:
True if the bounding box is visible or false if it isn’t.
-
virtual HBaseOperator *Clone()
Creates a new operator which is a copy of the current operator. The user is responsible for deleting the newly created operator.
- Returns:
A pointer to the newly created HOpCameraOrbit object.
-
inline bool GetSingleClick()
- Returns:
True if the mouse has moved between the left mouse button down and left mouse button up events.