はじめに
Google Maps(Google Local)のAPIを利用する方法を簡単に紹介しています。今回 は「地図の中にクリックで線を自由に描き、かつ、その座標を表示する方法について」です。スクリプトの変更
前回に作成したコードに1行追加します。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style type="text/css">
v\:*
{
behavior:url(#default#VML);
}
</style>
<script src="http://maps.google.com/maps?file=api&v=1&key=ABQIAAAAJ2A-EncISppmZHF0oZq2MxSIqVgmEE7Z7jvRqG49DJtM7mV-6xQVluTrLna8DIEesDPeKpUSnejCaA" type="text/javascript"></script>
</head>
<body>
<div id="map" style="width: 500px; height: 400px"></div>
<br><br><div id="label_test" style="width: 400px; height: 200px; overflow: scroll; padding: 3px; background-color: white; border: 1px solid black;"></div>
<script type="text/javascript">
//<![CDATA[
var map = new GMap(document.getElementById("map"));
map.addControl(new GSmallMapControl());
map.addControl(new GMapTypeControl());
map.centerAndZoom(new GPoint(135.3659722, 34.72072222), 4);
function AddGMarker(objMap,nLatitude,nLongitude,strHtml)
{
var objPoint = new GPoint(nLatitude,nLongitude);
var objMarker = new GMarker(objPoint);
GEvent.addListener(objMarker,"click",function(){ objMarker.openInfoWindowHtml(strHtml); });
objMap.addOverlay(objMarker);
}
AddGMarker(map,135.3659722,34.72072222,"<img src=http://www.dinop.com/google/map/use_html_comment_test.gif align=left>甲子園駅<br><br><a href=http://www.hanshintigers.jp/ target=_blank>阪神タイガース</a>の本拠地としても知<br>られる甲子園球場の目の前にあり<br>ます。<br clear=left>");
AddGMarker(map,135.3585277,34.70730555,"甲子園浜");
var aobjPoints =
[
new GPoint(135.3659722,34.72072222),
new GPoint(135.3585277,34.70730555)
];
var objLine = new GPolyline(aobjPoints,'#FF0000');
map.addOverlay(objLine);
GEvent.addListener(map, 'click', function(objOverlay, objPoint)
{
if(objPoint)
{
map.removeOverlay(objLine);
aobjPoints.length++;
aobjPoints[aobjPoints.length - 1] = new GPoint(objPoint.x,objPoint.y);
objLine = new GPolyline(aobjPoints,'#FF0000');
map.addOverlay(objLine);
document.getElementById("label_test").innerHTML += objPoint.x + ',' + objPoint.y + "<br>";
}
});
//]]>
</script>
</body>
</html>
赤字が追加した部分です。太字の部分はAPI Keyです(人それぞれ異なる値です)。
実際に動かして地図の中をクリックすると、どんどん線が新しく追加されると同時に地図下部に座標が 一覧されます(甲子園駅と甲子園浜間にも線が引かれていますがその座標は表示されません)。







