Позиционирование карты для показа результатов геокодирования и их кластеризация

Open in CodeSandbox

Пример иллюстрирует, как добавлять результаты геокодирования в выборку GeoQueryResult. С помощью метода applyBoundsToMap можно устанавливать область картографирования так, чтобы в нее попадали все объекты выборки. С помощью метода clusterize объекты можно добавлять в кластеризатор.

<!DOCTYPE html>

<html>
    <head>
        <title>
            Примеры. Позиционирование карты для показа результатов
            геокодирования и их кластеризация.
        </title>
        <meta
            http-equiv="Content-Type"
            content="text/html; charset=utf-8"
        />
        <!--
        Укажите свой API-ключ. Тестовый ключ НЕ БУДЕТ работать на других сайтах.
        Получить ключ можно в Кабинете разработчика: https://developer.tech.yandex.ru/keys/
    -->
        <script
            src="https://api-maps.yandex.ru/2.0.31/?load=package.standard,package.geocode,package.geoQuery,package.clusters&amp;lang=ru-RU&amp;apikey=<ваш API-ключ>"
            type="text/javascript"
        ></script>

        <script
            src="apply_bounds_and_clusterize.js"
            type="text/javascript"
        ></script>
    </head>

    <style>
        body {
            font-family: "Arial";
            font-size: 11pt;
        }
    </style>
    <body>
        <p>Показаны кластеризованные результаты по запросу "Арбат"</p>
        <div id="map" style="width:400px; height:300px"></div>
    </body>
</html>
function init() {
    var myMap = new ymaps.Map("map", {
        center: [55.73, 37.75],
        zoom: 10,
    });

    // Сделаем запрос на геокодирование, а затем спозиционируем карту, чтобы
    // все объекты попадали в видимую область карты и коэффициент масштабирования был
    // максимально возможным.
    var result = ymaps
        .geoQuery(ymaps.geocode("Арбат"))
        .applyBoundsToMap(myMap);
    // Откластеризуем полученные объекты и добавим кластеризатор на карту.
    // Обратите внимание, что кластеризатор будет создан сразу, а объекты добавлены в него
    // только после того, как будет получен ответ от сервера.
    myMap.geoObjects.add(result.clusterize());
}
ymaps.ready(init);