teratail header banner
teratail header banner
質問するログイン新規登録

質問編集履歴

1

ソースコードの追加

2018/01/30 04:04

投稿

ths
ths

スコア21

title CHANGED
File without changes
body CHANGED
@@ -1,1 +1,133 @@
1
- Google Map JavaScript APIをスマホで表示させたいのですが、PC基準のため文字サイズが小さいです。地図中の文字サイズを変更するにはどうすればよいのでしょうか。
1
+ Google Map JavaScript APIをスマホで表示させたいのですが、PC基準のため文字サイズが小さいです。地図中の文字サイズを変更するにはどうすればよいのでしょうか。ちなみに地図を全画面表示にするとちゃんとスマホに適したフォントサイズになります。できれば最初から全画面で表示させたいのですが、調べてやってみても全画面になりません。以下がソースコードと結果の画面を掲載いたします。
2
+
3
+ shelter.html
4
+ ```ここに言語を入力
5
+ <!DOCTYPE html>
6
+ <html>
7
+ <head>
8
+ <title></title>
9
+ <meta charset="utf-8">
10
+ <meta http-equiv="X-UA-Compatible" content="IE=edge">
11
+ <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
12
+
13
+ <link rel="stylesheet" type="text/css" href="../css/lib/bootstrap.css">
14
+ <link rel="stylesheet" type="text/css" href="../css/style.css">
15
+
16
+ <style type="text/css">
17
+ </style>
18
+
19
+ <script type="text/javascript" src="../js/lib/jquery.js"></script>
20
+ <script type="text/javascript" src="../js/lib/bootstrap.js"></script>
21
+ <script type="text/javascript" src="../js/menuBar.js"></script>
22
+
23
+ </head>
24
+ <body onload="initMap()">
25
+ <section id="topBar">Shelter</section>
26
+ <section id="menuBar"></section>
27
+
28
+ <section class="section" id="map"></section>
29
+ <script type="text/javascript" src="../js/shelter.js"></script>
30
+ <script async defer
31
+ src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCtcw7OkAR2a3ItvtPkU53Kh3Z5PTlqK8U">
32
+ </script>
33
+ </body>
34
+ </html>
35
+ ```
36
+
37
+ shelter.js
38
+ ```ここに言語を入力
39
+ // 地図描画処理
40
+ function initMap() {
41
+
42
+ // マーカーにクリックイベントを追加
43
+ function markerEvent(i) {
44
+ marker[i].addListener('click', function() { // マーカーをクリックしたとき
45
+ infoWindow[i].open(map, marker[i]); // 吹き出しの表示
46
+ });
47
+ }
48
+
49
+ var marker = [];
50
+ var infoWindow = [];
51
+ var data = [ //マーカを立てる場所、緯度、経度
52
+ {
53
+ name: 'West Elementary School',
54
+ lat: 36.592415,
55
+ lng: 136.636825
56
+ }
57
+ ];
58
+
59
+
60
+ // Geolocation APIに対応している
61
+ if (navigator.geolocation) {
62
+ // 現在地を取得
63
+ navigator.geolocation.getCurrentPosition(
64
+ // 取得成功した場合
65
+ function(position) {
66
+ // 緯度・経度を変数に格納
67
+ var mapLatLng = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
68
+ // マップオプションを変数に格納
69
+ var mapOptions = {
70
+ zoom : 20, // 拡大倍率
71
+ center : mapLatLng, // 緯度・経度
72
+ };
73
+ // マップオブジェクト作成
74
+ var map = new google.maps.Map(
75
+ document.getElementById("map"), // マップを表示する要素
76
+ mapOptions // マップオプション
77
+ );
78
+ //現在地にマーカーを立てる
79
+ var current = new google.maps.Marker({ // マーカーの追加
80
+ position: mapLatLng, // マーカーを立てる位置を指定
81
+ map: map // マーカーを立てる地図を指定
82
+ });
83
+
84
+
85
+ //マーカー毎の処理
86
+ for (var i = 0; i < data.length; i++) {
87
+ var markerLatLng = new google.maps.LatLng({lat: data[i]['lat'], lng: data[i]['lng']}); // 緯度経度のデータ作成
88
+ marker[i] = new google.maps.Marker({ // マーカーの追加
89
+ position: markerLatLng, // マーカーを立てる位置を指定
90
+ map: map // マーカーを立てる地図を指定
91
+ });
92
+
93
+ infoWindow[i] = new google.maps.InfoWindow({ // 吹き出しの追加
94
+ content: '<div class="mapInfo">' + data[i]['name'] + '</div>' // 吹き出しに表示する内容
95
+ });
96
+
97
+ markerEvent(i); // マーカーにクリックイベントを追加
98
+ }
99
+ },
100
+
101
+ // 取得失敗した場合
102
+ function(error) {
103
+ // エラーメッセージを表示
104
+ switch(error.code) {
105
+ case 1: // PERMISSION_DENIED
106
+ alert("位置情報の利用が許可されていません");
107
+ break;
108
+ case 2: // POSITION_UNAVAILABLE
109
+ alert("現在位置が取得できませんでした");
110
+ break;
111
+ case 3: // TIMEOUT
112
+ alert("タイムアウトになりました");
113
+ break;
114
+ default:
115
+ alert("その他のエラー(エラーコード:"+error.code+")");
116
+ break;
117
+ }
118
+ }
119
+ );
120
+
121
+ // Geolocation APIに対応していない
122
+ } else {
123
+ alert("この端末では位置情報が取得できません");
124
+ }
125
+ }
126
+
127
+ $(function(){
128
+ $('#map').css({"height": $(window).height() - $(window).height()*0. + "px"});
129
+ });
130
+ ```
131
+
132
+ 結果画面
133
+ ![イメージ説明](e6b598c519974246dd08fb3f1a972c97.png)