首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在特征集中添加高度坐标,然后序列化到Geojson

如何在特征集中添加高度坐标,然后序列化到Geojson
EN

Stack Overflow用户
提问于 2020-11-12 03:56:52
回答 1查看 817关注 0票数 0

我非常感谢您的帮助,我使用GeoJson将GeoJson.Net文件反序列化为特性集合。然后我从特性集合中获得该特性。在这个特性中,我可以循环得到所有的几何类型。在那里,我可以循环每个类型并得到坐标。然而,现在我仍然停留在如何编辑,使每个坐标的高度等于0,然后序列化回geojson。

这是我的示例test.geojson文件:

代码语言:javascript
复制
{
  "type": "FeatureCollection",
  "name": "MYS_adm2",
  "crs": { "type": "name", "properties": { "name": "urn:ogc:def:crs:OGC:1.3:CRS84" } },
  "features": [
{
    "type": "Feature",
    "id": 0,    
    "properties": {"party": "Republican","count": "2500"},
    "geometry": {
        "type": "Polygon",
        "coordinates": [[
            [-104.05, 48.99],
            [-97.22,  48.98],
            [-96.58,  45.94],
            [-104.03, 45.94],
            [-104.05, 48.99]
        ]]
    }
},
{
    "type": "Feature",
    "id": 1,
    "properties": {"party": "Democrat","count": "1300"},
    "geometry": {
        "type": "MultiPolygon",
        "coordinates": [[[
            [-109.05, 41.00],
            [-102.06, 40.99],
            [-102.03, 36.99],
            [-109.04, 36.99],
            [-109.05, 41.00]
        ]]]
    }
}
  ]
}

这是我反序列化的代码:

代码语言:javascript
复制
string filePath = @"D:\test.geojson";
            FeatureCollection collection = JsonConvert.DeserializeObject<FeatureCollection>(File.ReadAllText(filePath)); //1 min 21 s
            var feature = collection.Features;
            foreach (var featureItem in feature)
            {
                if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.Point))
                {
                    Point point = featureItem.Geometry as Point;

                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.MultiPoint))
                {

                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.Polygon))
                {
                    Polygon polygon = featureItem.Geometry as Polygon;
                    foreach (var Item in polygon.Coordinates)
                    {
                        foreach (var coordinates in Item.Coordinates)
                        {
                            //Here I want to add value 0 altitude coordinate
                            

                        }
                    }
                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.MultiPolygon))
                {
                    MultiPolygon multiPolygon = featureItem.Geometry as MultiPolygon;
                    foreach (var Item in multiPolygon.Coordinates)
                    {
                        foreach (var item1 in Item.Coordinates)
                        {
                            foreach (var item2 in item1.Coordinates)
                            {
                                //Here I want to add value 0 altitude coordinate
                            }
                        }
                    }
                }
            }

            //here I want to serialize my FeatureCollection after edit
            File.WriteAllText(@"D:\test_Edit.geojson", JsonConvert.SerializeObject(collection));

我的预期输出是添加等于0的高度,如下所示:

代码语言:javascript
复制
{
  "type": "FeatureCollection",
  "name": "MYS_adm2",
  "crs": { "type": "name", "properties": { "name": "urn:ogc:def:crs:OGC:1.3:CRS84" } },
  "features": [
{
    "type": "Feature",
    "id": 0,    
    "properties": {"party": "Republican","count": "2500"},
    "geometry": {
        "type": "Polygon",
        "coordinates": [[
            [-104.05, 48.99, 0],
            [-97.22,  48.98, 0],
            [-96.58,  45.94, 0],
            [-104.03, 45.94, 0],
            [-104.05, 48.99, 0]
        ]]
    }
},
{
    "type": "Feature",
    "id": 1,
    "properties": {"party": "Democrat","count": "1300"},
    "geometry": {
        "type": "MultiPolygon",
        "coordinates": [[[
            [-109.05, 41.00, 0],
            [-102.06, 40.99, 0],
            [-102.03, 36.99, 0],
            [-109.04, 36.99, 0],
            [-109.05, 41.00, 0]
        ]]]
    }
}
  ]
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-12 05:15:23

类型和某些属性在修改时关闭,很可能会保持数据完整性。因此,要更改某些属性的值​​,需要重新创建它们。更改了您的版本后,我得到了以下代码:

代码语言:javascript
复制
static void Main(string[] args)
        {
            string filePath = @"C:\Users\aleks\Documents\test.geojson.txt";
            FeatureCollection collection = JsonConvert.DeserializeObject<FeatureCollection>(File.ReadAllText(filePath)); //1 min 21 s
            var feature = collection.Features;

            var editedFeatures = new List<Feature>();
            IGeometryObject editedObject = null;

            foreach (var featureItem in feature)
            {
                if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.Point))
                {
                    Point point = featureItem.Geometry as Point;
                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.MultiPoint))
                {
                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.Polygon))
                {
                    var polygon = featureItem.Geometry as Polygon;

                    var editedLines = new List<LineString>();
                    foreach (var Item in polygon.Coordinates)
                    {
                        var editedcoordinates = new List<Position>();
                        foreach (var coordinates in Item.Coordinates)
                        {
                            editedcoordinates.Add(new Position(coordinates.Latitude, coordinates.Longitude, 0));
                        }
                        editedLines.Add(new LineString(editedcoordinates));
                    }

                    editedObject = new Polygon(editedLines);
                }
                else if (featureItem.Geometry.Type.Equals(GeoJSONObjectType.MultiPolygon))
                {
                    MultiPolygon multiPolygon = featureItem.Geometry as MultiPolygon;

                    var editedPoligons = new List<Polygon>();
                    foreach (var Item in multiPolygon.Coordinates)
                    {
                        var editedLines = new List<LineString>();
                        foreach (var item1 in Item.Coordinates)
                        {
                            var editedcoordinates = new List<Position>();
                            foreach (var item2 in item1.Coordinates)
                            {
                                editedcoordinates.Add(new Position(item2.Latitude, item2.Longitude, 0));
                            }
                            editedLines.Add(new LineString(editedcoordinates));
                        }
                        editedPoligons.Add(new Polygon(editedLines));
                    }
                    editedObject = new MultiPolygon(editedPoligons);
                }

                if (editedObject != null)
                {
                    editedFeatures.Add(new Feature(editedObject, featureItem.Properties, featureItem.Id));
                }
            }

            var editedCollection = new FeatureCollection(editedFeatures);
            editedCollection.CRS = collection.CRS;
            editedCollection.BoundingBoxes = collection.BoundingBoxes;
            //here I want to serialize my FeatureCollection after edit
            File.WriteAllText(@"C:\Users\aleks\Documents\test_Edit.geojson", JsonConvert.SerializeObject(editedCollection));
        }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64797707

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档