アプリケーション開発ポータルサイト
ServerNote.NET
ServerNote.NET厳選キャンペーン・クーポンはこちら!
カテゴリー【GoogleJavaScript
【Google Maps API】マップクリック地点の緯度経度取得とマーキング
POSTED BY
2021-05-03

表題のとおり、HTMLにGoogle Mapを読み込んで、クリックでその地点の緯度経度を取得しフォームに入力し、かつクリック地点を中心に地図を移動しマーカーを立てるサンプル。

緯度: 経度:

以下のようなソースになります。

HTMLgmap_get_point.htmlGitHub Source
<!doctype html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <title>Google Maps Point Marker</title>

<style type="text/css">
#map {
  height: 600px;
  width: 80%;
}
</style>

<!-- Google Maps API -->
<script src="https://maps.googleapis.com/maps/api/js"></script>
<script>
var marker = null;
var lat = 35.729493379635535;
var lng = 139.71086479574538;

function init() {
  //初期化
  var map = new google.maps.Map(document.getElementById('map'), {
    zoom: 18, center: {lat: lat, lng: lng}
  });

  document.getElementById('lat').value = lat;
  document.getElementById('lng').value = lng;

  //初期マーカー
  marker = new google.maps.Marker({
    map: map, position: new google.maps.LatLng(lat, lng),
  });

  //クリックイベント
  map.addListener('click', function(e) {
    clickMap(e.latLng, map);
  });
}

function clickMap(geo, map) {
  lat = geo.lat();
  lng = geo.lng();

  //小数点以下6桁に丸める場合
  //lat = Math.floor(lat * 1000000) / 1000000);
  //lng = Math.floor(lng * 1000000) / 1000000);

  document.getElementById('lat').value = lat;
  document.getElementById('lng').value = lng;

  //中心にスクロール
  map.panTo(geo);

  //マーカーの更新
  marker.setMap(null);
  marker = null;
  marker = new google.maps.Marker({
    map: map, position: geo 
  });
  
}
</script>

<body onload="javascript:init();">

<p>Google Maps Point Marker</p>

<div id="map" style="margin-top: 10px; margin-bottom:15px;"></div>

緯度:<input type="text" id="lat" name="lat" value="" size="20"> 経度:<input type="text" id="lng" name="lng" value="" size="20">

</body>
</html>

※本記事は当サイト管理人の個人的な備忘録です。本記事の参照又は付随ソースコード利用後にいかなる損害が発生しても当サイト及び管理人は一切責任を負いません。
※本記事内容の無断転載を禁じます。
【webmaster/管理人】
自営業プログラマー
ご連絡は以下アドレスまで★

☆ServerNote.NETショッピング↓
ShoppingNote
☆お仲間ブログ↓
一人社長の不動産業務日誌
【キーワード検索】