diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2019-11-14 17:38:59 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-11-14 17:38:59 +0100 |
| commit | fab6ae78eaea6881d24d2554be642bc1d2099a7e (patch) | |
| tree | f5f8ff41bbeb32e0b1b67c31017d219ccf814570 /src | |
| parent | 448af96a817b86fcd38c07c2a0c3b183cd988ef2 (diff) | |
| parent | 2305dec4384365524cef76db4f84214746c4bd95 (diff) | |
| download | PROJ-fab6ae78eaea6881d24d2554be642bc1d2099a7e.tar.gz PROJ-fab6ae78eaea6881d24d2554be642bc1d2099a7e.zip | |
Merge pull request #1732 from rouault/better_export_proj_create_vertical_crs_ex_to_projjson
import/export PROJJSON: support a interpolation_crs key to geoid_model
Diffstat (limited to 'src')
| -rw-r--r-- | src/iso19111/c_api.cpp | 3 | ||||
| -rw-r--r-- | src/iso19111/crs.cpp | 9 | ||||
| -rw-r--r-- | src/iso19111/io.cpp | 10 |
3 files changed, 20 insertions, 2 deletions
diff --git a/src/iso19111/c_api.cpp b/src/iso19111/c_api.cpp index fdfcdf7a..fd661cf8 100644 --- a/src/iso19111/c_api.cpp +++ b/src/iso19111/c_api.cpp @@ -3029,7 +3029,8 @@ PJ *proj_create_vertical_crs_ex( ? std::dynamic_pointer_cast<CRS>(geoid_geog_crs->iso_obj) : nullptr; const auto model(Transformation::create( - propsModel, vertCRSWithoutGeoid, GeographicCRS::EPSG_4979, + propsModel, vertCRSWithoutGeoid, + GeographicCRS::EPSG_4979, // arbitrarily chosen. Ignored interpCRS, OperationMethod::create(PropertyMap(), std::vector<OperationParameterNNPtr>()), diff --git a/src/iso19111/crs.cpp b/src/iso19111/crs.cpp index a55b701a..cf533bd3 100644 --- a/src/iso19111/crs.cpp +++ b/src/iso19111/crs.cpp @@ -2584,6 +2584,15 @@ void VerticalCRS::_exportToJSON( auto objectContext2(formatter->MakeObjectContext(nullptr, false)); writer.AddObjKey("name"); writer.Add(model->nameStr()); + + if (model->identifiers().empty()) { + const auto &interpCRS = model->interpolationCRS(); + if (interpCRS) { + writer.AddObjKey("interpolation_crs"); + interpCRS->_exportToJSON(formatter); + } + } + model->formatID(formatter); } diff --git a/src/iso19111/io.cpp b/src/iso19111/io.cpp index a0a87f65..4d9e8633 100644 --- a/src/iso19111/io.cpp +++ b/src/iso19111/io.cpp @@ -5129,8 +5129,16 @@ VerticalCRSNNPtr JSONParser::buildVerticalCRS(const json &j) { auto propsModel = buildProperties(geoidModelJ); const auto dummyCRS = VerticalCRS::create( PropertyMap(), datum, datumEnsemble, NN_NO_CHECK(verticalCS)); + CRSPtr interpolationCRS; + if (geoidModelJ.contains("interpolation_crs")) { + auto interpolationCRSJ = + getObject(geoidModelJ, "interpolation_crs"); + interpolationCRS = buildCRS(interpolationCRSJ).as_nullable(); + } const auto model(Transformation::create( - propsModel, dummyCRS, dummyCRS, nullptr, + propsModel, dummyCRS, + GeographicCRS::EPSG_4979, // arbitrarily chosen. Ignored, + interpolationCRS, OperationMethod::create(PropertyMap(), std::vector<OperationParameterNNPtr>()), {}, {})); |
