root/juggler/branches/1.0/Kernel/vjCameraProjection.h

Revision 8789, 2.5 kB (checked in by patrickh, 7 years ago)

Copyright update.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1 /*************** <auto-copyright.pl BEGIN do not edit this line> **************
2  *
3  * VR Juggler is (C) Copyright 1998, 1999, 2000, 2001, 2002
4  *   by Iowa State University
5  *
6  * Original Authors:
7  *   Allen Bierbaum, Christopher Just,
8  *   Patrick Hartling, Kevin Meinert,
9  *   Carolina Cruz-Neira, Albert Baker
10  *
11  * This library is free software; you can redistribute it and/or
12  * modify it under the terms of the GNU Library General Public
13  * License as published by the Free Software Foundation; either
14  * version 2 of the License, or (at your option) any later version.
15  *
16  * This library is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19  * Library General Public License for more details.
20  *
21  * You should have received a copy of the GNU Library General Public
22  * License along with this library; if not, write to the
23  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
24  * Boston, MA 02111-1307, USA.
25  *
26  * -----------------------------------------------------------------
27  * File:          $RCSfile$
28  * Date modified: $Date$
29  * Version:       $Revision$
30  * -----------------------------------------------------------------
31  *
32  *************** <auto-copyright.pl END do not edit this line> ***************/
33
34
35 #ifndef _VJ_CAMERA_PROJECTION_H_
36 #define _VJ_CAMERA_PROJECTION_H_
37
38 #include <vjConfig.h>
39 #include <Kernel/vjProjection.h>
40 class vjMatrix;
41
42 //: Projection class that simply takes a matrix for the camera position
43 //
44 class vjCameraProjection : public vjProjection
45 {
46 public:
47    vjCameraProjection()
48    {
49       mType = vjProjection::SIM;
50    }
51
52    virtual void config(vjConfigChunk* chunk)
53    {
54       vjProjection::config(chunk);
55
56       vjASSERT((std::string)chunk->getType() == std::string("simDisplay"));
57
58       // Set fov and make sure that it is not 0.0
59       mVertFOV = chunk->getProperty("vert_fov");
60       if(mVertFOV == 0.0f)
61          mVertFOV = 60.0f;
62       mAspectRatio = chunk->getProperty("aspect_ratio");
63       if(mAspectRatio == 0.0f)
64          mAspectRatio = 1.0f;
65    }
66
67    virtual void calcViewMatrix(vjMatrix& cameraPos)
68    {
69       mViewMat = cameraPos;
70       // XXX: The frustum is not used
71       mFrustum.set(-0.6f, 0.6f, -0.6f, 0.6f, mNearDist, mFarDist);
72    }
73
74    virtual std::ostream& outStream(std::ostream& out)
75    {
76       out << "vjCameraProjection:\n";
77       return out;
78    }
79
80 public:
81    float mAspectRatio;     // w/h
82    float mVertFOV;         // The vertical field of view
83 };
84
85 #endif
Note: See TracBrowser for help on using the browser.