質問編集履歴
2
質問内容の復元
title
CHANGED
File without changes
|
body
CHANGED
@@ -1,9 +1,120 @@
|
|
1
1
|
###前提・実現したいこと
|
2
|
-
|
2
|
+
googleMapを活用して移動経路の記録をマップ上で行いたいと考えています。
|
3
|
+
現時点では、geoLocation(watchPosition)を活用して位置情報を常に追跡し、マップに表示させています。
|
3
4
|
googleMapを活用して移動経路の表示をしたいです。
|
4
|
-
|
5
|
+
今悩んでいることは、サーバーへの位置情報データの格納方法と、**移動経路を線で結ぶことです**。
|
5
|
-
|
6
|
+
線を結んでいくタイミングは、「移動するごとに常に線を表示」または「位置情報をまとめて最後に線を結ぶ」どちらでも構いません。初心者でも理解が早いほうが嬉しいです。
|
6
|
-
|
7
|
+
Polylineを活用すると予想していますが、もっとふさわしいものがあれば教えていただきたいです。
|
8
|
+
サンプルや、参考になるページ等ご存じでしたらお願いします。
|
7
9
|
###該当のソースコード
|
8
|
-
|
9
|
-
|
10
|
+
/*html*/
|
11
|
+
<!DOCTYPE html>
|
12
|
+
<html>
|
13
|
+
<head>
|
14
|
+
<meta charset="UTF-8">
|
15
|
+
<meta name="robots" content="noindex,nofollow">
|
16
|
+
<!-- ビューポートの設定 -->
|
17
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
18
|
+
<link href="./css/geolocation-api.css" rel="stylesheet">
|
19
|
+
<script scr="ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
|
20
|
+
<script async defer
|
21
|
+
src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCE7BTRiGM6545NJFw3Mq0xVhVWrD-dLZ0&callback=initMap">
|
22
|
+
</script>
|
23
|
+
<script src="./js/plotMap.js "></script>
|
24
|
+
|
25
|
+
<title>Plot Map</title>
|
26
|
+
</head>
|
27
|
+
<body onload="Init()">
|
28
|
+
<div class="map-wrapper">
|
29
|
+
<div id="map-canvas"></div>
|
30
|
+
</div>
|
31
|
+
|
32
|
+
<h2>取得したデータ</h2>
|
33
|
+
<dl id="result"></dl>
|
34
|
+
|
35
|
+
</body>
|
36
|
+
</html>
|
37
|
+
|
38
|
+
|
39
|
+
|
40
|
+
|
41
|
+
|
42
|
+
/*JavaScript*/
|
43
|
+
// グローバル変数
|
44
|
+
|
45
|
+
var syncerWatchPosition = {
|
46
|
+
count: 0 ,
|
47
|
+
lastTime: 0 ,
|
48
|
+
map: null ,
|
49
|
+
marker: null ,
|
50
|
+
} ;
|
51
|
+
|
52
|
+
// 成功した時の関数
|
53
|
+
function successFunc( position )
|
54
|
+
{
|
55
|
+
// データの更新
|
56
|
+
++syncerWatchPosition.count ; // 処理回数
|
57
|
+
|
58
|
+
// HTMLに書き出し
|
59
|
+
document.getElementById( 'result' ).innerHTML = '<dt>緯度</dt><dd>' + position.coords.latitude + '</dd><dt>経度</dt><dd>' + position.coords.longitude + '</dd><dt>高度</dt><dd>' + position.coords.altitude + '</dd><dt>速度</dt><dd>' + position.coords.speed + '</dd><dt>実行回数</dt><dd>' + syncerWatchPosition.count + '回</dd>' ;
|
60
|
+
|
61
|
+
// 位置情報
|
62
|
+
var latlng = new google.maps.LatLng( position.coords.latitude , position.coords.longitude ) ;
|
63
|
+
|
64
|
+
|
65
|
+
// Google Mapsに書き出し
|
66
|
+
//if( syncerWatchPosition.map == null )
|
67
|
+
//{
|
68
|
+
// 地図の新規出力
|
69
|
+
syncerWatchPosition.map = new google.maps.Map( document.getElementById( 'map-canvas' ) , {
|
70
|
+
zoom: 17 , // ズーム値
|
71
|
+
center: latlng , // 中心座標 [latlng]
|
72
|
+
} ) ;
|
73
|
+
|
74
|
+
// マーカーの新規出力
|
75
|
+
syncerWatchPosition.marker = new google.maps.Marker( {
|
76
|
+
map: syncerWatchPosition.map ,
|
77
|
+
position: latlng ,
|
78
|
+
} ) ;
|
79
|
+
map.drawRoute({
|
80
|
+
origin: [-12.044012922866312, -77.02470665341184],
|
81
|
+
destination: latlng,
|
82
|
+
travelMode: 'driving',
|
83
|
+
strokeColor: '#131540',
|
84
|
+
strokeOpacity: 0.6,
|
85
|
+
strokeWeight: 6
|
86
|
+
});
|
87
|
+
//}
|
88
|
+
|
89
|
+
}
|
90
|
+
|
91
|
+
// 失敗した時の関数
|
92
|
+
function errorFunc( error )
|
93
|
+
{
|
94
|
+
// エラーコードのメッセージを定義
|
95
|
+
var errorMessage = {
|
96
|
+
0: "原因不明のエラーが発生しました…。" ,
|
97
|
+
1: "位置情報の取得が許可されませんでした…。" ,
|
98
|
+
2: "電波状況などで位置情報が取得できませんでした…。" ,
|
99
|
+
3: "位置情報の取得に時間がかかり過ぎてタイムアウトしました…。" ,
|
100
|
+
} ;
|
101
|
+
|
102
|
+
// エラーコードに合わせたエラー内容を表示
|
103
|
+
alert( errorMessage[error.code] ) ;
|
104
|
+
}
|
105
|
+
|
106
|
+
// オプション・オブジェクト
|
107
|
+
var optionObj = {
|
108
|
+
"enableHighAccuracy": false ,
|
109
|
+
//"timeout": 1000000 ,
|
110
|
+
//"maximumAge": 0 ,
|
111
|
+
} ;
|
112
|
+
|
113
|
+
function Init(){
|
114
|
+
// 現在位置を取得する
|
115
|
+
navigator.geolocation.watchPosition( successFunc , errorFunc , optionObj ) ;
|
116
|
+
}
|
117
|
+
###補足情報
|
118
|
+
※プログラミング初心者です。
|
119
|
+
筋の通っていない内容や、無駄な記述などが多数見受けられると思いますがどうぞよろしくお願いいたします。
|
120
|
+
後で確認できるように無駄な記述も「//」で残してあります。ご了承ください。
|
1
質問内容の変更
title
CHANGED
File without changes
|
body
CHANGED
@@ -1,124 +1,9 @@
|
|
1
1
|
###前提・実現したいこと
|
2
2
|
|
3
|
-
googleMapを活用して移動経路の
|
3
|
+
googleMapを活用して移動経路の表示をしたいです。
|
4
|
-
現時点では、geoLocation(watchPosition)を活用して位置情報を常に追跡し、マップに表示させています。
|
5
4
|
|
6
|
-
今悩んでいることは、サーバーへの位置情報データの格納方法と、**移動経路を線で結ぶことです**。
|
7
|
-
線を結んでいくタイミングは、「移動するごとに常に線を表示」または「位置情報をまとめて最後に線を結ぶ」どちらでも構いません。初心者でも理解が早いほうが嬉しいです。
|
8
|
-
Polylineを活用すると予想していますが、もっとふさわしいものがあれば教えていただきたいです。
|
9
|
-
サンプルや、参考になるページ等ご存じでしたらお願いします。
|
10
5
|
|
11
6
|
|
12
7
|
###該当のソースコード
|
13
|
-
/*html*/
|
14
|
-
<!DOCTYPE html>
|
15
|
-
<html>
|
16
|
-
<head>
|
17
|
-
<meta charset="UTF-8">
|
18
|
-
<meta name="robots" content="noindex,nofollow">
|
19
|
-
<!-- ビューポートの設定 -->
|
20
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
21
|
-
<link href="./css/geolocation-api.css" rel="stylesheet">
|
22
|
-
<script scr="ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
|
23
|
-
<script async defer
|
24
|
-
src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCE7BTRiGM6545NJFw3Mq0xVhVWrD-dLZ0&callback=initMap">
|
25
|
-
</script>
|
26
|
-
<script src="./js/plotMap.js "></script>
|
27
8
|
|
28
|
-
|
29
|
-
</head>
|
30
|
-
<body onload="Init()">
|
31
|
-
<div class="map-wrapper">
|
32
|
-
<div id="map-canvas"></div>
|
33
|
-
</div>
|
34
|
-
|
35
|
-
<h2>取得したデータ</h2>
|
36
|
-
<dl id="result"></dl>
|
37
|
-
|
38
|
-
</body>
|
39
|
-
</html>
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
/*JavaScript*/
|
46
|
-
// グローバル変数
|
47
|
-
|
48
|
-
var syncerWatchPosition = {
|
49
|
-
count: 0 ,
|
50
|
-
lastTime: 0 ,
|
51
|
-
map: null ,
|
52
|
-
marker: null ,
|
53
|
-
} ;
|
54
|
-
|
55
|
-
// 成功した時の関数
|
56
|
-
function successFunc( position )
|
57
|
-
{
|
58
|
-
// データの更新
|
59
|
-
++syncerWatchPosition.count ; // 処理回数
|
60
|
-
|
61
|
-
// HTMLに書き出し
|
62
|
-
document.getElementById( 'result' ).innerHTML = '<dt>緯度</dt><dd>' + position.coords.latitude + '</dd><dt>経度</dt><dd>' + position.coords.longitude + '</dd><dt>高度</dt><dd>' + position.coords.altitude + '</dd><dt>速度</dt><dd>' + position.coords.speed + '</dd><dt>実行回数</dt><dd>' + syncerWatchPosition.count + '回</dd>' ;
|
63
|
-
|
64
|
-
// 位置情報
|
65
|
-
var latlng = new google.maps.LatLng( position.coords.latitude , position.coords.longitude ) ;
|
66
|
-
|
67
|
-
|
68
|
-
// Google Mapsに書き出し
|
69
|
-
//if( syncerWatchPosition.map == null )
|
70
|
-
//{
|
71
|
-
// 地図の新規出力
|
72
|
-
syncerWatchPosition.map = new google.maps.Map( document.getElementById( 'map-canvas' ) , {
|
73
|
-
zoom: 17 , // ズーム値
|
74
|
-
center: latlng , // 中心座標 [latlng]
|
75
|
-
} ) ;
|
76
|
-
|
77
|
-
// マーカーの新規出力
|
78
|
-
syncerWatchPosition.marker = new google.maps.Marker( {
|
79
|
-
map: syncerWatchPosition.map ,
|
80
|
-
position: latlng ,
|
81
|
-
} ) ;
|
82
|
-
map.drawRoute({
|
83
|
-
origin: [-12.044012922866312, -77.02470665341184],
|
84
|
-
destination: latlng,
|
85
|
-
travelMode: 'driving',
|
86
|
-
strokeColor: '#131540',
|
87
|
-
strokeOpacity: 0.6,
|
88
|
-
strokeWeight: 6
|
89
|
-
});
|
90
|
-
//}
|
91
|
-
|
92
|
-
}
|
93
|
-
|
94
|
-
// 失敗した時の関数
|
95
|
-
function errorFunc( error )
|
96
|
-
{
|
97
|
-
// エラーコードのメッセージを定義
|
98
|
-
var errorMessage = {
|
99
|
-
0: "原因不明のエラーが発生しました…。" ,
|
100
|
-
1: "位置情報の取得が許可されませんでした…。" ,
|
101
|
-
2: "電波状況などで位置情報が取得できませんでした…。" ,
|
102
|
-
3: "位置情報の取得に時間がかかり過ぎてタイムアウトしました…。" ,
|
103
|
-
} ;
|
104
|
-
|
105
|
-
// エラーコードに合わせたエラー内容を表示
|
106
|
-
alert( errorMessage[error.code] ) ;
|
107
|
-
}
|
108
|
-
|
109
|
-
// オプション・オブジェクト
|
110
|
-
var optionObj = {
|
111
|
-
"enableHighAccuracy": false ,
|
112
|
-
//"timeout": 1000000 ,
|
113
|
-
//"maximumAge": 0 ,
|
114
|
-
} ;
|
115
|
-
|
116
|
-
function Init(){
|
117
|
-
// 現在位置を取得する
|
118
|
-
navigator.geolocation.watchPosition( successFunc , errorFunc , optionObj ) ;
|
119
|
-
}
|
120
|
-
|
121
|
-
###補足情報
|
122
|
-
※プログラミング初心者です。
|
123
|
-
筋の通っていない内容や、無駄な記述などが多数見受けられると思いますがどうぞよろしくお願いいたします。
|
124
|
-
後で確認できるように無駄な記述も「//」で残してあります。ご了承ください。
|
9
|
+
###補足情報
|