簡體   English   中英

Google Map API V3-2張地圖上的infowindows @標記

[英]Google Map API V3 - infowindows @ markers on 2 maps

我正在研究Google Map API V3代碼,我是JS的初學者,有些困惑。

這是我想做的事情:我有一個包含緯度/經度,地址,圖片,描述等的數據庫。

在我的最后一頁上,我有兩張地圖,一張是法國的,一張是巴黎的。 如果緯度/經度在巴黎,則標記在巴黎的地圖上;如果在巴黎以外,則在法國地圖上。

到目前為止,我已經完全完成了我想要的操作,但是我被困在infoWindow中:(我可以打開它們,但是不能自動關閉它們...我只想同時打開一個信息窗口。

這是我的代碼(只是JS部分):

(“ mapidf”用於巴黎,“ mapfr”用於法國,並且我刪除了無效的信息窗口的嘗試)

function CreateMarker(marker, map, infowindow, description)
    {
        google.maps.event.addListener(marker, 'click');
        marker.setMap(map);
    }



function initialize(ListeDesPoints) {
    var mapidfOptions = {
          center: { lat: 48.856614, lng: 2.352222},
          zoom: 11
        };
    var mapfrOptions = {
          center: { lat: 46.227638, lng: 2.213749},
          zoom: 5
        };

     var mapidf = new google.maps.Map(document.getElementById('maps-idf'),
            mapidfOptions);

     var mapfr = new google.maps.Map(document.getElementById('maps-fr'),
            mapfrOptions);


    var infowindow = new Array();
    var marker = new Array();

    for (var i = 0; i < ListeDesPoints.length; i++)
        {

                marker[i] = new google.maps.Marker({
                                        position: new google.maps.LatLng (ListeDesPoints[i]['lat'], ListeDesPoints[i]['lng']),
                                        title: ListeDesPoints[i]['address']
                                 });
                var max_lat = 48.9602260;
                var min_lat = 48.7451930;
                var max_lng = 2.6327379;
                var min_lng = 2.0946256;
                        if(ListeDesPoints[i]['lat'] > max_lat || ListeDesPoints[i]['lat'] < min_lat || ListeDesPoints[i]['lng'] > max_lng || ListeDesPoints[i]['lng'] < min_lng)
                            {
                                var map = mapfr;
                            }
                        else
                            {
                                var map = mapidf;
                            }
                infowindow[i] = new google.maps.InfoWindow({content:""})
                var description = '<h2>'+ ListeDesPoints[i]['address']+'</h2><img src="'+ListeDesPoints[i]['image']+'" />';


                CreateMarker(marker[i], map, infowindow[i], description);
        }


}

您可能會注意到我做錯的其他事情...請隨意批評這段代碼:)

非常感謝你

可能最簡單的方法是創建一個信息窗口實例,並將其重新用於所有標記,如下所示:

var infowindow = new google.maps.InfoWindow({});
var marker = new Array();

for (var i = 0; i < data.length; i++) {

      marker[i] = new google.maps.Marker({
           position: new google.maps.LatLng(data[i]['lat'], data[i]['lng']),
           title: data[i]['address'],
           map: map
      });

      google.maps.event.addListener(marker, 'click', function () {
          infowindow.setContent('Some content goes here');
          infowindow.open(map);
      });

}

根據信息窗口

最佳做法:為了獲得最佳的用戶體驗,任何時候都只能在地圖上打開一個信息窗口。 多個信息窗口使地圖顯得混亂。 如果一次只需要一個信息窗口,則可以只創建一個InfoWindow對象,並在地圖事件(例如用戶單擊)時在其他位置或標記處打開它。 如果確實需要多個信息窗口,則可以同時顯示多個InfoWindow對象。

在這種情況下,當您單擊新標記時,信息窗口應自動關閉,而無需調用close() method

JSFiddle: 修改示例

如果您希望每個地圖有一個標記,請為每個地圖創建一個單獨的InfoWindow,然后像標記地圖一樣將其與標記關聯。

for (var i = 0; i < ListeDesPoints.length; i++) {

    marker[i] = new google.maps.Marker({
        position: new google.maps.LatLng(ListeDesPoints[i]['lat'], ListeDesPoints[i]['lng']),
        title: ListeDesPoints[i]['address']
    });
    var max_lat = 48.9602260;
    var min_lat = 48.7451930;
    var max_lng = 2.6327379;
    var min_lng = 2.0946256;
    if (ListeDesPoints[i]['lat'] > max_lat || ListeDesPoints[i]['lat'] < min_lat || ListeDesPoints[i]['lng'] > max_lng || ListeDesPoints[i]['lng'] < min_lng) {
        var map = mapfr;
        var infowindow = infowindowfr;
    } else {
        var map = mapidf;
        var infowindow = infowindowidf;
    }
    //infowindow[i] = new google.maps.InfoWindow({ content: "" });
    var description = '<h2>' + ListeDesPoints[i]['address'] + '</h2><img src="' + ListeDesPoints[i]['image'] + '" />';


    CreateMarker(marker[i], map, infowindow, description);
}

概念證明

代碼段:

 function CreateMarker(marker, map, infowindow, description) { marker.setMap(map); google.maps.event.addListener(marker, 'click', function() { infowindow.setContent(description); infowindow.open(map, this); }); } function initialize(ListeDesPoints) { var mapidfOptions = { center: { lat: 48.856614, lng: 2.352222 }, zoom: 11 }; var mapfrOptions = { center: { lat: 46.227638, lng: 2.213749 }, zoom: 5 }; var mapidf = new google.maps.Map(document.getElementById('maps-idf'), mapidfOptions); var mapfr = new google.maps.Map(document.getElementById('maps-fr'), mapfrOptions); //var infowindow = new Array(); var infowindowfr = new google.maps.InfoWindow({}); var infowindowidf = new google.maps.InfoWindow({}); var marker = new Array(); for (var i = 0; i < ListeDesPoints.length; i++) { marker[i] = new google.maps.Marker({ position: new google.maps.LatLng(ListeDesPoints[i]['lat'], ListeDesPoints[i]['lng']), title: ListeDesPoints[i]['address'] }); var max_lat = 48.9602260; var min_lat = 48.7451930; var max_lng = 2.6327379; var min_lng = 2.0946256; if (ListeDesPoints[i]['lat'] > max_lat || ListeDesPoints[i]['lat'] < min_lat || ListeDesPoints[i]['lng'] > max_lng || ListeDesPoints[i]['lng'] < min_lng) { var map = mapfr; var infowindow = infowindowfr; } else { var map = mapidf; var infowindow = infowindowidf; } //infowindow[i] = new google.maps.InfoWindow({ content: "" }); var description = '<h2>' + ListeDesPoints[i]['address'] + '</h2><img src="' + ListeDesPoints[i]['image'] + '" />'; CreateMarker(marker[i], map, infowindow, description); } } //Usage google.maps.event.addDomListener(window, 'load', function() { //1.load data var points = [{ 'lat': 48.856614, 'lng': 2.352222, 'address': 'Paris', 'image':'' }, { 'lat': 48.85837, 'lng': 2.294481, 'address': 'Eiffel Tower', 'image': '' }, { 'lat': 46.227638, 'lng': 2.213749, 'address': 'France', 'image':'' }, { 'lat': 44.837789, 'lng': -0.57918, 'address': 'Bordeaux', 'image':''}]; initialize(points); }); 
 #maps-fr, #maps-idf { height: 240px; width: 640px; margin: 0px; padding: 0px; } 
 <script src="https://maps.googleapis.com/maps/api/js"></script> <div id="maps-fr"></div> <div id="maps-idf"></div> 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM