Navigation Menu

Skip to content

Commit

Permalink
Added possibility to set custom ellipsoid
Browse files Browse the repository at this point in the history
  • Loading branch information
homann committed Sep 3, 2012
1 parent 143300d commit 6154f8e
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 0 deletions.
19 changes: 19 additions & 0 deletions src/core/qgsdistancearea.cpp
Expand Up @@ -79,6 +79,9 @@ void QgsDistanceArea::_copy( const QgsDistanceArea & origDA )
mSemiMajor = origDA.mSemiMajor;
mSemiMinor = origDA.mSemiMinor;
mInvFlattening = origDA.mInvFlattening;
// Some calculations and trig. Should not be TOO time consuming.
// Alternatively we could copy the temp vars?
computeAreaInit();
mSourceRefSys = origDA.mSourceRefSys;
mCoordTransform = new QgsCoordinateTransform( origDA.mCoordTransform->sourceCrs(), origDA.mCoordTransform->destCRS() );
}
Expand Down Expand Up @@ -205,6 +208,22 @@ bool QgsDistanceArea::setEllipsoid( const QString& ellipsoid )
return true;
}

//! Sets ellipsoid by supplied radii
// Inverse flattening is calculated with invf = a/(a-b)
// Also, b = a-(a/invf)
bool QgsDistanceArea::setEllipsoid( double semiMajor, double semiMinor )
{
mEllipsoid = "PARAMETER";
mSemiMajor = semiMajor;
mSemiMinor = semiMinor;
mInvFlattening = mSemiMajor / ( mSemiMajor - mSemiMinor );

computeAreaInit();

return true;
}



double QgsDistanceArea::measure( QgsGeometry* geometry )
{
Expand Down
4 changes: 4 additions & 0 deletions src/core/qgsdistancearea.h
Expand Up @@ -71,6 +71,10 @@ class CORE_EXPORT QgsDistanceArea
//! sets ellipsoid by its acronym
bool setEllipsoid( const QString& ellipsoid );

//! Sets ellipsoid by supplied radii
// Inverse flattening is calculated with invf = a/(a-b)
bool setEllipsoid( double semiMajor, double semiMinor );

//! returns ellipsoid's acronym
const QString& ellipsoid() { return mEllipsoid; }

Expand Down
4 changes: 4 additions & 0 deletions tests/src/core/testqgsdistancearea.cpp
Expand Up @@ -81,6 +81,10 @@ void TestQgsDistanceArea::basic()
QCOMPARE( resultB, resultC );
delete daC;

// Use parameter setting of ellipsoid radii (from WGS72 )
daA.setEllipsoid( 6378135.0, 6378135.0 - ( 6378135.0 / 298.26 ) );
resultA = daA.measureLine( p1, p2 );
QCOMPARE( resultA, resultB );
};

void TestQgsDistanceArea::test_distances()
Expand Down

0 comments on commit 6154f8e

Please sign in to comment.