Отображение множества маркеров на Яндекс.Картах

Если Вам необходимо отобразить на Яндекс.Карте большое количество объектов (например, несколько тысяч меток), то используя традиционный подход map.addOverlay(placemark); Вы можете столкнуться с проблемами. Долгое время загрузки карты в браузере, резкое замедление реакции карты при панарамировании и т. д.

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

И так что нам необходимо для реализации примера:

1. Я подготовил файл в формате CSV с исходными данными — платежные терминалы QIWI в Нижнем Новгороде, 550 строк адреса и координаты. 2. Специальное приложение, которое позволяет из YMapsML-файла получить набор тайлов, от пользователя клуба API Яндекс.Карт twirl необходимых для создания слоя активных областей. Скачать приложение можно по адресу: http://github.com/twirl/hsTiler.

Для начала нужно из csv-файла получить YmapsML-файл.

Сделать это можно с помощью специального скрипта, его исходный код:

 

<?php
 
header("Content-type: text/xml");
 
echo '<ymaps xmlns="http://maps.yandex.ru/ymaps/1.x" xmlns:gml="http://www.opengis.net/gml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maps.yandex.ru/schemas/ymaps/1.x/ymaps.xsd"> 
    <Representation xmlns="http://maps.yandex.ru/representation/1.x"> 
        <Style gml:id="qiwist"> 
 	<iconStyle> 
            <href>http://api-maps.yandex.ru/i/0.4/placemarks/pmgns.png</href> 
                <size x="19" y="20"/> 
                <offset x="-9" y="-20"/> 
            </iconStyle> 
 
            <balloonContentStyle> 
                <template>#balloonTemplate</template> 
            </balloonContentStyle> 
        </Style> 
 
        <Template gml:id="balloonTemplate"> 
            <text><![CDATA[
                   <div style="font-size:12px;">
                        <div style="color:#ff0303;font-weight:bold">$[name]</div> 
                        <div>Адрес: $[metaDataProperty.AnyMetaData.adres]</div>
 
                    </div>]]></text> 
        </Template> 
    </Representation> 
 
    <GeoObjectCollection> 
        <gml:name>Объекты карте</gml:name> 
        <style>#qiwist</style> 
        <gml:featureMembers>';
 
$filename1 = "qiwi-nn-coordinats.csv";
 
$content1 = file($filename1);
 
for($i=0; $i<count($content1); $i++)
{
$content1[$i] = trim($content1[$i]);
 
$exp_str1 = explode(";", $content1[$i]);
 
 
echo '<GeoObject>', "\n";
echo '<gml:name>Терминал №', $exp_str1[0], '</gml:name>', "\n";
echo '<gml:metaDataProperty>', "\n";
echo '<AnyMetaData>', "\n";
echo '<adres>', $exp_str1[1], '</adres>', "\n";
echo '</AnyMetaData>', "\n";
echo '</gml:metaDataProperty>', "\n";
echo '<gml:Point>', "\n";
echo '<gml:pos>', $exp_str1[2], ' ', $exp_str1[3], '</gml:pos>', "\n";
echo '</gml:Point>', "\n";
echo '</GeoObject>', "\n";
 
echo "\n";
 
}
 
echo '</gml:featureMembers>
    </GeoObjectCollection>
</ymaps>';
 
?>

После этого разархивируем скаченный файл twirl-hsTiler-adaccd8.zip.

Копируем папку с о всем содержимым на сервер и добавляем в нее полученный файл ymapqiwi.xml и пустую папку qiwimap, где будут сохраняться тайлы для слоя активных областей.

Теперь мы должны отредактировать файл index.php в папке twirl-hsTiler-adaccd8.

Указать путь к YmapsML-файлу в седьмой строке, для нашего примера ‘XML’ => ‘ymapqiwi.xml’,

Минимальный и максимальный уровень масштаба, для которых необходимо создавать тайлы, в нашем примере это ‘minZoom’ => 15 и ‘maxZoom’ => 17

В строке 17 название папки для размещения тайлов примера и файла со стилями.

У нас это будет ‘directory’ => ‘qiwimap’

Вы также можете задать префикс для имен стилей, у нас это ‘styleKey’ => ‘qiwimap’.

Сохраняем измененный файл index.php

Запускаем в браузере этот файл на выполнение.

Через некоторое время мы увидим следующую картину

 

 

Это означает, что процесс генерации тайлов закончен и изменив центр карты и уровень масштаба мы увидим результат

 

 

Посмотреть пример в действии http://webmap-blog.ru/examples/qiwimap/index.html

Щелкнув по метке, мы можем посмотреть ее параметры.

Это не единственный способ решение проблемы размещения большого количества маркеров на Яндекс.Карте, можно использовать диспетчер объектов или кластеризацию.

В качестве дополнительной информации предлагаю Вам посмотреть два видео в которых как раз говориться о проектах в ходе реализации которых было необходимо решать проблему размещения большого количества маркеров на Яндекс.Карте.

 

 

источник http://webmap-blog.ru



Отображение множества маркеров на Яндекс.Картах - Генератор расширений Joomla и многое другое на нашем сайте посвященном работе расширений, компонентов, модулей, плагинов для линейки Joomla. Отправляйте ссылку на страницу своим друзьям и в социальные сети воспользовавшись графическими иконками выше.

Блог

Календарь приёма объявлений

Небольшой пример из повседневной практики. Организация меняет реквизиты, и они вступят в силу через  пару недель. На сайте идет приём объявлений и объявления принимаются на несколько месяцев в...

Дырка в com_content

Сегодня у товарища, сайт которого находится на старой  Joomla 1.0.3, была сильная нагрузка на сервере, просматривая логи обнаружил не вежливый запрос такого порядка: http://сайт/index2...

Лечим вирус на сайте

  Первоначальный осмотр сайта обнаружил, что у клиента закрыт доступ по фтп, что сузило круг подозреваемых уязвимостей, стало быть отверстие в какомто скрипте движка joomla. Касперский яро...

Troj/JSRedir-MH

Снова грянул гром зарежения сайтов новым вирусом  Troj/JSRedir-MH.  И так в коротко по вирусу Troj/JSRedir-MH. Вирус или троян куда интереснее чем свои предшествиники, тепер...

Доработка расширения для рассылки Send Email JK

Сегодня поделюсь немного интересной информацией для владельцев сайтов собранных ан joomla.  Рано и поздно возникает задача подписки и рассылки информации с сайта, это может быть разная постановка зада...

Привет Ie 10 регулярка

И вот и мне пришлось столкнулся с проблемами перехода на win 8 в придачу с ie 10, некоторых постоянных пользователей моих сайтов. На многих сайтах  имеющих раздел по приёму объявлений, использ...

Kunena заменяем ссылку на профиль пользователя

Всем привет, снова снова кунена, получил задание на допиливание популярного форума Kunena, сегодня потребовалось поменять ссылку на профиль пользователя. Это связано с тем, что на сайте стоит социа...

Работает на Kunena - зачем на каждой странице?

  Все у кого стоит форум kunena мешает надпись с двумя ссылкам внизу форума "Работает на Kunena". Сея надпись висит на каждой странице форма, а также страница разработчиков содержит множество вн...

Kunena избавимся от лишних quote

Для тех кто действительно делает сайт для людей, моя следующая заметка. Расскажу вам, как избавиться от лишних quote в постах на форуме kunena. У меня несколько тематических сайтов с нормальной посеща...

Kunena решаем проблему с пропажей аватаров

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

Джомлавикам

Обработка параметров расширений joomla

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

Кunena крамсаем шаблон

1. В папке \components\com_kunena\template\ваш_шаблон\ находим файл template.xml и вставляем в него такой кусок (чтобы была возможность выбора показывать это поле или нет): <param name="l...

Подключить свои классы и методы в Joomla?

Иногда случается, что набор собственных функций или библиотек нужно подключить в Joomla. Но иногда подключить их нужно так, чтобы они присутсвовали во всей системе, вне зависимо...

3 новых полезных класса в Joomla 2.5

В платформе Joomla 11.3 разработчики добавлил несколько полезных новых классов для разработчиков. Рассмотрю некоторый из них - JGrid (для построения HTML таблиц), JWebClient (для получения информац...

Репозиторий файлов на Joomla средствами Apache

Создадим две вложенные директории /files/files в корне сайта. Если вы пожелаете использовать другие имена директорий, то вам необходимо будет внести соответствующие правки в дальнейшем. ...