制作Google Map mashup的最简单方法是什么?

Mar*_*son 8 html google-maps

给出一个位置列表,如

<td>El Cerrito, CA</td>
<td>Corvallis, OR</td>
<td>Morganton, NC</td>
<td>New York, NY</td>
<td>San Diego, CA</td>
Run Code Online (Sandbox Code Playgroud)

使用每个位置的图钉生成Google Map的最简单方法是什么?

Ber*_*rez 11

我假设您已经使用API​​密钥在代码中拥有了地图的基础知识.

<head>
  <script 
   type="text/javascript"
   href="http://maps.google.com/maps?
         file=api&v=2&key=xxxxx">
  function createMap() {
    var map = new GMap2(document.getElementById("map"));
    map.setCenter(new GLatLng(37.44, -122.14), 14);
  }
  </script>
</head>
<body onload="createMap()" onunload="GUnload()">
Run Code Online (Sandbox Code Playgroud)

Google地图中的所有内容均基于纬度(纬度)和经度(lng).
因此,要创建一个简单的标记,您只需使用lat和lng创建一个GMarker.

var where = new GLatLng(37.925243,-122.307358); //Lat and Lng for El Cerrito, CA
var marker = new GMarker(where); // Create marker (Pinhead thingy)
map.setCenter(where); // Center map on marker
map.addOverlay(marker); // Add marker to map
Run Code Online (Sandbox Code Playgroud)

但是,如果您不想查找每个城市的Lat和Lng,您可以使用Google的地理编码器.下面是一个例子:

var address = "El Cerrito, CA";
var geocoder = new GClientGeocoder;
geocoder.getLatLng(address, function(point) {
  if (point) {
    map.clearOverlays(); // Clear all markers
    map.addOverlay(new GMarker(point)); // Add marker to map
    map.setCenter(point, 10); // Center and zoom map on marker
  }
});
Run Code Online (Sandbox Code Playgroud)

所以我只想从GeoCoder创建一个每个城市的GLatLng数组,然后在地图上绘制它们.


Ada*_*ile 8

查看Google Maps API示例 它们非常简单,API文档非常棒.大多数示例都是在客户端使用JavaScript执行所有代码,但也有其他语言的API可用.