ルート検索で表示される情報ウィンドウの内容を書き換える

説明

ルート検索で表示される情報ウィンドウの内容を書き換える事は基本的にはできないようです。情報ウィンドウにアクセスするための手段が用意されていないためです。しかし、ページ内に表示された後であれば、情報ウィンドウに関する何かを探し出して内容を書き換えることは可能です。バージョンが変われば使えなくなる恐れがあるのと日本語限定になりますが、マップが表示されている中にあるdivタグでstyleにdirection:ltrが設定されているものを探し出します。そのdivタグの内容をinnerHTMLを使って書き換えれば、ルート検索で表示された情報ウィンドウの内容を書き換えることができます。ただし、無理矢理かきかえているため、今後のAPIのマイナーアップデート等で使えなくなる可能性があります。

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>
<div id="result"></div>
<div><a href="#" onclick="changeText()">無理矢理、情報ウィンドウの内容を現在時刻に書き換える</a></div>
<script type="text/javascript">
var directionsService = new google.maps.DirectionsService();
var directionsDisplay = new google.maps.DirectionsRenderer({draggable: true});
var map = new google.maps.Map(
document.getElementById("gmap"),{
zoom : 8,
center : new google.maps.LatLng(35.689160610317174, 139.70083951950073),
mapTypeId : google.maps.MapTypeId.ROADMAP
}
);
google.maps.event.addListener(directionsDisplay, "directions_changed", function() {
calcRoute(directionsDisplay.directions);
});
directionsDisplay.setMap(map);
directionsService.route({
origin : "新宿駅",
waypoints: [ { location: "鈴鹿駅" }, { location :"名古屋駅" } ],
destination: "新潟駅",
travelMode: google.maps.DirectionsTravelMode.DRIVING
}, function(response, status){
if (status == google.maps.DirectionsStatus.OK) {
directionsDisplay.setDirections(response);
calcRoute(response);
}else{
alert("ルート検索に失敗しました");
}
});
function calcRoute(response){
var m = 0;
for(var i=0; i<response.routes[0].legs.length; i++){
m += response.routes[0].legs[i].distance.value; // 距離(m)
}
document.getElementById("result").innerHTML = m+"メートル";
}
// 情報ウィンドウを探し出して現在時刻に書き換える
function changeText(){
var iwList = document.getElementById("gmap").getElementsByTagName("div");
for(var i=0; i<iwList.length; i++){
if (iwList[i].style.direction == "ltr"){
iwList[i].innerHTML = new Date();
}
}
}
</script>
</body>
</html>