ホームページ > ウェブフロントエンド > jsチュートリアル > Google Maps JS API v3 を使用して InfoWindows で複数のマーカーを表示するにはどうすればよいですか?

Google Maps JS API v3 を使用して InfoWindows で複数のマーカーを表示するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-20 15:45:10
オリジナル
781 人が閲覧しました

How to Display Multiple Markers with InfoWindows using the Google Maps JS API v3?

Google Maps JS API v3 - シンプルな複数マーカーの例

マップとマーカーの作成

まず、新しい HTML ファイルを作成し、API キーを含む Google Maps API スクリプトを含めます。次に、Map オブジェクトを設定し、必要なパラメータを指定します。

var map = new google.maps.Map(document.getElementById('map'), {
  zoom: 10,
  center: new google.maps.LatLng(-33.92, 151.25),
  mapTypeId: google.maps.MapTypeId.ROADMAP
});
ログイン後にコピー

InfoWindow の作成

場所の名前を表示する InfoWindow オブジェクトを定義します。マーカーのクリック:

var infowindow = new google.maps.InfoWindow();
ログイン後にコピー

位置をループデータ

次に、データ配列を反復処理して、各場所のマーカーを作成し、地図に追加します。

for (i = 0; i < locations.length; i++) {  
  marker = new google.maps.Marker({
    position: new google.maps.LatLng(locations[i][1], locations[i][2]),
    map: map
  });
ログイン後にコピー

InfoWindows のクリック イベントの設定

最後に、情報ウィンドウが開くようにトリガーするイベント リスナーを各マーカーに追加します。クリックされました:

  google.maps.event.addListener(marker, 'click', (function(marker, i) {
    return function() {
      infowindow.setContent(locations[i][0]);
      infowindow.open(map, marker);
    }
  })(marker, i));
}
ログイン後にコピー

完全なコード

完全なコードは次のようになります:

var locations = [
  ['Bondi Beach', -33.890542, 151.274856, 4],
  ['Coogee Beach', -33.923036, 151.259052, 5],
  ['Cronulla Beach', -34.028249, 151.157507, 3],
  ['Manly Beach', -33.80010128657071, 151.28747820854187, 2],
  ['Maroubra Beach', -33.950198, 151.259302, 1]
];

var map = new google.maps.Map(document.getElementById('map'), {
  zoom: 10,
  center: new google.maps.LatLng(-33.92, 151.25),
  mapTypeId: google.maps.MapTypeId.ROADMAP
});

var infowindow = new google.maps.InfoWindow();

var marker, i;

for (i = 0; i < locations.length; i++) {  
  marker = new google.maps.Marker({
    position: new google.maps.LatLng(locations[i][1], locations[i][2]),
    map: map
  });

  google.maps.event.addListener(marker, 'click', (function(marker, i) {
    return function() {
      infowindow.setContent(locations[i][0]);
      infowindow.open(map, marker);
    }
  })(marker, i));
}
ログイン後にコピー

以上がGoogle Maps JS API v3 を使用して InfoWindows で複数のマーカーを表示するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート