Информационное окно (балун)– является отличным способом отображения информации о конкретной точке или объекте.
Существует несколько видов информационных окон.
В этой заметке я покажу, как можно добавить различные их виды, которые появляются при щелчке на маркере.
1. Основное информационное окно
Для открытия окна с информацией существует специальный класс GMarker.openInfoWindowHTML()
Он принимает два параметра: первый, текст который появится в информационном окне, а второй, необязательный, содержит опции для настройки информационного окна.
Пример основного информационного окна.
Фрагмент кода:
// Создаем новый маркер var marker = new GMarker(new GLatLng(56.317213,43.993976)) // Добавляем обработку события щелчек по маркеру GEvent.addListener(marker, 'click', function() { // При клике открываем информационное окно marker.openInfoWindowHtml('Кинотеатр Октябрь'); }); // Добавляем маркер на карту map.addOverlay(marker); |
2. Информационное окно с закладками
Для создания информационного окна с закладками служит класс GInfoWindowTab.
С помощью его Вы определяете каждую закладку и объединяете их в массив, который после добавляется маркеру с помощью метода openInfoWindowTabsHtml().
Пример информационного окна с закладками.
Фрагмент кода:
// Создаем новый маркер var marker = new GMarker(new GLatLng(56.317213,43.993976)) // Добавляем обработку события щелчек по маркеру GEvent.addListener(marker, 'click', function() { var tabs = []; tabs.push(new GInfoWindowTab('Название', 'Кинотеатр Октябрь')); tabs.push(new GInfoWindowTab('Адрес', 'ул. Большая Покровская, 51а')); marker.openInfoWindowTabsHtml(tabs); }); // Добавляем маркер на карту map.addOverlay(marker); |
3. Информационное окно с миникарой
Существует возможность показать миникарту над районом, в котором расположен маркер.
За это отвечает функция showMapBlowup().
Она имеет два параметра: InfoWindowOptions.zoomLevel и InfoWindowOptions.mapType
Они позволяют определить какой уровень масштаба должен быть у миникарты и какой тип карты она должна отображать.
Пример основного информационного окна с миникарой.
Фрагмент кода:
// Добавляем обработку события щелчек по маркеру GEvent.addListener(marker, 'click', function() { // При клике открываем информационное окно с миникартой marker.showMapBlowup(); }); |
Добавим параметры для миникарты.
Зададим уровень масштаба миникарты – 15, тип – спутниковый снимок (G_SATELLITE_3D_MAP).
Фрагмент кода:
// Добавляем обработку события щелчек по маркеру GEvent.addListener(marker, 'click', function() { // При клике открываем информационное окно с миникартой marker.showMapBlowup({zoomLevel: 15, mapType: G_SATELLITE_3D_MAP}); }); |
4. Максимальное информационное окно.
Если у Вас много информации для размещения в окне, необходимо разрешить пользователю увеличивать информационное окно до максимального размера.
Это делается с помощью параметров maxContent и maxTitle.
После их задания появиться кнопка для развертывания окна.
Пример основного информационного окна с миникарой.
Фрагмент кода:
// Добавляем обработку события щелчек по маркеру GEvent.addListener(marker, 'click', function() { // При клике открываем информационное окно и показывем метку, чтобы развернуть окно полностью marker.openInfoWindowHtml('Нажми (+), чтобы развернуть окно', { maxTitle: '<strong>Кинотеатр Октябрь</strong>', maxContent: '<img src="ris/october2.jpg" alt="" hspace="10" vspace="10" width="150" height="112" align="left" /><strong>Адрес:</strong> ул. Большая Покровская, 51а На настоящий момент, это самый фешенебельный кинотеатр нашего города. Кинозал имеет 430 комфортабельных мест, кроме этого в кинотеатре работают два кафе, бар и ресторан. Есть где и поговорить, и накормить детей, и покурить, и «взбодриться»… Одиноким и мечтающим можно разглядывать картины нижегородских художников,наблюдать «парение» рыб аквариумах.Oпоздать на просмотр фильмапрактически не возможно. Вместо привычных нашему восприятию «звонков» зазвучит «живая» речь. Грамотно и легко подаётся информация о том, где и что в кинотеатре находится и через сколько минут начнется сеанс. Звуковое приглашение услышат даже в самых удаленных местах кинотеатра.' }); }); |
В первую очередь большое спасибо за статьи и ваш сайт !!!
Но не вышло обойтись без вопроса…
Смотрю ваши примеры, и вижу, что почти на всех не работает скрол мышки… а на моём сайте ситуация обратная, скрол работает и это доставляет неудобства 🙁
Подскажите пожалуйста, как его можно отключить…???
Вот пример карты у нас на сайте — http://altai-photo.ru/photo/tematicheskie_razdely/dostoprimechatelnosti/soldatskij_most/9-0-2366
Подскажите, пожалуйста, а как свернуть предыдущее окно при щелчке на другом маркере?
День добрый.
Скажите, пожалуйста, а как сделать чтобы инфоокно открывалось при нажатии и маркера было собственное изображение.
Заранее спасибо.
Можно ли создавать информационные окна с закладками в версии 3 (api v3)?
Во второй версии информационные окна отображаются с закругленными углами. Как сделать чтобы в версии 3 у InfoWindow тоже были закругленные углы.
Вот ссылки на два примера: табы в балуне;
пользовательский макет балуна
Добрый день!
1. в вашем примере от 27.10.12(«пользовательский макет балуна») балун открыт сразу при загрузке страницы. Возможно ли сделать в google maps чтобы при открытии страницы все балуны уже были раскрыты.
2.Может существуют маркеры, в которые можно вписывать какую-либо информацию, брать эту информацию из fusion tables?
Спасибо за Ваш гениальный блог!