[スクリプトの概要]
ボタンを押すことで、指定した場所にマーカーを配置し、指定したズーム値で地図を表示します。
同時に写真と文章の切り替えを行います。

  1. //=============================================================================
  2. var map;
  3. var markerS = new Array();
  4. var mapPosS = new Array();
  5. var mapNameS = new Array();
  6. var cirRadiusS = new Array();
  7. var zoomValS = new Array();
  8. var mapCenS = new Array();
  9. var mapArea = document.getElementById('mainmap');
  10. var circle;
  11. var addMarkerCount = 1; //最初のマーカー追加用カウンタ
  12. //=============================================================================
  13. //マップの初期化
  14. function initMap() {
  15. mapPosS[00] = {lat: 34.390000, lng: 134.820000}; mapNameS[00] = "マップセンター"; cirRadiusS[00] = 0; zoomValS[00] = 10.9; mapCenS[00] = {lat: 34.390000, lng: 134.820000};
  16. mapPosS[01] = {lat: 34.583912, lng: 135.017080}; mapNameS[01] = "淡路SA大観覧車"; cirRadiusS[01] = 0; zoomValS[01] = 17; mapCenS[01] = {lat: 34.583912, lng: 135.017080};
  17. mapPosS[02] = {lat: 34.579283, lng: 135.013377}; mapNameS[02] = "ハイウェイオアシス物産館"; cirRadiusS[02] = 614; zoomValS[02] = 16.5; mapCenS[02] = {lat: 34.581597, lng: 135.015228};
  18. mapPosS[03] = {lat: 34.577365, lng: 135.011188}; mapNameS[03] = "ニジゲンノモリ入口"; cirRadiusS[03] = 916; zoomValS[03] = 16.2; mapCenS[03] = {lat: 34.580638, lng: 135.014134};
  19. mapPosS[04] = {lat: 34.574405, lng: 135.006664}; mapNameS[04] = "県立淡路島公園"; cirRadiusS[04] = 1430; zoomValS[04] = 15.5; mapCenS[04] = {lat: 34.579158, lng: 135.011872};
  20. mapPosS[05] = {lat: 34.563890, lng: 135.010062}; mapNameS[05] = "淡路夢舞台"; cirRadiusS[05] = 2340; zoomValS[05] = 15.0; mapCenS[05] = {lat: 34.573901, lng: 135.013571};
  21. mapPosS[06] = {lat: 34.549648, lng: 134.937659}; mapNameS[06] = "北淡震災記念公園"; cirRadiusS[06] = 8222; zoomValS[06] = 13; mapCenS[06] = {lat: 34.566780, lng: 134.977369};
  22. mapPosS[07] = {lat: 34.504561, lng: 134.908336}; mapNameS[07] = "五斗長垣内遺跡"; cirRadiusS[07] = 13345; zoomValS[07] = 12.6; mapCenS[07] = {lat: 34.544236, lng: 134.962708};
  23. mapPosS[08] = {lat: 34.416056, lng: 134.792714}; mapNameS[08] = "ウェルネスパーク五色"; cirRadiusS[08] = 27810; zoomValS[08] = 11.5; mapCenS[08] = {lat: 34.499984, lng: 134.904897};
  24. mapPosS[09] = {lat: 34.302126, lng: 134.740386}; mapNameS[09] = "陸の港西淡"; cirRadiusS[09] = 40375; zoomValS[09] = 11.2; mapCenS[09] = {lat: 34.443019, lng: 134.878733};
  25. mapPosS[10] = {lat: 34.241754, lng: 134.658892}; mapNameS[10] = "門崎(鳴門海峡)"; cirRadiusS[10] = 50331; zoomValS[10] = 10.9; mapCenS[10] = {lat: 34.390000, lng: 134.820000};
  26. var mapOptions = {
  27. center: mapPosS[0],
  28. zoom: 10.9,
  29. };
  30. map = new google.maps.Map(mapArea, mapOptions);
  31. //マーカーの定義
  32. for (var i=0; i<11; i++) {
  33. markerS[i] = new google.maps.Marker({
  34. position: mapPosS[i],
  35. animation: google.maps.Animation.DROP,
  36. title: mapNameS[i]
  37. });
  38. }
  39. addMarker();
  40. circle = new google.maps.Circle({
  41. center: new google.maps.LatLng(34.583912, 135.017080),
  42. map: map,
  43. radius: cirRadiusS[1],
  44. fillColor: '#FF8800',
  45. fillOpacity: 0.1,
  46. strokeColor: '#FF8800',
  47. strokeOpacity: 0.8,
  48. strokeWeight: 2
  49. });
  50. }
  51. //最初のマーカーの配置
  52. function addMarker() {
  53. markerS[addMarkerCount].setMap(map);
  54. addMarkerCount ++;
  55. if(addMarkerCount < 11) {
  56. setTimeout(addMarker, 50);
  57. }
  58. }
  59. //サークルを表示
  60. function dispCircle(num) {
  61. circle.setMap(null);
  62. if(num > 1) {
  63. circle = new google.maps.Circle({
  64. center: new google.maps.LatLng(34.583912, 135.017080),
  65. map: map,
  66. radius: cirRadiusS[num],
  67. fillColor: '#FF8800',
  68. fillOpacity: 0.1,
  69. strokeColor: '#FF8800',
  70. strokeOpacity: 0.8,
  71. strokeWeight: 2
  72. });
  73. }
  74. map.setZoom(zoomValS[num]);
  75. map.setCenter(mapCenS[num]);
  76. //必要なマーカーのみ表示
  77. for (var i=0; i<11; i++) {
  78. markerS[i].visible = false;
  79. }
  80. dispValueData(num);
  81. dispPlaceData(num);
  82. }
  83. //数値データを表示
  84. function dispValueData(num) {
  85. var str = "---";
  86. switch(num) {
  87. case 0:
  88. str = "---";
  89. for (var i=0; i<11; i++) {
  90. markerS[i].visible = true;
  91. }
  92. break;
  93. case 1:
  94. str = "太陽(直径139万km)を淡路SA大観覧車のところに置くと、直径12.5mの球体に相当します。";
  95. break;
  96. case 2:
  97. str = "水星(距離5,800万km、直径約5,000km) は、520m離れた「ハイウェイオアシス物産館」にある「直径4cmの玉」になります。";
  98. break;
  99. case 3:
  100. str = "金星(距離1億800万km、直径約12,100km) は、970m離れた「ニジゲンノモリ入口」にある「直径11cmの玉」になります。";
  101. break;
  102. case 4:
  103. str = "地球(距離1億5000万km、直径約12,700km) は、1.3km離れた「県立淡路島公園」にある「直径11cmの玉」になります。";
  104. break;
  105. case 5:
  106. str = "火星(距離2億2800万km、直径約6,800km) は、2.1km離れた「淡路夢舞台 野外劇場」にある「直径6cmの玉」になります。";
  107. break;
  108. case 6:
  109. str = "木星(距離7億8000万km、直径約143,000km) は、7.0km離れた「北淡震災記念公園」にある「直径1.3mの玉」になります。";
  110. break;
  111. case 7:
  112. str = "土星(距離14億3000万km、直径約120,000km) は、12.8km離れた「五斗長垣内遺跡」にある「直径1.1mの玉」になります。";
  113. break;
  114. case 8:
  115. str = "天王星(距離28億7500万km、直径約51,000km) は、25.8km離れた「ウェルネスパーク五色」にある「直径46cmの玉」になります。";
  116. break;
  117. case 9:
  118. str = "海王星(距離45億km、直径約50,000km) は、40km離れた「陸の港西淡」にある「直径45cmの玉」になります。";
  119. break;
  120. case 10:
  121. str = "冥王星(距離59億km、直径約2,370km) は、53km離れた「門崎(鳴門海峡)」にある「直径2cmの玉」になります。";
  122. break;
  123. }
  124. markerS[1].visible = true;
  125. markerS[num].visible = true;
  126. var txtArea = document.getElementById('valuedata');
  127. txtArea.innerHTML = " " + str + "
  128. ";
  129. }
  130. //場所紹介文を表示
  131. function dispPlaceData(num) {
  132. var filename1 = "nophoto.jpg";
  133. var filename2 = "nophoto.jpg";
  134. var explainst = "---";
  135. switch(num) {
  136. case 1: //淡路SA大観覧車
  137. explainst = "淡路島の北の玄関口、淡路サービスエリアにある大観覧車です。
  138. ";
  139. explainst += "サービスエリア内に設置されている観覧車としては日本初のものです。
  140. ";
  141. explainst += "直径65m、海抜135mの頂上からは明石海峡大橋や、神戸空港が見渡せます。
  142. ";
  143. explainst += "ゴンドラの一部には等身大のわたるくん(マスコットキャラ)やアンパンマンのぬいぐるみが乗せられています。
  144. ";
  145. break;
  146. case 2: //ハイウェイオアシス物産館
  147. explainst = "淡路サービスエリアは上りと下りが自由に行き来可能で、その中間地点にあるのがこの物産館です。
  148. ";
  149. explainst += "1階はたまねぎをはじめ、海産物などの名産品のお土産が売られています。
  150. ";
  151. explainst += "2階はレストランになっていて、新鮮な肉、魚、野菜のメニューが充実しています。
  152. ";
  153. explainst += "ここからも明石海峡大橋が一望できます。
  154. ";
  155. break;
  156. case 3: //ニジゲンノモリ入口
  157. explainst = "兵庫県立淡路島公園内にあるアニメ、テクノロジー、自然をテーマとした新感覚テーマパーク。
  158. ";
  159. explainst += "さまざまなアトラクションやイベント、アニメキャラクター関連のショッピング、
  160. ";
  161. explainst += "きれいな夜空を楽しみながら宿泊まで、大人も子供もがっつり楽しめるスポットです。
  162. ";
  163. explainst += "写真はプロジェクションマッピングを使ったナイトウォーク入口付近の、昼間の風景です。
  164. ";
  165. break;
  166. case 4: //県立淡路島公園
  167. explainst = "淡路島の北部に位置する、兵庫県立淡路島公園。自然に囲まれた東京ドームの28個分の敷地には、
  168. ";
  169. explainst += "「ハイウェイオアシスゾーン」「森のゾーン」「交流ゾーン」「草原と花のゾーン」の4つのエリアがあり、
  170. ";
  171. explainst += "季節の花や森の風景を楽しんだり、広大な草原で散歩、いろいろな遊具で遊ぶなど、
  172. ";
  173. explainst += "リフレッシュと癒しあふれる空間になっています。
  174. ";
  175. break;
  176. case 5: //淡路夢舞台
  177. explainst = "ウェスティンホテルに隣接する、自然豊かなリゾート施設です。
  178. ";
  179. explainst += "世界各国の植物を集めた大温室「奇跡の星の植物館」をはじめ、
  180. ";
  181. explainst += "北側へ広大な敷地が広がっていて、展望台、野外劇場、レストランなどがあり、
  182. ";
  183. explainst += "家族連れやカップル、少人数から団体旅行まで人数を問わず楽しめるスポットです。
  184. ";
  185. break;
  186. case 6: //北淡震災記念公園
  187. explainst = "過去の教訓を未来へ…、1995年に発生した阪神淡路大震災の記録を未来へ伝えるための施設です。
  188. ";
  189. explainst += "地震により現れた野島断層をそのまま保存しているため、地震の脅威をそのまま感じることができます。
  190. ";
  191. explainst += "当時の街並みを復元したものや、倒壊を免れた建物の壁の展示がみられます。
  192. ";
  193. explainst += "震度7の揺れを体験できる部屋もあり、日ごろからの備えの大切さを身をもって知ることができます。
  194. ";
  195. break;
  196. case 7: //五斗長垣内遺跡
  197. explainst = "弥生時代後期に存在した、国内最大規模の鉄器製造群落遺跡です。
  198. ";
  199. explainst += "約23棟の鉄製造施設跡からなり、鉄製の斧をはじめ、矢じりや鉄片などが出土しています。
  200. ";
  201. explainst += "管理棟を抜けると、当時の住居が復元されていて、中に入ることもできます。
  202. ";
  203. explainst += "最上部の展望台までいくと、瀬戸内海を望む景色を楽しむことができます。
  204. ";
  205. break;
  206. case 8: //ウェルネスパーク五色
  207. explainst = "江戸時代後期の淡路島生まれの廻船商人、高田屋嘉兵衛の功績を紹介する資料館のほか、
  208. ";
  209. explainst += "公共の宿泊所、キャンプ場、温泉、テニスやフットサル用のドーム付きグラウンド、
  210. ";
  211. explainst += "レストランや体験教室もある複合施設です。中央の大きな芝生広場ではいろいろなイベントが催されていて、
  212. ";
  213. explainst += "春先には、芝生上空を横切るように大量の鯉のぼりが泳ぎます。
  214. ";
  215. break;
  216. case 9: //陸の港西淡
  217. explainst = "淡路島南部(南あわじ市)と神戸・大阪方面をつなぐ、パークアンドライド型駐車場です。
  218. ";
  219. explainst += "高速バスのチケット売り場、待合スペースに加えて、2018年4月にリニューアルによって、
  220. ";
  221. explainst += "飲食スペース、お土産ショップ、レンタサイクルサービスも開始しました。
  222. ";
  223. explainst += "更衣室や工具類も常備されていてサイクリストにも便利な施設になっています。
  224. ";
  225. break;
  226. case 10://門崎(鳴門海峡)
  227. explainst = "淡路島の南端に位置する観光スポットがこの門崎(とさき)です。
  228. ";
  229. explainst += "淡路牛やタコ天ぷらなどをサンドしたあわじしまバーガーとはじめ、さまざまなグルメや、お土産ショッピングを楽しめます。
  230. ";
  231. explainst += "鳴門海峡大橋の付け根まで降りていくことができるので、鳴門渦潮の大迫力を肌で感じることもできます。
  232. ";
  233. explainst += "年末年始には、クリスマスツリーならぬタマネギツリーや、タマネギ門松も見られます。
  234. ";
  235. break;
  236. }
  237.   filename1 = "p" + ('00' + num).slice(-2) + "a.jpg";
  238. filename2 = "p" + ('00' + num).slice(-2) + "b.jpg";
  239. var str = " 
  240.  " + explainst + "
  241. ";
  242. var txtArea = document.getElementById('placedata');
  243. txtArea.innerHTML = str;
  244. }
  245.  

[ファイルのダウンロード]
SpaceScalesonAwaji.zip

サンプルを表示
ウィンドウを閉じる
トップに戻る