Карты Google:Автоматическое закрытие открытых информационных окон?
-
19-09-2019 - |
Вопрос
На моем сайте, Я использую Google Maps API v3 для размещения маркеров домов на карте.
Информационные окна остаются открытыми до тех пор, пока вы явно не нажмете на значок закрытия.Это означает, что у вас может быть открыто более 2 информационных окон одновременно, если вы наведете курсор на маркер карты.
Вопрос:Как мне сделать так, чтобы было открыто только текущее активное информационное окно, а все остальные информационные окна были закрыты?Это значит, что одновременно будет открыто не более 1 информационного окна?
Решение
Eсть закрывать() функция для InfoWindows.Просто отслеживайте последнее открытое окно и вызывайте для него функцию закрытия при создании нового окна.
Эта демонстрация имеет ту функциональность, которую вы ищете.Я нашел это в Галерея демонстраций Maps API V3.
Другие советы
альтернативное решение для этого с использованием множества информационных окон:сохранить предыдущее открытое информационное окно в переменной, а затем закрыть его при открытии нового окна
var prev_infowindow =false;
...
base.attachInfo = function(marker, i){
var infowindow = new google.maps.InfoWindow({
content: 'yourmarkerinfocontent'
});
google.maps.event.addListener(marker, 'click', function(){
if( prev_infowindow ) {
prev_infowindow.close();
}
prev_infowindow = infowindow;
infowindow.open(base.map, marker);
});
}
//assuming you have a map called 'map'
var infowindow = new google.maps.InfoWindow();
var latlng1 = new google.maps.LatLng(0,0);
var marker1 = new google.maps.Marker({position:latlng1, map:map});
google.maps.event.addListener(marker1, 'click',
function(){
infowindow.close();//hide the infowindow
infowindow.setContent('Marker #1');//update the content for this marker
infowindow.open(map, marker1);//"move" the info window to the clicked marker and open it
}
);
var latlng2 = new google.maps.LatLng(10,10);
var marker2 = new google.maps.Marker({position:latlng2, map:map});
google.maps.event.addListener(marker2, 'click',
function(){
infowindow.close();//hide the infowindow
infowindow.setContent('Marker #2');//update the content for this marker
infowindow.open(map, marker2);//"move" the info window to the clicked marker and open it
}
);
Это «переместит» информационное окно вокруг каждого нажатого маркера, фактически закроется, а затем снова откроется (и панорамируется в соответствии с размером области просмотра) в новом месте.Он меняет свое содержимое перед открытием, чтобы дать желаемый эффект.Работает для n маркеров.
Мое решение.
var map;
var infowindow = new google.maps.InfoWindow();
...
function createMarker(...) {
var marker = new google.maps.Marker({
...,
descrip: infowindowHtmlContent
});
google.maps.event.addListener(marker, 'click', function() {
infowindow.setOptions({
content: this.descrip,
maxWidth:300
});
infowindow.open(map, marker);
});
По этой ссылке http://www.svennerberg.com/2009/09/google-maps-api-3-infowindows/:
Тео:Самый простой способ сделать это - просто иметь один экземпляр объекта InfoWindow, который вы будете использовать снова и снова.Таким образом, когда вы нажимаете на новый маркер, информационное окно “перемещается” с того места, где оно находится в данный момент, чтобы указать на новый маркер.
Используйте его метод setContent, чтобы загрузить его с правильным содержимым.
Помимо использования функции close(), существует более простой способ.если вы создаете переменную со свойством InfoWindow, она автоматически закрывается при открытии другой.
var info_window;
var map;
var chicago = new google.maps.LatLng(33.84659, -84.35686);
function initialize() {
var mapOptions = {
center: chicago,
zoom: 14,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
map = new google.maps.Map(document.getElementById("map_canvas"), mapOptions);
info_window = new google.maps.InfoWindow({
content: 'loading'
)};
createLocationOnMap('Location Name 1', new google.maps.LatLng(33.84659, -84.35686), '<p><strong>Location Name 1</strong><br/>Address 1</p>');
createLocationOnMap('Location Name 2', new google.maps.LatLng(33.84625, -84.36212), '<p><strong>Location Name 1</strong><br/>Address 2</p>');
}
function createLocationOnMap(titulo, posicao, conteudo) {
var m = new google.maps.Marker({
map: map,
animation: google.maps.Animation.DROP,
title: titulo,
position: posicao,
html: conteudo
});
google.maps.event.addListener(m, 'click', function () {
info_window.setContent(this.html);
info_window.open(map, this);
});
}
Объявить переменную для активного окна
var activeInfoWindow;
и привяжите этот код к прослушивателю маркеров
marker.addListener('click', function () {
if (activeInfoWindow) { activeInfoWindow.close();}
infowindow.open(map, marker);
activeInfoWindow = infowindow;
});
Как насчет -
google.maps.event.addListener(yourMarker, 'mouseover', function () {
yourInfoWindow.open(yourMap, yourMarker);
});
google.maps.event.addListener(yourMarker, 'mouseout', function () {
yourInfoWindow.open(yourMap, yourMarker);
});
Затем вы можете просто навести на него курсор, и он закроется.
var map;
var infowindow;
...
function createMarker(...) {
var marker = new google.maps.Marker({...});
google.maps.event.addListener(marker, 'click', function() {
...
if (infowindow) {
infowindow.close();
};
infowindow = new google.maps.InfoWindow({
content: contentString,
maxWidth: 300
});
infowindow.open(map, marker);
}
...
function initialize() {
...
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
...
google.maps.event.addListener(map, 'click', function(event) {
if (infowindow) {
infowindow.close();
};
...
}
}
Я сохранил переменную вверху, чтобы отслеживать, какое информационное окно открыто в данный момент, см. ниже.
var currentInfoWin = null;
google.maps.event.addListener(markers[counter], 'click', function() {
if (currentInfoWin !== null) {
currentInfoWin.close(map, this);
}
this.infoWin.open(map, this);
currentInfoWin = this.infoWin;
});
var contentString = "Location: " + results[1].formatted_address;
google.maps.event.addListener(marker,'click', (function(){
infowindow.close();
infowindow = new google.maps.InfoWindow({
content: contentString
});
infowindow.open(map, marker);
}));