An orbital camera, controlled by yaw, pitch, distance, and focal point. More...
#include <orbit_camera.h>
Public Member Functions | |
void | fromString (const std::string &str) override |
Loads the camera's configure from the supplied string (generated through toString()) More... | |
float | getDistance () |
const Ogre::Vector3 & | getFocalPoint () |
Ogre::Quaternion | getOrientation () override |
Get the orientation of this camera. More... | |
float | getPitch () |
Ogre::Vector3 | getPosition () override |
Get the position of this camera. More... | |
float | getYaw () |
void | lookAt (const Ogre::Vector3 &point) override |
Point the camera at the specified point. More... | |
void | mouseLeftDown (int x, int y) override |
void | mouseLeftDrag (int diff_x, int diff_y, bool ctrl, bool alt, bool shift) override |
Handle a left mouse button drag. More... | |
void | mouseLeftUp (int x, int y) override |
void | mouseMiddleDown (int x, int y) override |
void | mouseMiddleDrag (int diff_x, int diff_y, bool ctrl, bool alt, bool shift) override |
Handle a middle mouse button drag. More... | |
void | mouseMiddleUp (int x, int y) override |
void | mouseRightDown (int x, int y) override |
void | mouseRightDrag (int diff_x, int diff_y, bool ctrl, bool alt, bool shift) override |
Handle a right mouse button drag. More... | |
void | mouseRightUp (int x, int y) override |
void | move (float x, float y, float z) override |
Move the camera relative to its orientation. More... | |
OrbitCamera (Ogre::SceneManager *scene_manager) | |
void | pitch (float angle) override |
Pitch the camera. More... | |
void | roll (float angle) override |
Roll the camera. More... | |
void | scrollWheel (int diff, bool ctrl, bool alt, bool shift) override |
Handle a scrollwheel change. More... | |
void | setFocalPoint (const Ogre::Vector3 &focal_point) |
Set the focal point of the camera. Keeps the pitch/yaw/distance the same. More... | |
void | setFrom (CameraBase *camera) override |
Set the position/orientation of this camera from another camera. More... | |
void | setOrientation (float x, float y, float z, float w) override |
Set the orientation of the camera from a quaternion. More... | |
void | setPosition (float x, float y, float z) override |
Set the position of the camera. More... | |
std::string | toString () override |
Returns a string representation of the camera's configuration. More... | |
void | update () override |
Calculates the camera's position and orientation from the yaw, pitch, distance and focal point. More... | |
void | yaw (float angle) override |
Yaw the camera. More... | |
void | zoom (float amount) |
Move in/out from the focal point, ie. adjust distance_ by amount. More... | |
~OrbitCamera () override | |
Public Member Functions inherited from rviz::CameraBase | |
CameraBase (Ogre::SceneManager *scene_manager) | |
Constructor. More... | |
Ogre::Camera * | getOgreCamera () |
Get the Ogre camera associated with this camera object. More... | |
virtual void | relativeNodeChanged () |
Called when the relative node changes. More... | |
virtual void | setOrientation (const Ogre::Quaternion &orientation) |
Set the orientation of the camera. More... | |
virtual void | setPosition (const Ogre::Vector3 &position) |
Set the position of the camera. More... | |
void | setRelativeNode (Ogre::SceneNode *node) |
Set a scene node that all camera transformations should be relative to. More... | |
virtual | ~CameraBase () |
Private Member Functions | |
void | calculatePitchYawFromPosition (const Ogre::Vector3 &position) |
Calculates pitch and yaw values given a new position and the current focal point. More... | |
Ogre::Vector3 | getGlobalFocalPoint () |
void | normalizePitch () |
Normalizes the camera's pitch, preventing it from reaching vertical (or turning upside down) More... | |
void | normalizeYaw () |
Normalizes the camera's yaw in the range [0, 2*pi) More... | |
Private Attributes | |
float | distance_ |
The camera's distance from the focal point. More... | |
Ogre::Vector3 | focal_point_ |
The camera's focal point. More... | |
Shape * | focal_point_object_ |
float | pitch_ |
The camera's pitch (rotation around the x-axis), in radians. More... | |
float | yaw_ |
The camera's yaw (rotation around the y-axis), in radians. More... | |
Additional Inherited Members | |
Protected Attributes inherited from rviz::CameraBase | |
Ogre::Camera * | camera_ |
Ogre camera associated with this camera object. More... | |
Ogre::SceneNode * | relative_node_ |
Ogre::SceneManager * | scene_manager_ |
Scene manager this camera is part of. More... | |
An orbital camera, controlled by yaw, pitch, distance, and focal point.
This camera is based on the equation of a sphere in spherical coordinates:
x = d*cos(theta)sin(phi) y = d*cos(phi) z = d*sin(theta)sin(phi)
Where:
d = distance_
theta = yaw_
phi = pitch_
Definition at line 61 of file orbit_camera.h.
rviz::OrbitCamera::OrbitCamera | ( | Ogre::SceneManager * | scene_manager | ) |
Definition at line 52 of file orbit_camera.cpp.
|
override |
Definition at line 67 of file orbit_camera.cpp.
|
private |
Calculates pitch and yaw values given a new position and the current focal point.
position | Position to calculate the pitch/yaw for |
Definition at line 162 of file orbit_camera.cpp.
|
overridevirtual |
Loads the camera's configure from the supplied string (generated through toString())
str | The string to load from |
Implements rviz::CameraBase.
Definition at line 343 of file orbit_camera.cpp.
|
inline |
Definition at line 87 of file orbit_camera.h.
|
inline |
Definition at line 91 of file orbit_camera.h.
|
private |
Definition at line 94 of file orbit_camera.cpp.
|
overridevirtual |
Get the orientation of this camera.
Implements rviz::CameraBase.
Definition at line 157 of file orbit_camera.cpp.
|
inline |
Definition at line 79 of file orbit_camera.h.
|
overridevirtual |
Get the position of this camera.
Implements rviz::CameraBase.
Definition at line 152 of file orbit_camera.cpp.
|
inline |
Definition at line 83 of file orbit_camera.h.
|
overridevirtual |
Point the camera at the specified point.
point | The point to look at |
Implements rviz::CameraBase.
Definition at line 251 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 313 of file orbit_camera.cpp.
|
overridevirtual |
Handle a left mouse button drag.
diff_x | Pixels the mouse has moved in the (window space) x direction |
diff_y | Pixels the mouse has moved in the (window space) y direction |
Implements rviz::CameraBase.
Definition at line 271 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 328 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 318 of file orbit_camera.cpp.
|
overridevirtual |
Handle a middle mouse button drag.
diff_x | Pixels the mouse has moved in the (window space) x direction |
diff_y | Pixels the mouse has moved in the (window space) y direction |
Implements rviz::CameraBase.
Definition at line 277 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 333 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 323 of file orbit_camera.cpp.
|
overridevirtual |
Handle a right mouse button drag.
diff_x | Pixels the mouse has moved in the (window space) x direction |
diff_y | Pixels the mouse has moved in the (window space) y direction |
Implements rviz::CameraBase.
Definition at line 289 of file orbit_camera.cpp.
|
overridevirtual |
Reimplemented from rviz::CameraBase.
Definition at line 338 of file orbit_camera.cpp.
|
overridevirtual |
Move the camera relative to its orientation.
x | Distance to move along the X-axis |
y | Distance to move along the Y-axis |
z | Distance to move along the Z-axis |
Implements rviz::CameraBase.
Definition at line 227 of file orbit_camera.cpp.
|
private |
Normalizes the camera's pitch, preventing it from reaching vertical (or turning upside down)
Definition at line 72 of file orbit_camera.cpp.
|
private |
Normalizes the camera's yaw in the range [0, 2*pi)
Definition at line 84 of file orbit_camera.cpp.
|
overridevirtual |
Pitch the camera.
Calls to pitch are cumulative, so: pitch(PI); pitch(PI);
is equivalent to pitch(2*PI);
angle | Angle to pitch, in radians |
Implements rviz::CameraBase.
Definition at line 139 of file orbit_camera.cpp.
|
overridevirtual |
Roll the camera.
Calls to roll are cumulative, so: roll(PI); roll(PI);
is equivalent to roll(2*PI);
angle | Angle to roll, in radians |
Implements rviz::CameraBase.
Definition at line 148 of file orbit_camera.cpp.
|
overridevirtual |
Handle a scrollwheel change.
diff | Number of "units" the scrollwheel has moved |
Implements rviz::CameraBase.
Definition at line 301 of file orbit_camera.cpp.
void rviz::OrbitCamera::setFocalPoint | ( | const Ogre::Vector3 & | focal_point | ) |
Set the focal point of the camera. Keeps the pitch/yaw/distance the same.
focal_point | The new focal point |
Definition at line 220 of file orbit_camera.cpp.
|
overridevirtual |
Set the position/orientation of this camera from another camera.
camera | The camera to set from |
Implements rviz::CameraBase.
Definition at line 182 of file orbit_camera.cpp.
|
overridevirtual |
Set the orientation of the camera from a quaternion.
Implements rviz::CameraBase.
Definition at line 195 of file orbit_camera.cpp.
|
overridevirtual |
Set the position of the camera.
Implements rviz::CameraBase.
Definition at line 241 of file orbit_camera.cpp.
|
overridevirtual |
Returns a string representation of the camera's configuration.
Implements rviz::CameraBase.
Definition at line 362 of file orbit_camera.cpp.
|
overridevirtual |
Calculates the camera's position and orientation from the yaw, pitch, distance and focal point.
Implements rviz::CameraBase.
Definition at line 106 of file orbit_camera.cpp.
|
overridevirtual |
Yaw the camera.
Calls to yaw are cumulative, so: yaw(PI); yaw(PI);
is equivalent to yaw(2*PI);
angle | Angle to yaw, in radians |
Implements rviz::CameraBase.
Definition at line 130 of file orbit_camera.cpp.
void rviz::OrbitCamera::zoom | ( | float | amount | ) |
Move in/out from the focal point, ie. adjust distance_ by amount.
amount | The distance to move. Positive amount moves towards the focal point, negative moves away |
Definition at line 208 of file orbit_camera.cpp.
|
private |
The camera's distance from the focal point.
Definition at line 150 of file orbit_camera.h.
|
private |
The camera's focal point.
Definition at line 147 of file orbit_camera.h.
|
private |
Definition at line 152 of file orbit_camera.h.
|
private |
The camera's pitch (rotation around the x-axis), in radians.
Definition at line 149 of file orbit_camera.h.
|
private |
The camera's yaw (rotation around the y-axis), in radians.
Definition at line 148 of file orbit_camera.h.