简体   繁体   English

Google Map API V3-2张地图上的infowindows @标记

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

I am working on a Google Map API V3 code, I am a beginner in JS and I am a little bit confused. 我正在研究Google Map API V3代码,我是JS的初学者,有些困惑。

Here is what I am trying to do : I have a database with Lat/Lng, address, a picture, a description.... etc 这是我想做的事情:我有一个包含纬度/经度,地址,图片,描述等的数据库。

On my final page, i have 2 maps, one for France, one for Paris. 在我的最后一页上,我有两张地图,一张是法国的,一张是巴黎的。 If the lat/lng is in Paris, the marker is on Paris' map, if it's outside paris, it goes on the France map. 如果纬度/经度在巴黎,则标记在巴黎的地图上;如果在巴黎以外,则在法国地图上。

So far, I've done exactly what i wanted, but i'm stuck on the infoWindow :( I can open them, but can't close them automatically... I just want to have one infowindow opened at the same time. 到目前为止,我已经完全完成了我想要的操作,但是我被困在infoWindow中:(我可以打开它们,但是不能自动关闭它们...我只想同时打开一个信息窗口。

Here is my code (just the JS part) : 这是我的代码(只是JS部分):

("mapidf" is for Paris and "mapfr" is for France, and i've removed my attempts with the infowindow which didn't work) (“ 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);
        }


}

It's possible that you notice other things I did wrong... please, feel free to criticizes this piece of code :) 您可能会注意到我做错的其他事情...请随意批评这段代码:)

Thank you very much 非常感谢你

Probably the easiest way would be to create a single instance of info window and reuse it for all the markers as demonstrated below: 可能最简单的方法是创建一个信息窗口实例,并将其重新用于所有标记,如下所示:

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);
      });

}

According to Info Windows : 根据信息窗口

Best practices: For the best user experience, only one info window should be open on the map at any one time. 最佳做法:为了获得最佳的用户体验,任何时候都只能在地图上打开一个信息窗口。 Multiple info windows make the map appear cluttered. 多个信息窗口使地图显得混乱。 If you only need one info window at a time, you can create just one InfoWindow object and open it at different locations or markers upon map events, such as user clicks. 如果一次只需要一个信息窗口,则可以只创建一个InfoWindow对象,并在地图事件(例如用户单击)时在其他位置或标记处打开它。 If you do need more than one info window, you can display multiple InfoWindow objects at the same time. 如果确实需要多个信息窗口,则可以同时显示多个InfoWindow对象。

In that case info window should automatically close when you click on a new marker without having to call the close() method . 在这种情况下,当您单击新标记时,信息窗口应自动关闭,而无需调用close() method

JSFiddle: Modified example JSFiddle: 修改示例

If you want to have one marker per map, create a separate InfoWindow for each map, and associate it with the marker like you do the map. 如果您希望每个地图有一个标记,请为每个地图创建一个单独的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);
}

proof of concept fiddle 概念证明

code snippet: 代码段:

 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