Google Maps API Работаем с информационными окнами

Автор: | 26.09.2009

Информационное окно (балун)– является отличным способом отображения информации о конкретной точке или объекте.

Существует несколько видов информационных окон.

В этой заметке я покажу, как можно добавить различные их виды, которые появляются при щелчке на маркере.

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поздать на просмотр фильмапрактически не возможно. Вместо привычных нашему восприятию «звонков» зазвучит «живая» речь. Грамотно и легко подаётся информация о том, где и что в кинотеатре находится и через сколько минут начнется сеанс. Звуковое приглашение услышат даже в самых удаленных местах кинотеатра.'
});
});

Посмотреть пример в действии.

Google Maps API Работаем с информационными окнами: 6 комментариев

  1. Виталий

    В первую очередь большое спасибо за статьи и ваш сайт !!!
    Но не вышло обойтись без вопроса…
    Смотрю ваши примеры, и вижу, что почти на всех не работает скрол мышки… а на моём сайте ситуация обратная, скрол работает и это доставляет неудобства 🙁
    Подскажите пожалуйста, как его можно отключить…???
    Вот пример карты у нас на сайте — http://altai-photo.ru/photo/tematicheskie_razdely/dostoprimechatelnosti/soldatskij_most/9-0-2366

  2. Руслан

    Подскажите, пожалуйста, а как свернуть предыдущее окно при щелчке на другом маркере?

  3. коля

    День добрый.
    Скажите, пожалуйста, а как сделать чтобы инфоокно открывалось при нажатии и маркера было собственное изображение.
    Заранее спасибо.

  4. Андрей

    Можно ли создавать информационные окна с закладками в версии 3 (api v3)?

    Во второй версии информационные окна отображаются с закругленными углами. Как сделать чтобы в версии 3 у InfoWindow тоже были закругленные углы.

  5. Антон

    Добрый день!
    1. в вашем примере от 27.10.12(«пользовательский макет балуна») балун открыт сразу при загрузке страницы. Возможно ли сделать в google maps чтобы при открытии страницы все балуны уже были раскрыты.
    2.Может существуют маркеры, в которые можно вписывать какую-либо информацию, брать эту информацию из fusion tables?

    Спасибо за Ваш гениальный блог!

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *