如何使用反向地理编码获取Mapbox的城市/州/国家/地区?

时间:2015-01-06 03:49:34

标签: geocoding mapbox

我已经阅读了这个API,并根据一些示例测试了很多坐标 https://www.mapbox.com/developers/api/geocoding/

是一个提供大量信息的例子,问题是没有简单的方法来获得我能够找到的城市,州和国家。

http://api.tiles.mapbox.com/v4/geocode/mapbox.places/-114.0701,51.0495.json?access_token=pk.eyJ1IjoibWFyaXNhZmx5bm4iLCJhIjoibG9JcmhrbyJ9.yDc_eDeDW2DeM_JVSQPp7g

我可以得到这样的结果

Mc Lean,22102,Virginia,United States

旧金山,94103,加利福尼亚,美国

伦敦,SW1H6,英国威斯敏斯特市

旧金山,94114,加利福尼亚,美国

珀斯,6053,西澳大利亚,澳大利亚

问题是我必须弄清楚如何解析每个国家的邮政编码(不合理)。

我觉得http://api.tiles.mapbox.com/v4/geocode/mapbox.places/可能是错误的终点。我一度找到了http://api.tiles.mapbox.com/v4/geocode/mapbox.places-country-v1/,但它只会返回国家名称。

如何从Mapbox反向地理编码api查找中获取城市/州/国家/地区数据?

2 个答案:

答案 0 :(得分:3)

我最终根据mapbox返回的内容提出了这个功能。根节点给出城镇/城市,然后给出它周围的上下文。这是一个检查邮政编码的上下文,并在重建字符串时将其排除在外的问题。

                //builds proper format of location string based on mapbox data. city,state/province,country
                function parseReverseGeo(geoData) {
                    // debugger;
                    var region, countryName, placeName, returnStr;
                    if(geoData.context){
                        $.each(geoData.context, function(i, v){
                            if(v.id.indexOf('region') >= 0) {
                                region = v.text;
                            }
                            if(v.id.indexOf('country') >= 0) {
                                countryName = v.text;
                            }
                        });
                    }
                    if(region && countryName) {
                        returnStr = region + ", " + countryName;
                    } else {
                        returnStr = geoData.place_name;
                    }
                    return returnStr;
                }

答案 1 :(得分:0)

与上述相同。当我用来设置地址解析器结果数据的输入字段时,我将使用这种格式。

        placeName = geoData.place_name.split(',');
        $('#addressLine1').val(placeName[1]);

            if(v.id.indexOf('region') >= 0) {
                region = v.text;
                $('input[name="vstate"]').val(region);
            }
            if(v.id.indexOf('postcode') >= 0) {
                postcode = v.text;
                $('input[name="vpostalCode"]').val(postcode);
            }
            if(v.id.indexOf('place') >= 0) {
                city = v.text;
                $('input[name="vcity"]').val(city);
            }               
            if(v.id.indexOf('country') >= 0) {
                countryName = v.text;
                if (countryName.indexOf('United States') > 0) {
                    $('input[name="vcountry"]').val("US");
                }
                if (countryName.indexOf('Canada') > 0) {
                    $('input[name="vcountry"]').val("CA");
                }
                else {
                    $('input[name="vcountry"]').val("US");
                }
            }