2013-04-29 12:50:40 +00:00
|
|
|
#ifndef GAME_MWRENDER_CAMERA_H
|
|
|
|
#define GAME_MWRENDER_CAMERA_H
|
2011-01-08 14:11:37 +00:00
|
|
|
|
2012-07-03 13:32:38 +00:00
|
|
|
#include <string>
|
2011-02-10 11:56:19 +00:00
|
|
|
|
2013-04-29 06:44:44 +00:00
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
|
2011-01-08 14:11:37 +00:00
|
|
|
namespace Ogre
|
2012-08-12 14:35:35 +00:00
|
|
|
{
|
2012-08-08 20:15:52 +00:00
|
|
|
class Vector3;
|
2011-01-08 14:11:37 +00:00
|
|
|
class Camera;
|
2012-07-03 13:32:38 +00:00
|
|
|
class SceneNode;
|
2011-01-08 14:11:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWRender
|
|
|
|
{
|
2012-08-14 16:33:29 +00:00
|
|
|
class NpcAnimation;
|
2013-04-29 06:44:44 +00:00
|
|
|
|
2013-04-29 12:50:40 +00:00
|
|
|
/// \brief Camera control
|
|
|
|
class Camera
|
2011-01-08 14:11:37 +00:00
|
|
|
{
|
2012-08-13 22:36:18 +00:00
|
|
|
struct CamData {
|
|
|
|
float pitch, yaw, offset;
|
|
|
|
};
|
|
|
|
|
2013-04-29 06:44:44 +00:00
|
|
|
MWWorld::Ptr mTrackingPtr;
|
2012-08-12 11:50:37 +00:00
|
|
|
|
2013-04-29 06:44:44 +00:00
|
|
|
Ogre::Camera *mCamera;
|
2012-08-12 11:50:37 +00:00
|
|
|
Ogre::SceneNode *mCameraNode;
|
2014-10-01 16:55:35 +00:00
|
|
|
Ogre::SceneNode *mCameraPosNode;
|
2011-01-08 14:11:37 +00:00
|
|
|
|
2012-08-14 16:33:29 +00:00
|
|
|
NpcAnimation *mAnimation;
|
|
|
|
|
2012-08-08 20:15:52 +00:00
|
|
|
bool mFirstPersonView;
|
2012-08-12 11:50:37 +00:00
|
|
|
bool mPreviewMode;
|
2012-08-17 09:23:02 +00:00
|
|
|
bool mFreeLook;
|
2013-07-29 14:43:16 +00:00
|
|
|
float mNearest;
|
|
|
|
float mFurthest;
|
|
|
|
bool mIsNearest;
|
2012-08-12 11:50:37 +00:00
|
|
|
|
2012-08-14 10:37:48 +00:00
|
|
|
struct {
|
2013-04-27 08:24:36 +00:00
|
|
|
bool enabled, allowed;
|
2012-08-14 10:37:48 +00:00
|
|
|
} mVanity;
|
|
|
|
|
|
|
|
float mHeight, mCameraDistance;
|
2012-08-13 22:36:18 +00:00
|
|
|
CamData mMainCam, mPreviewCam;
|
2012-08-12 14:35:35 +00:00
|
|
|
|
2012-08-16 09:15:38 +00:00
|
|
|
bool mDistanceAdjusted;
|
|
|
|
|
2013-12-26 23:36:06 +00:00
|
|
|
bool mVanityToggleQueued;
|
|
|
|
bool mViewModeToggleQueued;
|
|
|
|
|
2012-08-11 08:13:16 +00:00
|
|
|
/// Updates sound manager listener data
|
2012-08-09 13:01:03 +00:00
|
|
|
void updateListener();
|
2012-08-09 06:24:18 +00:00
|
|
|
|
2014-10-01 16:55:35 +00:00
|
|
|
void setPosition(const Ogre::Vector3& position);
|
|
|
|
void setPosition(float x, float y, float z);
|
|
|
|
|
2012-08-08 20:15:52 +00:00
|
|
|
public:
|
2013-04-29 12:50:40 +00:00
|
|
|
Camera(Ogre::Camera *camera);
|
|
|
|
~Camera();
|
2012-08-08 20:15:52 +00:00
|
|
|
|
2013-05-17 20:53:43 +00:00
|
|
|
/// Reset to defaults
|
|
|
|
void reset();
|
|
|
|
|
2013-04-29 12:50:40 +00:00
|
|
|
/// Set where the camera is looking at. Uses Morrowind (euler) angles
|
2012-08-11 09:23:54 +00:00
|
|
|
/// \param rot Rotation angles in radians
|
2012-11-05 19:48:07 +00:00
|
|
|
void rotateCamera(const Ogre::Vector3 &rot, bool adjust);
|
|
|
|
|
|
|
|
float getYaw();
|
|
|
|
void setYaw(float angle);
|
2011-01-08 14:11:37 +00:00
|
|
|
|
2012-11-05 19:48:07 +00:00
|
|
|
float getPitch();
|
|
|
|
void setPitch(float angle);
|
|
|
|
|
2013-04-28 08:14:58 +00:00
|
|
|
const std::string &getHandle() const;
|
2011-01-08 14:11:37 +00:00
|
|
|
|
2012-08-11 08:13:16 +00:00
|
|
|
/// Attach camera to object
|
2014-10-01 16:55:35 +00:00
|
|
|
Ogre::SceneNode* attachTo(const MWWorld::Ptr &);
|
2011-02-10 11:56:19 +00:00
|
|
|
|
2014-06-05 15:21:02 +00:00
|
|
|
/// @param Force view mode switch, even if currently not allowed by the animation.
|
|
|
|
void toggleViewMode(bool force=false);
|
2012-08-12 11:50:37 +00:00
|
|
|
|
2013-04-27 08:24:36 +00:00
|
|
|
bool toggleVanityMode(bool enable);
|
2012-08-14 10:37:48 +00:00
|
|
|
void allowVanityMode(bool allow);
|
2012-08-12 11:50:37 +00:00
|
|
|
|
2013-12-26 23:36:06 +00:00
|
|
|
/// @note this may be ignored if an important animation is currently playing
|
2012-08-13 22:36:18 +00:00
|
|
|
void togglePreviewMode(bool enable);
|
2012-05-30 13:52:39 +00:00
|
|
|
|
2013-10-02 09:16:52 +00:00
|
|
|
/// \brief Lowers the camera for sneak.
|
|
|
|
/// As animation is tied to the camera, this needs
|
|
|
|
/// to be set each frame after the animation is
|
|
|
|
/// applied.
|
2014-01-10 21:39:01 +00:00
|
|
|
void setSneakOffset(float offset);
|
2013-10-02 09:16:52 +00:00
|
|
|
|
2013-04-29 11:40:28 +00:00
|
|
|
bool isFirstPerson() const
|
|
|
|
{ return !(mVanity.enabled || mPreviewMode || !mFirstPersonView); }
|
|
|
|
|
2013-07-13 23:12:38 +00:00
|
|
|
void processViewChange();
|
|
|
|
|
2013-07-30 21:24:18 +00:00
|
|
|
void update(float duration, bool paused=false);
|
2012-08-14 10:37:48 +00:00
|
|
|
|
2012-08-16 09:15:38 +00:00
|
|
|
/// Set camera distance for current mode. Don't work on 1st person view.
|
|
|
|
/// \param adjust Indicates should distance be adjusted or set.
|
|
|
|
/// \param override If true new distance will be used as default.
|
|
|
|
/// If false, default distance can be restored with setCameraDistance().
|
|
|
|
void setCameraDistance(float dist, bool adjust = false, bool override = true);
|
|
|
|
|
|
|
|
/// Restore default camera distance for current mode.
|
|
|
|
void setCameraDistance();
|
2012-08-14 16:33:29 +00:00
|
|
|
|
2014-01-01 22:59:17 +00:00
|
|
|
float getCameraDistance() const;
|
|
|
|
|
2013-01-17 23:48:09 +00:00
|
|
|
void setAnimation(NpcAnimation *anim);
|
2012-08-14 16:33:29 +00:00
|
|
|
|
2013-07-23 08:37:41 +00:00
|
|
|
/// Stores focal and camera world positions in passed arguments
|
|
|
|
void getPosition(Ogre::Vector3 &focal, Ogre::Vector3 &camera);
|
2012-08-17 09:23:02 +00:00
|
|
|
|
|
|
|
void togglePlayerLooking(bool enable);
|
2013-03-07 23:12:56 +00:00
|
|
|
|
|
|
|
bool isVanityOrPreviewModeEnabled();
|
2013-07-29 14:43:16 +00:00
|
|
|
|
|
|
|
bool isNearest();
|
2011-01-08 14:11:37 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|