1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2002 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
41 //---------------------------------------------------------------------------
46 #include "OSGConfig.h"
47 #include "OSGMatrixUtility.h"
49 #include "OSGOrthographicCamera.h"
53 /***************************************************************************\
55 \***************************************************************************/
57 /*! \class OSG::OrthographicCamera
58 An orthographic camera.
61 /***************************************************************************\
63 \***************************************************************************/
65 /***************************************************************************\
67 \***************************************************************************/
69 void OrthographicCamera::initMethod(InitPhase ePhase
)
71 Inherited::initMethod(ePhase
);
75 /***************************************************************************\
77 \***************************************************************************/
79 /*-------------------------------------------------------------------------*\
81 \*-------------------------------------------------------------------------*/
83 /*----------------------- constructors & destructors ----------------------*/
85 OrthographicCamera::OrthographicCamera(void) :
90 OrthographicCamera::OrthographicCamera(const OrthographicCamera
&source
) :
95 OrthographicCamera::~OrthographicCamera(void)
99 /*----------------------------- class specific ----------------------------*/
101 void OrthographicCamera::changed(ConstFieldMaskArg whichField
,
105 Inherited::changed(whichField
, origin
, details
);
108 /*-------------------------- your_category---------------------------------*/
110 void OrthographicCamera::getProjection(Matrix
&result
,
114 Real32 vs
= getVerticalSize () / 2;
115 Real32 hs
= getHorizontalSize() / 2;
117 // catch some illegal cases
118 if(((vs
<= 0) && (hs
<= 0)) || width
== 0 || height
== 0)
120 result
.setIdentity();
124 Real32 winAspect
= width
/ Real32(height
) * getAspect();
135 Real32 camAspect
= hs
/ vs
;
137 if (winAspect
< camAspect
)
147 MatrixOrthogonal(result
, -hs
, hs
,
149 getNear(), getFar());
153 void OrthographicCamera::dump( UInt32
,
154 const BitVector
) const
156 SLOG
<< "Dump OrthographicCamera NI" << std::endl
;