SO3Engine
SO3Sun.cpp
Go to the documentation of this file.
1/*
2-----------------------------------------------------------------------------
3This source file is part of OpenSpace3D
4For the latest info, see http://www.openspace3d.com
5
6Copyright (c) 2012 I-maginer
7
8This program is free software; you can redistribute it and/or modify it under
9the terms of the GNU Lesser General Public License as published by the Free Software
10Foundation; either version 2 of the License, or (at your option) any later
11version.
12
13This program is distributed in the hope that it will be useful, but WITHOUT
14ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
16
17You should have received a copy of the GNU Lesser General Public License along with
18this program; if not, write to the Free Software Foundation, Inc., 59 Temple
19Place - Suite 330, Boston, MA 02111-1307, USA, or go to
20http://www.gnu.org/copyleft/lesser.txt
21
22-----------------------------------------------------------------------------
23*/
24
34
35namespace SO3
36{
37
38SSun::SSun(SEnvironment* parent, const std::string& sunName) : SSkyLight(parent, sunName, Ogre::ColourValue(0.8, 0.8, 0.8))
39{
41}
42
43SSun::SSun() : SSkyLight(0, "", Ogre::ColourValue::Black)
44{
45 // Forbiden (private)
46}
47
49{
50}
51
52const Ogre::Vector3 SSun::ComputeDirectionImpl(const double& julianDay)
53{
54 return GetSunDirection(julianDay);
55}
56
57const Ogre::Vector3 SSun::GetSunDirection(const double& jday)
58{
59 Ogre::Degree azimuth;
60 Ogre::Degree altitude;
61 {
62 ScopedHighPrecissionFloatSwitch precisionSwitch;
64 }
65 Ogre::Vector3 res = MakeDirection(azimuth, altitude);
66 return res;
67}
68
69
70}
static void GetHorizontalSunPosition(const double &jday, const double &longitude, const double &latitude, double &azimuth, double &altitude)
Ogre::Degree GetLatitude()
Ogre::Degree GetLongitude()
void SetCastShadowEnable(const bool &enable)
SEnvironment * parentEnvironment
Definition SO3SkyLight.h:45
const Ogre::Vector3 MakeDirection(const Ogre::Degree &azimuth, const Ogre::Degree &altitude)
virtual const Ogre::Vector3 ComputeDirectionImpl(const double &julianDay)
Definition SO3Sun.cpp:52