00001 /*************** <auto-copyright.pl BEGIN do not edit this line> ************** 00002 * 00003 * VR Juggler is (C) Copyright 1998-2003 by Iowa State University 00004 * 00005 * Original Authors: 00006 * Allen Bierbaum, Christopher Just, 00007 * Patrick Hartling, Kevin Meinert, 00008 * Carolina Cruz-Neira, Albert Baker 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Library General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2 of the License, or (at your option) any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Library General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Library General Public 00021 * License along with this library; if not, write to the 00022 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, 00023 * Boston, MA 02111-1307, USA. 00024 * 00025 * ----------------------------------------------------------------- 00026 * File: $RCSfile: CameraProjection.h,v $ 00027 * Date modified: $Date: 2003/07/10 23:59:14 $ 00028 * Version: $Revision: 1.35 $ 00029 * ----------------------------------------------------------------- 00030 * 00031 *************** <auto-copyright.pl END do not edit this line> ***************/ 00032 00033 #ifndef _VRJ_CAMERA_PROJECTION_H_ 00034 #define _VRJ_CAMERA_PROJECTION_H_ 00035 00036 #include <vrj/vrjConfig.h> 00037 #include <vrj/Display/Projection.h> 00038 #include <jccl/Config/ConfigElementPtr.h> 00039 00040 #include <gmtl/Matrix.h> 00041 #include <gmtl/Vec.h> 00042 00043 00044 namespace vrj 00045 { 00046 00050 class VJ_CLASS_API CameraProjection : public Projection 00051 { 00052 public: 00053 CameraProjection() : mVertFOV(60.0f) 00054 { 00055 //mType = Projection::SIM; 00056 } 00057 00058 virtual void config(jccl::ConfigElementPtr element); 00059 00060 void setVerticalFOV(const float fov) 00061 { 00062 mVertFOV = fov; 00063 } 00064 00069 virtual void calcViewMatrix(gmtl::Matrix44f& cameraPos, const float scaleFactor); 00070 00071 virtual std::ostream& outStream(std::ostream& out, 00072 const unsigned int indentLevel = 0); 00073 00074 public: 00075 //float mAspectRatio; // w/h 00076 float mVertFOV; // The vertical field of view 00077 }; 00078 00079 } 00080 00081 #endif
1.2.14 written by Dimitri van Heesch,
© 1997-2002