ルート案内できるものを作ってみたいと思っていて、検索して地図にマーカーを立てることはできたのですが、
そのマーカーを使ってルート案内する記述がわかりません。
教えていただけませんか。
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Google Maps</title>
<meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS"/>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false" …
<script type="text/javascript">
var geocoder;
var map;
var markers = [];
function initialize() {
//デフォルト緯度経度を設定する
var myLatlng = new google.maps.LatLng(35.681586, 139.766247);
geocoder = new google.maps.Geocoder();
//オプションを設定
var mapOptions = {
zoom: 12, //拡大率
center: myLatlng //緯度経度
};
//GoogleMapを描写
map = new google.maps.Map(document.getElementById('map-canvas'),mapOptions);
}
function CreateMarker(latlng)
{
var marker = new google.maps.Marker({
position: latlng,
map: map,
draggable: true
});
google.maps.event.addListener(marker, "dragend", UpdateRoute);
return marker;
}
//検索した住所の位置にマーカーを配置
function codeAddress() {
var address = document.getElementById('address').value;
geocoder.geocode( { 'address': address}, function(results, status) {
if (status == google.maps.GeocoderStatus.OK) {
map.setCenter(results[0].geometry.location);
var marker = new google.maps.Marker({
map: map,
position: results[0].geometry.location,
draggable: true
});
markers.push(marker); //マーカーの配列に渡す
} else {
alert('取得に失敗しました'); //存在しない住所の場合はアラート
}
});
}
google.maps.event.addDomListener(window, 'load', initialize); //ページをロードしたらマップを表示
</script>
</head>
<body>
<div id="map-canvas" style="width:80%; height: 600px; border: 1px solid Gray;">
</div></BR>
<div id="panel">
<input id="address" type="text" value="" size="35">
<input type="button" id="button" value="検索" onclick="codeAddress()">
</body>
</html>
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
こんにちは
>そのマーカーを使ってルート案内する記述がわかりません
具体的にはどのような表示方法をイメージなさっているのでしょうか?
よくわからないので、勝手に考えてみると・・・
ルートというからには出発地点と目標地点の二か所が与えられるものと思います。
ご例示のスクリプトでは、住所からジオコーディングしているようですので、それを二か所にするとして、この二点を結ぶルートを求めて表示すれば良いものとして考えてみました。
「googleさんが用意してくれているものは素直に利用しちゃおう」という横着な発想でいけば、2点間を結ぶルートを検索してくれるサービス(Directions Service)がありますのでそれを利用するのが手っ取り早いと思います。
(途中の経由地点を指定したりもできるようです)
https://developers.google.com/maps/documentation …
おや?どうやら、少し新しいサービスに変わっているのかもしれません
https://developers.google.com/maps/documentation …
例によって、リクエストの制限などはありますが、その辺はクリアできるものとして、これを利用することでルートのデータを得ることができます。
ポリライン表示でもよければ、MAP APIのDirectionsRendererを利用することで、得られたデータをマップ上に表示することも可能です。(ライン表示になりますが、この方法が一番簡単だと思います)
https://developers.google.com/maps/documentation …
少し面倒になりますが、得られたルートデータを解析して、途中のポイントにマーカを表示することや自分でオーバーレイを利用してポリラインを引くなどといったことも可能です。
過去の質問で、ルート検索に関するものがありましたので、ご参考までに。
◇スタート地点、ゴール地点を指定(ドラッグで移動)してルートを求める例。
https://oshiete.goo.ne.jp/qa/8159078.html
◇検索したルートを解析し、ルート上を等分割した点にマーカを表示する例。
https://oshiete.goo.ne.jp/qa/8793696.html
https://oshiete.goo.ne.jp/qa/8800586.html
※ map APIを利用するのに、一時期はkeyが無いと利用できなかったようですが、再度、keyがなくても良くなったみたいですね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- JavaScript GoogleChart 階層ごとのブロックの長さを個別に設定したい 1 2022/07/06 14:27
- JavaScript 画像の表示位置 3 2022/12/23 08:25
- JavaScript コードレビューをお願いします。 1 2022/07/16 05:38
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/30 09:10
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript switch文のswitch(n)の部分を複数の値にするか、if文に変えてほしいです。 1 2022/07/27 17:18
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ホームページビルダー16 地図...
-
iPhoneサイトにgooglemapを掲載...
-
LightWindowのサイズがおかしい...
-
map = new google.maps.Mapで作...
-
googlemapsとjavascriptの勉強...
-
マイページはどこを開くの
-
デジタル時計の時刻合わせの方...
-
デスクトップ画面を4分割するには
-
ウインドウを毎回同じ位置、大...
-
Excelでワードアートや図を常に...
-
エクセルのシート上に別のシー...
-
ポップアップウィンドウがブロ...
-
Javascript_submit()完了後に処...
-
5ちゃんねる
-
エクセルVBAでフォームのListbo...
-
【Android】ユーザー補助機能ボ...
-
リストビューをスクロールさせ...
-
スライドショーを全画面でなく...
-
Excelで一部分だけを常に表示さ...
-
PDFを(htmlのように)無限に縦...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Yahoo地図でマーカーを表示した...
-
VBAでオブジェクトがありません...
-
【javascript】住所から郵便番...
-
WordのVBAについて
-
googlemapで複数条件絞り込みで...
-
GoogleMap のマーカーに数値を...
-
GoogleMapsでルート内の座標を...
-
GoogleMapお店の情報をJSONで取...
-
google map の画面サイズを小さ...
-
Google Map Api 複数のマーカ...
-
Google マップにマーカーと同心...
-
逆ジオコーディングについて
-
ホワイトボードに水性顔料マー...
-
spanの位置、サイズを取得したい
-
PHPで入力された住所で地図表示
-
googlemap api で複数マーカー表示
-
ホームページの案内地図をマッ...
-
入力した住所の画面内でグーグ...
-
グーグルマップ(Googlemap)を...
-
Google maps API 吹き出しに画像
おすすめ情報