fixed: auto_ptr -> unique_ptr
[opensg.git] / Source / System / Window / Camera / OSGOrthographicCamera.cpp
blob2d993b18793d6ec29904dc235a73c51a9e53445c
1 /*---------------------------------------------------------------------------*\
2 * OpenSG *
3 * *
4 * *
5 * Copyright (C) 2000-2002 by the OpenSG Forum *
6 * *
7 * www.opensg.org *
8 * *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
10 * *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
13 * License *
14 * *
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. *
18 * *
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. *
23 * *
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. *
27 * *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
30 * Changes *
31 * *
32 * *
33 * *
34 * *
35 * *
36 * *
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
40 // Includes
41 //---------------------------------------------------------------------------
43 #include <stdlib.h>
44 #include <stdio.h>
46 #include "OSGConfig.h"
47 #include "OSGMatrixUtility.h"
49 #include "OSGOrthographicCamera.h"
51 OSG_USING_NAMESPACE
53 /***************************************************************************\
54 * Description *
55 \***************************************************************************/
57 /*! \class OSG::OrthographicCamera
58 An orthographic camera.
61 /***************************************************************************\
62 * Class variables *
63 \***************************************************************************/
65 /***************************************************************************\
66 * Class methods *
67 \***************************************************************************/
69 void OrthographicCamera::initMethod(InitPhase ePhase)
71 Inherited::initMethod(ePhase);
75 /***************************************************************************\
76 * Instance methods *
77 \***************************************************************************/
79 /*-------------------------------------------------------------------------*\
80 - private -
81 \*-------------------------------------------------------------------------*/
83 /*----------------------- constructors & destructors ----------------------*/
85 OrthographicCamera::OrthographicCamera(void) :
86 Inherited()
90 OrthographicCamera::OrthographicCamera(const OrthographicCamera &source) :
91 Inherited(source)
95 OrthographicCamera::~OrthographicCamera(void)
99 /*----------------------------- class specific ----------------------------*/
101 void OrthographicCamera::changed(ConstFieldMaskArg whichField,
102 UInt32 origin,
103 BitVector details)
105 Inherited::changed(whichField, origin, details);
108 /*-------------------------- your_category---------------------------------*/
110 void OrthographicCamera::getProjection(Matrix &result,
111 UInt32 width,
112 UInt32 height)
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();
121 return;
124 Real32 winAspect = width / Real32(height) * getAspect();
125 if (vs <= 0)
127 vs = hs / winAspect;
129 else if (hs <= 0)
131 hs = vs * winAspect;
133 else
135 Real32 camAspect = hs / vs;
137 if (winAspect < camAspect)
139 vs = hs / winAspect;
141 else
143 hs = vs * winAspect;
147 MatrixOrthogonal(result, -hs, hs,
148 -vs, vs,
149 getNear(), getFar());
153 void OrthographicCamera::dump( UInt32 ,
154 const BitVector ) const
156 SLOG << "Dump OrthographicCamera NI" << std::endl;