説明
イベントを追加するにはGEvent.addListener()を使います。最初のパラメータにイベントを追加するオブジェクトを指定します。このオブジェクトにはマップオブジェクトまたはマーカーオブジェクトを指定することができます。二番目のパラメータにはイベント名を指定します。指定できるイベント名を表1に示します。イベントが発生した際に処理する関数を三番目のパラメータに設定します。イベントが発生した場合には、どの位置でクリックされたか、どのマーカーオブジェクト(オーバーレイ)がクリックされたかがパラメータとして渡されます。発生したイベントと発生したオブジェクトにより渡されるパラメータが異なります(表1参照)。また、ver 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">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<title>Sample</title>
<script src="http://maps.google.com/maps?file=api&v=2&key=ABQIAAAAasAJryKxWJnBFVJa487d9hTHGAxTVT7IRADYa-JdYz7xQ8IQZBSthgDZdggYpQHsmm6WYtHstQFfLA" type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
var msgObj;
window.onload = function() {
msgObj = document.getElementById("result");
map = new GMap2(document.getElementById("gmap"));
map.setCenter(new GLatLng(37, 138), 6);
map.addControl(new GLargeMapControl());
map.addControl(new GMapTypeControl());
GEvent.addListener(map, "move", function(){ msgObj.innerHTML += "move, "; } );
GEvent.addListener(map, "click", function(){ msgObj.innerHTML += "click, "; } );
GEvent.addListener(map, "movestart", function(){ msgObj.innerHTML += "movestart, "; } );
GEvent.addListener(map, "moveend", function(){ msgObj.innerHTML += "moveend, "; } );
GEvent.addListener(map, "zoom", function(){ msgObj.innerHTML += "zoom, "; } );
GEvent.addListener(map, "maptypechanged", function(){ msgObj.innerHTML += "maptypechanged, "; } );
}
//]]>
</script>
</head>
<body>
<div id="gmap" style="width: 500px; height: 400px"></div>
<div id="result"></div>
</body>
</html>