マーカーを貼り付ける(2)
前述したマーカー貼り付け例では、デフォルトのマーカーを使っていましたが、ここでは自作の画像をマーカーとして利用する方法を説明したいと思います。
サンプル
以下のサンプルは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>
<title>Google Maps JavaScript API Example - simple</title>
<script src="http://maps.google.com/maps?file=api&v=1&key=aaaaa"
type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div id="map" style="width: 500px; height: 450px"></div>
<script type="text/javascript">
//<![CDATA[
if (GBrowserIsCompatible()) {
var map = new GMap(document.getElementById("map"));
var point = new GPoint(139.15, 36.033333);
map.centerAndZoom(point, 7);
point.x = point.x + 0.1;
point.y = point.y + 0.1;
var icon = new GIcon();
icon.image = "http://www.geekpage.jp/img/geek-title.png";
icon.iconSize = new GSize(240, 40);
icon.iconAnchor = new GPoint(0, 0);
var marker = new GMarker(point, icon);
map.addOverlay(marker);
}
//]]>
</script>
</body>
</html>
前述した例では、new GMarker(GPoint)でGMarkerを作成していましたが、今回はnew GMarker(GPoint, GIcon)で作成しています。 GMarkerにGIconを第二引数として渡すとGMarkerとして表示される画像を指定できます。
GIconはnew GIconで生成した後にいくつか設定をおこなわなければなりません。 まず、画像ファイルを指定しなければいけませんが、ここでは"http://www.geekpage.jp/img/geek-title.png"という画像をマーカーに使ってみました。 次に、画像を表示する大きさを指定しなければなりません。 ここでは、とりあえずGSize(240, 40)としました。 最後に、マーカーが表示される位置を指定しなければなりません。 この位置とは、マーカーが配置される緯度/経度からの相対距離になります。 GIconにはその他にも設定項目がありますが、上記3つの項目を最低限設定すれば表示されるようです。
表示例
表示例です。