1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
/**************************************************************************\
*
* This file is part of the Coin 3D visualization library.
* Copyright (C) by Kongsberg Oil & Gas Technologies.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* ("GPL") version 2 as published by the Free Software Foundation.
* See the file LICENSE.GPL at the root directory of this source
* distribution for additional information about the GNU GPL.
*
* For using Coin with software that can not be combined with the GNU
* GPL, and for taking advantage of the additional benefits of our
* support services, please contact Kongsberg Oil & Gas Technologies
* about acquiring a Coin Professional Edition License.
*
* See http://www.coin3d.org/ for more information.
*
* Kongsberg Oil & Gas Technologies, Bygdoy Alle 5, 0257 Oslo, NORWAY.
* http://www.sim.no/ sales@sim.no coin-support@coin3d.org
*
\**************************************************************************/
#include "SbGeoEllipsoid.h"
#include <Inventor/SbString.h>
#include <stdio.h>
SbGeoEllipsoid::SbGeoEllipsoid(void)
{
this->a = 0.0;
this->e = 0.0;
}
// constructor
SbGeoEllipsoid::SbGeoEllipsoid(const SbString & desc, char hemisphere)
{
if (desc == "WGS_1984" || desc == "WGS84" || desc == "WGS1984UTM") {
this->a = 6378137.0;
this->e = 0.081819191;
this->eccsquared = 0.00669438;
}
else {
fprintf(stderr,"Unsupported ellipsoid: %s\n",
desc.getString());
this->a = 6378137.0;
this->e = 0.081819191;
this->eccsquared = 0.00669438;
}
assert(hemisphere == 'N' || hemisphere == 'S');
this->hemisphere = hemisphere;
// polar stereographic
if (this->hemisphere == 'N') {
this->lambda0.setDegree(0); // Longitude of origin
this->phiF.setDegree(75); // Latitude of standard parallel
}
else {
this->lambda0.setDegree(180); // Longitude of origin
this->phiF.setDegree(-75); // Latitude of standard parallel
}
}
// copy constructor
SbGeoEllipsoid::SbGeoEllipsoid(const SbGeoEllipsoid & e)
{
*this = e;
}
SbGeoEllipsoid &
SbGeoEllipsoid::operator=(const SbGeoEllipsoid & e)
{
this->e = e.e;
this->a = e.a;
this->eccsquared = e.eccsquared;
this->hemisphere = e.hemisphere;
this->lambda0 = e.lambda0;
this->phiF = e.phiF;
return *this;
}
double
SbGeoEllipsoid::getA(void) const
{
return this->a;
}
double
SbGeoEllipsoid::getE(void) const
{
return this->e;
}
double
SbGeoEllipsoid::getEccentricitySquared(void) const
{
return this->eccsquared;
}
char
SbGeoEllipsoid::getHemisphere(void) const
{
return this->hemisphere;
}
const SbGeoAngle &
SbGeoEllipsoid::getLatStdParallel(void) const
{
return this->phiF;
}
const SbGeoAngle &
SbGeoEllipsoid::getLongOrigin(void) const
{
return this->lambda0;
}
|