diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2020-04-19 13:27:25 +0200 |
|---|---|---|
| committer | Even Rouault <even.rouault@spatialys.com> | 2020-04-19 16:11:33 +0200 |
| commit | d9934eb07fb38ad57f40eb6c308fcbbf0f713d86 (patch) | |
| tree | fb74a190ceaf05dc763bec79ce656137074eab3f /test/unit/test_io.cpp | |
| parent | d032e0d957e020ede28832b3d18c15d238355e72 (diff) | |
| download | PROJ-d9934eb07fb38ad57f40eb6c308fcbbf0f713d86.tar.gz PROJ-d9934eb07fb38ad57f40eb6c308fcbbf0f713d86.zip | |
Ingestion of WKT1_GDAL: correctly map 'Cylindrical_Equal_Area'
Map it to 'Lambert Cylindrical Equal Area' / EPSG:9835 non-spherical
method, when the ellipsoid is not a sphere. And rationalize the
handling of this for other methods with spherical vs non-spherical formulations
Diffstat (limited to 'test/unit/test_io.cpp')
| -rw-r--r-- | test/unit/test_io.cpp | 48 |
1 files changed, 47 insertions, 1 deletions
diff --git a/test/unit/test_io.cpp b/test/unit/test_io.cpp index c029b09b..a2c75e04 100644 --- a/test/unit/test_io.cpp +++ b/test/unit/test_io.cpp @@ -4662,7 +4662,7 @@ static const struct { {"False_Northing", 2}, {"Central_Meridian", 3}, {"Standard_Parallel_1", 4}}, - "Lambert Cylindrical Equal Area (Spherical)", + "Lambert Cylindrical Equal Area", { {"Latitude of 1st standard parallel", 4}, {"Longitude of natural origin", 3}, @@ -7958,6 +7958,30 @@ TEST(io, projparse_aeqd_guam) { // --------------------------------------------------------------------------- +TEST(io, projparse_cea_spherical) { + auto obj = PROJStringParser().createFromPROJString( + "+proj=cea +R=6371228 +type=crs"); + auto crs = nn_dynamic_pointer_cast<ProjectedCRS>(obj); + ASSERT_TRUE(crs != nullptr); + EXPECT_EQ(crs->derivingConversion()->method()->getEPSGCode(), + EPSG_CODE_METHOD_LAMBERT_CYLINDRICAL_EQUAL_AREA_SPHERICAL); + + auto crs2 = ProjectedCRS::create( + PropertyMap(), crs->baseCRS(), + Conversion::createLambertCylindricalEqualArea( + PropertyMap(), Angle(0), Angle(0), Length(0), Length(0)), + crs->coordinateSystem()); + EXPECT_EQ(crs2->derivingConversion()->method()->getEPSGCode(), + EPSG_CODE_METHOD_LAMBERT_CYLINDRICAL_EQUAL_AREA); + + EXPECT_TRUE( + crs->isEquivalentTo(crs2.get(), IComparable::Criterion::EQUIVALENT)); + EXPECT_TRUE( + crs2->isEquivalentTo(crs.get(), IComparable::Criterion::EQUIVALENT)); +} + +// --------------------------------------------------------------------------- + TEST(io, projparse_cea_ellipsoidal) { auto obj = PROJStringParser().createFromPROJString( "+proj=cea +ellps=GRS80 +type=crs"); @@ -8481,6 +8505,17 @@ TEST(io, projparse_laea_spherical) { // --------------------------------------------------------------------------- +TEST(io, projparse_laea_ellipsoidal) { + auto obj = PROJStringParser().createFromPROJString( + "+proj=laea +ellps=WGS84 +type=crs"); + auto crs = nn_dynamic_pointer_cast<ProjectedCRS>(obj); + ASSERT_TRUE(crs != nullptr); + EXPECT_EQ(crs->derivingConversion()->method()->getEPSGCode(), + EPSG_CODE_METHOD_LAMBERT_AZIMUTHAL_EQUAL_AREA); +} + +// --------------------------------------------------------------------------- + TEST(io, projparse_eqc_spherical) { auto obj = PROJStringParser().createFromPROJString( "+proj=eqc +R=6371228 +type=crs"); @@ -8505,6 +8540,17 @@ TEST(io, projparse_eqc_spherical) { // --------------------------------------------------------------------------- +TEST(io, projparse_eqc_ellipsoidal) { + auto obj = PROJStringParser().createFromPROJString( + "+proj=eqc +ellps=WGS84 +type=crs"); + auto crs = nn_dynamic_pointer_cast<ProjectedCRS>(obj); + ASSERT_TRUE(crs != nullptr); + EXPECT_EQ(crs->derivingConversion()->method()->getEPSGCode(), + EPSG_CODE_METHOD_EQUIDISTANT_CYLINDRICAL); +} + +// --------------------------------------------------------------------------- + TEST(io, projparse_non_earth_ellipsoid) { std::string input("+proj=merc +lon_0=0 +k=1 +x_0=0 +y_0=0 +R=1 +units=m " "+no_defs +type=crs"); |
