マーカーを一定回数だけ移動させる

説明

マーカーを一定回数だけ移動させるにはsetTimeout()とマーカーオブジェクトのsetPosition()メソッドを使います。移動する回数はカウンタ変数(サンプルではcount)を用意し、一定数以内であればsetTimeout()メソッドを使ってマーカーを移動させる関数を呼び出します。setPosition()はパラメータに緯度経度を指定すれば、指定した場所にマーカーが表示されます。あとは、マーカーの緯度経度を変化させることによりマーカーでアニメーション移動させることができます。

Google Maps APIプログラミング入門 Google Maps API プログラミング入門。Google Maps API Expertである勝又雅史氏が最新のAPI ver3やGoogle Maps for Flashなどについて解説しています。
アマゾンで購入する

サンプルコード [実行]

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>Google Maps API ver 3 Sample/グーグルマップAPIサンプル/Google Maps API样品</title>
<link rel="stylesheet" href="css/main.css" type="text/css" media="all">
<script src="http://maps.google.com/maps/api/js?sensor=false" type="text/javascript"></script>
</head>
<body>
<div id="gmap"></div>
<script type="text/javascript">
var lat = 35.689160610317174;
var lng = 139.70083951950073;
var map = new google.maps.Map(
document.getElementById("gmap"),{
zoom : 10,
center : new google.maps.LatLng(lat, lng),
mapTypeId : google.maps.MapTypeId.ROADMAP
}
);
var marker = new google.maps.Marker({
position: new google.maps.LatLng(lat, lng),
map: map
});
var count = 20;
function moveMarker(){
lat = lat - 0.01;
lng = lng + 0.01;
marker.setPosition(new google.maps.LatLng(lat, lng));
count = count - 1;
if (count > 0) {
setTimeout("moveMarker()", 500);
}
}
moveMarker(); // アニメーション移動開始
</script>
</body>
</html>