1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277
|
/*
* $Id: KX_Camera.h 14444 2008-04-16 22:40:48Z hos $
*
* ***** BEGIN GPL LICENSE BLOCK *****
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
* All rights reserved.
*
* The Original Code is: all of this file.
*
* Contributor(s): none yet.
*
* ***** END GPL LICENSE BLOCK *****
* Camera in the gameengine. Cameras are also used for views.
*/
#ifndef __KX_CAMERA
#define __KX_CAMERA
#include "MT_Transform.h"
#include "MT_Matrix3x3.h"
#include "MT_Matrix4x4.h"
#include "MT_Vector3.h"
#include "MT_Point3.h"
#include "KX_GameObject.h"
#include "IntValue.h"
#include "RAS_CameraData.h"
class KX_Camera : public KX_GameObject
{
Py_Header;
protected:
/** Camera parameters (clips distances, focal lenght). These
* params are closely tied to Blender. In the gameengine, only the
* projection and modelview matrices are relevant. There's a
* conversion being done in the engine class. Why is it stored
* here? It doesn't really have a function here. */
RAS_CameraData m_camdata;
// Never used, I think...
// void MoveTo(const MT_Point3& movevec)
// {
/*MT_Transform camtrans;
camtrans.invert(m_trans1);
MT_Matrix3x3 camorient = camtrans.getBasis();
camtrans.translate(camorient.inverse()*movevec);
m_trans1.invert(camtrans);
*/
// }
/**
* Storage for the projection matrix that is passed to the
* rasterizer. */
MT_Matrix4x4 m_projection_matrix;
/**
* Storage for the modelview matrix that is passed to the
* rasterizer. */
MT_Matrix4x4 m_modelview_matrix;
/**
* true if the view frustum (modelview/projection matrix)
* has changed - the clip planes (m_planes) will have to be
* regenerated.
*/
bool m_dirty;
/**
* true if the frustum planes have been normalized.
*/
bool m_normalized;
/**
* View Frustum clip planes.
*/
MT_Vector4 m_planes[6];
/**
* This camera is frustum culling.
* Some cameras (ie if the game was started from a non camera view should not cull.)
*/
bool m_frustum_culling;
/**
* true if this camera has a valid projection matrix.
*/
bool m_set_projection_matrix;
/**
* The center point of the frustum.
*/
MT_Point3 m_frustum_center;
MT_Scalar m_frustum_radius;
bool m_set_frustum_center;
/**
* Python module doc string.
*/
static char doc[];
/**
* Extracts the camera clip frames from the projection and world-to-camera matrices.
*/
void ExtractClipPlanes();
/**
* Normalize the camera clip frames.
*/
void NormalizeClipPlanes();
/**
* Extracts the bound sphere of the view frustum.
*/
void ExtractFrustumSphere();
public:
typedef enum { INSIDE, INTERSECT, OUTSIDE } ;
KX_Camera(void* sgReplicationInfo,SG_Callbacks callbacks,const RAS_CameraData& camdata, bool frustum_culling = true, PyTypeObject *T = &Type);
virtual ~KX_Camera();
/**
* Inherited from CValue -- return a new copy of this
* instance allocated on the heap. Ownership of the new
* object belongs with the caller.
*/
virtual CValue*
GetReplica(
);
/**
* Inherited from CValue -- Makes sure any internal
* data owned by this class is deep copied. Called internally
*/
virtual void
ProcessReplica(
KX_Camera* replica
);
MT_Transform GetWorldToCamera() const;
MT_Transform GetCameraToWorld() const;
/**
* Not implemented.
*/
void CorrectLookUp(MT_Scalar speed);
const MT_Point3 GetCameraLocation() const;
/* I want the camera orientation as well. */
const MT_Quaternion GetCameraOrientation() const;
/** Sets the projection matrix that is used by the rasterizer. */
void SetProjectionMatrix(const MT_Matrix4x4 & mat);
/** Sets the modelview matrix that is used by the rasterizer. */
void SetModelviewMatrix(const MT_Matrix4x4 & mat);
/** Gets the projection matrix that is used by the rasterizer. */
const MT_Matrix4x4& GetProjectionMatrix() const;
/** returns true if this camera has been set a projection matrix. */
bool hasValidProjectionMatrix() const;
/** Sets the validity of the projection matrix. Call this if you change camera
data (eg lens, near plane, far plane) and require the projection matrix to be
recalculated.
*/
void InvalidateProjectionMatrix(bool valid = false);
/** Gets the modelview matrix that is used by the rasterizer.
* @warning If the Camera is a dynamic object then this method may return garbage. Use GetCameraToWorld() instead.
*/
const MT_Matrix4x4& GetModelviewMatrix() const;
/** Gets the focal length. */
float GetLens() const;
/** Gets the near clip distance. */
float GetCameraNear() const;
/** Gets the far clip distance. */
float GetCameraFar() const;
/** Gets all camera data. */
RAS_CameraData* GetCameraData();
/**
* Tests if the given sphere is inside this camera's view frustum.
*
* @param center The center of the sphere, in world coordinates.
* @param radius The radius of the sphere.
* @return INSIDE, INTERSECT, or OUTSIDE depending on the sphere's relation to the frustum.
*/
int SphereInsideFrustum(const MT_Point3& center, const MT_Scalar &radius);
/**
* Tests the given eight corners of a box with the view frustum.
*
* @param box a pointer to eight MT_Point3 representing the world coordinates of the corners of the box.
* @return INSIDE, INTERSECT, or OUTSIDE depending on the box's relation to the frustum.
*/
int BoxInsideFrustum(const MT_Point3 *box);
/**
* Tests the given point against the view frustum.
* @return true if the given point is inside or on the view frustum; false if it is outside.
*/
bool PointInsideFrustum(const MT_Point3& x);
/**
* Gets this camera's culling status.
*/
bool GetFrustumCulling() const;
/**
* Sets this camera's viewport status.
*/
void EnableViewport(bool viewport);
/**
* Sets this camera's viewport.
*/
void SetViewport(int left, int bottom, int right, int top);
/**
* Gets this camera's viewport status.
*/
bool GetViewport() const;
/**
* Gets this camera's viewport left.
*/
int GetViewportLeft() const;
/**
* Gets this camera's viewport bottom.
*/
int GetViewportBottom() const;
/**
* Gets this camera's viewport right.
*/
int GetViewportRight() const;
/**
* Gets this camera's viewport top.
*/
int GetViewportTop() const;
KX_PYMETHOD_DOC(KX_Camera, sphereInsideFrustum);
KX_PYMETHOD_DOC(KX_Camera, boxInsideFrustum);
KX_PYMETHOD_DOC(KX_Camera, pointInsideFrustum);
KX_PYMETHOD_DOC(KX_Camera, getCameraToWorld);
KX_PYMETHOD_DOC(KX_Camera, getWorldToCamera);
KX_PYMETHOD_DOC(KX_Camera, getProjectionMatrix);
KX_PYMETHOD_DOC(KX_Camera, setProjectionMatrix);
KX_PYMETHOD_DOC(KX_Camera, enableViewport);
KX_PYMETHOD_DOC(KX_Camera, setViewport);
KX_PYMETHOD_DOC(KX_Camera, setOnTop);
virtual PyObject* _getattr(const STR_String& attr); /* lens, near, far, projection_matrix */
virtual int _setattr(const STR_String& attr, PyObject *pyvalue);
};
#endif //__KX_CAMERA
|