グーグルマップ

説明

カスタムコントロールを表示するには、コントロールで使用するタグや画像などをinitialize内で指定します。表示する内容はあらかじめHTMLタグとして設定しておく方法とcreateElement()、createTextNode()などを使ってスクリプトで生成する方法があります。どちらを使っても構いません。作成したオブジェクトはGEvent.addDomListener()を使って、クリックされた場合などのイベントを設定します。続きは書籍で、どうぞ...
逆引きGoogle Maps APIリファレンス  詳しい解説などは逆引きGoogle Maps APIリファレンス、またはGoogle Maps APIリファレンスを参照してください。

サンプルコード [実行]

<!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&amp;v=2&amp;key=ABQIAAAAasAJryKxWJnBFVJa487d9hTHGAxTVT7IRADYa-JdYz7xQ8IQZBSthgDZdggYpQHsmm6WYtHstQFfLA" type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
var map;
function customControl() {}
customControl.prototype = new GControl();
customControl.prototype.initialize = function(map) {
var container = document.getElementById("customButton");
var btnDiv = document.getElementById("btn");
GEvent.addDomListener(btnDiv, "click", function() {
map.setCenter(new GLatLng(35.36083, 138.72861), 13);
});
map.getContainer().appendChild(container);
return container;
}
customControl.prototype.getDefaultPosition = function() {
return new GControlPosition(G_ANCHOR_TOP_RIGHT, new GSize(5, 2));
}
window.onload = function() {
map = new GMap2(document.getElementById("gmap"));
map.addControl(new customControl());
map.addControl(new GLargeMapControl());
map.setCenter(new GLatLng(37, 136), 6);
}
//]]>
</script>
</head>
<body>
<div id="gmap" style="width: 500px; height: 400px"></div>
<div id="customButton">
<img id="btn" src="fuji.jpg" />
</div>
</body>
</html>