0

我读了这篇文章,但现在我无法根据我的情况使用它。

给定以下 Google Maps JSON 字符串(我使用的是 中使用的数据结构Blitzmap.js):

{
   "zoom":12,
   "overlays":[
      {
         "type": "polygon",
         "paths":[
            [
               { "lat":52.06630340325415, "lng":5.749811642494365 },
               { "lat":52.066277072534014, "lng":5.758523457374736 },
               { "lat":52.06306460782621, "lng":5.758544915046855 },
               { "lat":52.063011942539184, "lng":5.749811642494365 }
            ]
         ]
      }
   ],
   "center":{ "lat":52.06465767289667, "lng":5.75417827877061 }
}

使用Newtonsoft.JSON时,我可以这样做:

dynamic mapObjectsAsDynamic = (JObject)formPostedData.MapObjects;
foreach (var overlay in mapObjectsAsDynamic.overlays)
{
    if (overlay.type == "polygon")
    {
        foreach (var pathpart in overlay.paths)
        {
            foreach (var pathItem in pathpart.Children())
            {
                ... = pathItem.lat;
                ... = pathItem.lng;
            }
        }
    }
}

现在我喜欢使用 ServiceStack 的 JSON 解析器(ServiceStack.Text),但我被困在paths.

我试过:

var mapObjectsAsJsonObject = JsonObject.Parse(request.MapObjects);
var trial1 = mapObjectsAsJsonObject.ArrayObjects("overlays");
var trial2 = trial1[0].ArrayObjects("paths");

有没有类似的 Newtonsoft 方式?

4

1 回答 1

1

您可以使用.JsonTo<T>扩展方法将您的paths密钥转换为 aPoint[][]然后您可以轻松地遍历集合。

简单Point类:

public class Point
{
    public float lat { get; set; }
    public float lng { get; set; }
}

用法(与您在 JSON.NET 中的用法类似)

var mapObjects = JsonObject.Parse(request.MapObjects);

foreach(var overlay in mapObjects.ArrayObjects("overlays"))
{
    if(overlay.Get("type")=="polygon")
    {
        foreach(var pathPart in overlay.JsonTo<Point[][]>("paths"))
        {
            foreach(var pathItem in pathPart)
            {
                Console.WriteLine(pathItem.lat);
                Console.WriteLine(pathItem.lng);
            }
        }
    }
}

我希望这有帮助。

于 2013-12-18T15:56:31.337 回答