/usr/include/libwildmagic/Wm5Camera.h is in libwildmagic-dev 5.13-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 | // Geometric Tools, LLC
// Copyright (c) 1998-2014
// Distributed under the Boost Software License, Version 1.0.
// http://www.boost.org/LICENSE_1_0.txt
// http://www.geometrictools.com/License/Boost/LICENSE_1_0.txt
//
// File Version: 5.0.3 (2011/08/25)
#ifndef WM5CAMERA_H
#define WM5CAMERA_H
#include "Wm5GraphicsLIB.h"
#include "Wm5Object.h"
#include "Wm5HMatrix.h"
namespace Wm5
{
class WM5_GRAPHICS_ITEM Camera : public Object
{
WM5_DECLARE_RTTI;
WM5_DECLARE_NAMES;
WM5_DECLARE_STREAM(Camera);
public:
// Construction and destruction.
Camera (bool isPerspective = true);
virtual ~Camera ();
// The camera frame is always in world coordinates.
// default position P = (0, 0, 0; 1)
// default direction D = (0, 0, -1; 0)
// default up U = (0, 1, 0; 0)
// default right R = (1, 0, 0; 0)
void SetFrame (const APoint& position, const AVector& dVector,
const AVector& uVector, const AVector& rVector);
void SetPosition (const APoint& position);
void SetAxes (const AVector& dVector, const AVector& uVector,
const AVector& rVector);
inline APoint GetPosition () const;
inline AVector GetDVector () const;
inline AVector GetUVector () const;
inline AVector GetRVector () const;
// Access the view matrix of the camera. If D = (d0,d1,d2),
// U = (u0,u1,u2), and R = (r0,r1,r2), then the view matrix is
// +- -+
// | r0 r1 r2 -Dot(R,P) |
// | u0 u1 u2 -Dot(U,P) |
// | d0 d1 d2 -Dot(D,P) |
// | 0 0 0 1 |
// +- -+
// The view matrix multiplies vectors on its right, viewMat*vector4.
inline const HMatrix& GetViewMatrix () const;
// The view frustum has parameters [rmin,rmax], [umin,umax], and
// [dmin,dmax]. The interval [rmin,rmax] is measured in the right
// direction R. These are the "left" and "right" frustum values. The
// interval [umin,umax] is measured in the up direction U. These are
// the "bottom" and "top" values. The interval [dmin,dmax] is measured
// in the view direction D. These are the "near" and "far" values.
// The frustum values are stored in an array with the following mappings:
enum
{
VF_DMIN = 0, // near
VF_DMAX = 1, // far
VF_UMIN = 2, // bottom
VF_UMAX = 3, // top
VF_RMIN = 4, // left
VF_RMAX = 5, // right
VF_QUANTITY = 6
};
// The default view frustum has an up field-of-view of 90 degrees, an
// aspect ratio of 1, near value 1, and far value 10000.
inline bool IsPerspective () const;
// Set the view frustum. The interval [rmin,rmax] is measured in the
// right direction R. These are the "left" and "right" frustum values.
// The interval [umin,umax] is measured in the up direction U. These are
// the "bottom" and "top" values. The interval [dmin,dmax] is measured
// in the view direction D. These are the "near" and "far" values.
void SetFrustum (float dMin, float dMax, float uMin, float uMax,
float rMin, float rMax);
// Set all the view frustum values simultaneously. The input array must
// have the order: dmin, dmax, umin, umax, rmin, rmax.
void SetFrustum (const float* frustum);
// Set a symmetric view frustum (umin = -umax, rmin = -rmax) using a field
// of view in the "up" direction and an aspect ratio "width/height". This
// call is the equivalent of gluPerspective in OpenGL. As such, the field
// of view in this function must be specified in degrees and be in the
// interval (0,180).
void SetFrustum (float upFovDegrees, float aspectRatio, float dMin,
float dMax);
// Get the view frustum.
void GetFrustum (float& dMin, float& dMax, float& uMin, float& uMax,
float& rMin, float& rMax) const;
// Get all the view frustum values simultaneously.
inline const float* GetFrustum () const;
// Get the parameters for a symmetric view frustum. The return value is
// 'true' iff the current frustum is symmetric, in which case the output
// parameters are valid.
bool GetFrustum (float& upFovDegrees, float& aspectRatio, float& dMin,
float& dMax) const;
// Get the individual frustum values.
inline float GetDMin () const;
inline float GetDMax () const;
inline float GetUMin () const;
inline float GetUMax () const;
inline float GetRMin () const;
inline float GetRMax () const;
// Access the projection matrices of the camera. The projection matrix
// that maps to depths [0,1] is what Direct3D uses. The view matrix that
// maps to depths [-1,1] is what OpenGL uses.
enum WM5_GRAPHICS_ITEM DepthType
{
PM_DEPTH_ZERO_TO_ONE, // [0,1]
PM_DEPTH_MINUS_ONE_TO_ONE, // [-1,1]
PM_DEPTH_QUANTITY
};
inline DepthType GetDepthType () const;
// The frustum values are N (near), F (far), B (bottom), T (top),
// L (left), and R (right). The various matrices are as follows.
//
// perspective, depth [0,1]
// +- -+
// | 2*N/(R-L) 0 -(R+L)/(R-L) 0 |
// | 0 2*N/(T-B) -(T+B)/(T-B) 0 |
// | 0 0 F/(F-N) -N*F/(F-N) |
// | 0 0 1 0 |
// +- -+
//
// perspective, depth [-1,1]
// +- -+
// | 2*N/(R-L) 0 -(R+L)/(R-L) 0 |
// | 0 2*N/(T-B) -(T+B)/(T-B) 0 |
// | 0 0 (F+N)/(F-N) -2*F*N/(F-N) |
// | 0 0 1 0
// +- -+
//
// orthographic, depth [0,1]
// +- -+
// | 2/(R-L) 0 0 -(R+L)/(R-L) |
// | 0 2/(T-B) 0 -(T+B)/(T-B) |
// | 0 0 1/(F-N) -N/(F-N) 0 |
// | 0 0 0 1 |
// +- -+
//
// orthographic, depth [-1,1]
// +- -+
// | 2/(R-L) 0 0 -(R+L)/(R-L) |
// | 0 2/(T-B) 0 -(T+B)/(T-B) |
// | 0 0 2/(F-N) -(F+N)/(F-N) |
// | 0 0 0 1 |
// +- -+
//
// The projection matrix multiplies vectors on its right, projMat*vector4.
// The returned matrix depends on the values of msDepthType and
// mIsPerspective.
inline const HMatrix& GetProjectionMatrix () const;
// Support for advanced effects. The first function allows you to set the
// projection matrix anyway you like. The second function specifies a
// convex quadrilateral viewport. The points must be in camera
// coordinates and are counterclockwise ordered as viewed from the
// eyepoint. The plane of the quadrilateral is the view plane and has an
// "extrude" value of 1. The nearExtrude value is in (0,infinity); this
// specifies the fraction from the eyepoint to the view plane at which to
// place the near-face of the cuboidal view volume. The farExtrude value
// is in (nearExtrude,infinity); this specifies the fraction from the
// eyepoint at which to place the far-face of the cuboidal view volume.
inline void SetProjectionMatrix (const HMatrix& projMatrix);
void SetProjectionMatrix (const APoint& p00, const APoint& p10,
const APoint& p11, const APoint& p01, float nearExtrude,
float farExtrude);
// The projection-view-world matrix is commonly used in the shader
// programs to transform model-space data to clip-space data. To avoid
// repeatedly computing the projection-view matrix for each geometric
// object, the product is stored and maintained in this class.
inline const HMatrix& GetProjectionViewMatrix () const;
// The preview matrix is applied after the model-to-world but before the
// view matrix. It is used for transformations such as reflections of
// world objects. The default value is the identity matrix.
void SetPreViewMatrix (const HMatrix& preViewMatrix);
inline const HMatrix& GetPreViewMatrix () const;
inline bool PreViewIsIdentity () const;
// The postprojection matrix is used for screen-space transformations such
// as reflection of the rendered image. The default value is the identity
// matrix.
void SetPostProjectionMatrix (const HMatrix& postProjMatrix);
inline const HMatrix& GetPostProjectionMatrix () const;
inline bool PostProjectionIsIdentity () const;
// Compute the axis-aligned bounding rectangle in normalized display
// space, [-1,1]x[-1,1], for a set of vertices. The input 'vertices' is a
// pointer to triples of 'float' values, each triple representing a vertex.
// The stride is the number of bytes from the first position channel of one
// vertex to the first position channel of the next vertex. If the
// vertices are packed contiguously, the stride is 3*sizeof(float). The
// vertices are in model space. The input 'worldMatrix' transforms the
// model space to world space.
void ComputeBoundingAABB (int numVertices, const char* vertices,
int stride, const HMatrix& worldMatrix, float& xmin, float& xmax,
float& ymin, float& ymax);
protected:
// Compute the view matrix after the frame changes.
void OnFrameChange ();
// Compute the projection matrices after the frustum changes.
void OnFrustumChange ();
// Compute the product postproj-proj-view-preview.
void UpdatePVMatrix ();
// The world coordinate frame.
APoint mPosition;
AVector mDVector, mUVector, mRVector;
// The view matrix for the camera. The matrix is stored so that you
// apply it to vectors on the right: viewMatrix*someVector4.
HMatrix mViewMatrix;
// The view frustum, stored in order as dmin (near), dmax (far),
// umin (bottom), umax (top), rmin (left), and rmax (right).
float mFrustum[VF_QUANTITY];
// The projection matrices for the camera. The matrices are stored so
// that you apply it to vectors on the right: projMatrix*someVector4.
HMatrix mProjectionMatrix[PM_DEPTH_QUANTITY];
// The product of the projection and view matrix. This includes the
// post-projection and/or pre-view whenever those are not the identity
// matrix.
HMatrix mProjectionViewMatrix[PM_DEPTH_QUANTITY];
// The preview matrix for the camera.
HMatrix mPreViewMatrix;
bool mPreViewIsIdentity;
// The postprojection matrix for the camera.
HMatrix mPostProjectionMatrix;
bool mPostProjectionIsIdentity;
// This member is 'true' for a perspective camera or 'false' for an
// orthographic camera.
bool mIsPerspective;
// This object's depth type. The value is initialized to
// msDefaultDepthType during the constructor call. Camera does not
// stream this value. The Projector derived class overrides the depth
// type and does stream it, because you might want a projector of a
// type that does not match the graphics API type.
DepthType mDepthType;
// Specify the type of projection matrix (different between DirectX and
// OpenGL). This value is used to initialize mDepthType during the
// constructor call.
static DepthType msDefaultDepthType;
public_internal:
// Set this to one of the previously mentioned enumerations. You should
// do so in the platform-dependent application layer. This guarantees
// that you access the correct projection matrix in GetProjection().
inline static void SetDefaultDepthType (DepthType type);
inline static DepthType GetDefaultDepthType ();
// Read the comments in Wm5GraphicsLIB.h about this define.
private_internal:
#ifdef WM5_VALIDATE_CAMERA_FRAME_ONCE
bool mValidateCameraFrame;
#endif
};
WM5_REGISTER_STREAM(Camera);
typedef Pointer0<Camera> CameraPtr;
#include "Wm5Camera.inl"
}
#endif
|