Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/playability/src/world_entities/camera.h @ 10262

Last change on this file since 10262 was 10237, checked in by muellmic, 18 years ago

changed camera handling for the vertical-scroller playmode. the top-down view in vertical scroller is now a proper camera-viewmode. also added a bool-state in the camera class to override the camera's event-listener and handle the camera-events (view buttons) in other classes. i used this to handle the camera parenting with the space-ship class, so other views as the top-down get useful and nice-looking again…. *taking-a-look-at-the-watch* oops damnit… i hope i won't forget the last tram ;-)

File size: 3.0 KB
RevLine 
[4592]1/*!
[5005]2 * @file camera.h
3 * Viewpoint controlling class definitions
[4592]4*/
[2068]5
[3224]6#ifndef _CAMERA_H
7#define _CAMERA_H
[2068]8
[3635]9#include "p_node.h"
[4414]10#include "event_listener.h"
[7009]11#include "plane.h"
[2100]12
[2636]13class World;
[3635]14class CameraTarget;
[4414]15class Event;
[2100]16
[3635]17
[2096]18//! Camera
19/**
[5005]20 * This class controls the viewpoint from which the World is rendered.
[2096]21*/
[4414]22class Camera : public PNode, public EventListener
[3635]23{
[9869]24  ObjectListDeclaration(Camera);
[7347]25public:
26  //! an enumerator for different types of view
27  typedef enum ViewMode
28  {
29    ViewNormal,
30    ViewBehind,
31    ViewFront,
32    ViewLeft,
33    ViewRight,
34    ViewTop
35  };
36
[4746]37  Camera();
38  virtual ~Camera();
[3635]39
40  void lookAt(PNode* target);
[7014]41  CameraTarget* getTarget() const { return this->target; };
42  PNode* getTargetNode() const;
[3636]43
44  void setAspectRatio(float aspectRatio);
45  void setClipRegion(float nearClip, float farClip);
46
[7173]47  /** @param fovy new field of view factor (in degrees) */
48  void setFovy(float fovy) { this->fovy = fovy; };
49  /** @param fovy new field of view factor (in degrees) to iterate to */
50  void setToFovy(float toFovy) { this->toFovy = toFovy; };
51
[7347]52  void setViewMode(Camera::ViewMode mode);
[7009]53  inline const Vector& getViewVector() const { return this->viewVector; }
54  inline const Vector& getUpVector() const { return this->upVector; }
55  inline const Plane& getViewFrustum() const { return this->frustumPlane; }
56
[7013]57  inline float distance(const Vector& distance) const { return this->frustumPlane.distancePoint(distance); }
58  inline float distance(const PNode* node) const { return distance(node->getAbsCoor()); }
[7009]59
[10237]60  inline void setEventHandling(bool b) {this->eventHandling = b;}
61  inline bool getEventHandling() {return this->eventHandling;}
62
[3639]63  void tick(float dt);
[4746]64  void apply ();
[7108]65  void project();
[4414]66
67  void process(const Event &event);
[4490]68
[7347]69private:
[4490]70  CameraTarget*     target;          //!< The Target of the Camera (where this Camera Looks at)
71
[10237]72  bool              eventHandling;    //!< True, if the Camera handles the processing of events itself. Set false to overwrite the standard handling.
73
[4490]74  float             fovy;            //!< The field of view Angle (in degrees).
75  float             aspectRatio;     //!< The aspect ratio (width / height).
76  float             nearClip;        //!< The near clipping plane.
77  float             farClip;         //!< The far clipping plane.
78
[4986]79  float             toFovy;          //!< The fovy-mode to iterate to.
[7347]80  Camera::ViewMode  currentMode;     //!< The ViewMode the camera is in
[6999]81
82  Vector            delay;
[7009]83  Plane             frustumPlane;    //!< plane that marks the view frustum
84  Vector            viewVector;      //!< the direction of the camera view
85  Vector            upVector;        //!< direction of the up vector
[3635]86};
[2068]87
[3635]88//! A CameraTarget is where the Camera is looking at.
[4592]89class CameraTarget : public PNode
[3635]90{
[3636]91  friend class Camera;             //! The CameraTarget is a friend of Camera. noone else needs a CameraTarget, so noone else can create it.
[9869]92  ObjectListDeclaration(CameraTarget);
[4592]93
[7347]94private:
[4746]95  CameraTarget();
[4592]96
[7347]97public:
[3635]98};
[2068]99
100
[3224]101#endif /* _CAMERA_H */
Note: See TracBrowser for help on using the repository browser.