我正在开发一个应用程序,它将找到两点之间的方向,将其显示在谷歌地图上并将其存储在服务器端,以便我可以在需要时再次渲染它,并将一条路线与另一条路线进行比较。
我已成功使用google maps api web serivce查找路线,并且我还使用google maps javascript v3查找路线并使用DirectionsRenderer将其显示在地图上。
这两个服务都返回相似的 JSON,但 JSON 的属性名称不同(参见下面的示例 1)。更重要的是,JS api 从一个调用到另一个调用返回不同的 lat/lng 属性名称(参见下面的示例 2)。
所以问题是我不能使用从服务器端 Web 服务调用获得的 JSON 并将其直接传递给 javascripts DirectionRenderer 类来显示路由。此外,每次在地图上显示路线时,我都必须进行 JS 调用。这将导致不必要地使用我的配额。有没有更好的方法来做到这一点。我已经解决了以下问题,但我实际上无法在这里和这里得到答案
示例 1:
网络服务调用结果:
{
"routes" : [
{
"bounds" : {
"northeast" : {
"lat" : 12.9198217,
"lng" : 77.6124895
},
"southwest" : {
"lat" : 12.912811,
"lng" : 77.60924989999999
}
},
.....
这没有“路径”属性。
Javascript V3 调用结果:
{
"routes": [
{
"bounds": {
"ta": {
"d": 12.91281,
"b": 12.919820000000001
},
"ga": {
"b": 77.60925,
"d": 77.61249000000001
}
},
......
"path": [
{
"d": 12.913920000000001,
"e": 77.60928000000001
},
{
"d": 12.913960000000001,
"e": 77.60958000000001
},
{
"d": 12.91398,
"e": 77.61
}
],
..........
示例 2: 另一个 Javascript V3 调用结果:
{
"routes": [
{
"bounds": {
"Aa": {
"k": 12.91281,
"j": 12.919820000000001
},
"qa": {
"j": 77.60925,
"k": 77.61249000000001
}
},
.....
"path": [
{
"k": 12.91281,
"A": 77.60925
},
{
"k": 12.913920000000001,
"A": 77.60928000000001
}
],
.........