如何使用Google Maps API v3在地图上显示多个城市

时间:2012-10-01 14:17:02

标签: php json google-maps-api-3

我有一个像php这样的城市列表:

$cities = array(0=>"Absecon,NJ",1=>"Alamogordo,NJ",2=>"Atlantic city,NJ....);

我必须在地图上显示我的所有城市,如果我没有lat和lon可以吗?

我用这种方式初始化地图:

<!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map_canvas { height: 100% }
    </style>
    <script type="text/javascript"
      src="http://maps.googleapis.com/maps/api/js?key=MY_API_KEY&sensor=true">
    </script>
    <script type="text/javascript">
      function initialize() {
        var countries = '<?php echo json_enconde($cities);?>';
        var mapOptions = {
          center: new google.maps.LatLng(-34.397, 150.644),
          zoom: 2,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),mapOptions);
      }
    </script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:100%; height:100%"></div>
  </body>
</html>

1 个答案:

答案 0 :(得分:2)

那些看起来不像国家&#34;对我来说,你的例子似乎是美国的城市或城镇(如标题所示)。

Geocoding web service将返回地名的地理坐标,但受限于配额和费率限制。

通常的建议是离线对地点进行地理编码,存储生成的坐标并使用它们来显示地图。

Here是地理编码策略文档中的一篇文章。