49 / 49 / 3
Регистрация: 15.11.2009
Сообщений: 372

Расчет протяженности автомобильного пути с подключением к Яндекс.Карты API (не работает цикл)

27.02.2014, 02:45. Показов 4824. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем примет!
Подскажите пожалуйста в чем здесь может быть проблема:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>Добавление маршрута на карту - API Яндекс.Карт 2.х</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
 
<script src="http://yandex.st/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
 
    <script src="http://api-maps.yandex.ru/2.0/?load=package.full&lang=ru-RU" type="text/javascript"></script>
    <script type="text/javascript"> 
        var myMap, route;
 
        ymaps.ready(init);
 
        function init () 
        {
            myMap = new ymaps.Map("map", {center: [56.326944, 44.0075],zoom: 12}); 
            
            var myFamily = new Array(
            [57.6198, 39.8554, 55.7536, 37.6198],
            [58.0446, 38.8426, 55.7536, 37.6198],
            [56.9972, 40.9714, 55.7536, 37.6198],
            [57.7665, 40.9269, 55.7536, 37.6198],
            [58.4807, 41.5370, 55.7536, 37.6191]
            );
            
               for (var i = 0; i < myFamily.length; i++)
                  { 
                      $('#search_route').submit(function ()
                            {
                               ymaps.route([[myFamily[i][0], myFamily[i][1]], [myFamily[i][2], myFamily[i][3]]], { mapStateAutoApply: true}).then(function (router) 
                                  {  
                                      route && myMap.geoObjects.remove(route);
                                      route = router;
                                      myMap.geoObjects.add(route);
                                      $('#list').append((Math.round(router.getLength() / 1000))+"<br>");
                                  }, function (error) { alert("Возникла ошибка: " + error.message); }); return false;
                            });
                   };
         }   
    </script>
</head>
 
<body>
       <form id="search_route">
          <input type="submit" value="Найти"/>
       </form>
       <br>        
       <div id="map" style="width:800px;height:600px"></div>
       <br>
       <b>Расстояние между точками:</b>
       <div id="list"></div>
</body>
</html>
Необходимо вычислить протяженность автомобильного пути между 4-мя объектами, координаты которых находятся в данном массиве:
JavaScript
1
2
3
4
5
6
7
var myFamily = new Array(
            [57.6198, 39.8554, 55.7536, 37.6198],
            [58.0446, 38.8426, 55.7536, 37.6198],
            [56.9972, 40.9714, 55.7536, 37.6198],
            [57.7665, 40.9269, 55.7536, 37.6198],
            [58.4807, 41.5370, 55.7536, 37.6191]
            );
Если считать путь только для двух объектов, то все нормально работает (код ниже):
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>Добавление маршрута на карту - API Яндекс.Карт 2.х</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
 
<script src="http://yandex.st/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
 
    <script src="http://api-maps.yandex.ru/2.0/?load=package.full&lang=ru-RU"
            type="text/javascript"></script>
    <script type="text/javascript"> 
        var myMap, route;
 
        ymaps.ready(init);
 
        function init () 
        {
            myMap = new ymaps.Map("map", {center: [56.326944, 44.0075],zoom: 12}); 
            
            
              $('#search_route').submit(function () //Ярославль-Москва
              {
                 ymaps.route([[57.6198, 39.8554], [55.7536, 37.6198]], { mapStateAutoApply: true}).then(function (router) 
                   {
                       route && myMap.geoObjects.remove(route);
                       route = router;
                       myMap.geoObjects.add(route); 
                       
                       $('#list').append((Math.round(router.getLength() / 1000))+"<br>");
                   }, function (error) { alert("Возникла ошибка: " + error.message); }); return false;
              });
              $('#search_route').submit(function () //Рыбинск-Москва
              {
                 ymaps.route([[58.0446, 38.8426], [55.7536, 37.6198]], { mapStateAutoApply: true}).then(function (router) 
                   {
                       route && myMap.geoObjects.remove(route);
                       route = router;
                       myMap.geoObjects.add(route); 
                       
                       $('#list').append(Math.round(router.getLength() / 1000));
                   }, function (error) { alert("Возникла ошибка: " + error.message); }); return false;
              });
              
              
        }    
    </script>
</head>
 
<body>
       <form id="search_route">
          <input type="submit" value="Найти"/>
       </form>
       <br>        
       <div id="map" style="width:800px;height:600px"></div>
       <br>
       <b>Расстояние между точками:</b>
       <div id="list"></div>
</body>
</html>
В коде выше 2 раза посылаются данные, что является проблемой, так как нужен скрипт, который бы считал протяженность пути между большим количеством пар объектов (около 2500), которые бы брались из массива (идеально считывались бы из файла).

Через цикл не могу реализовать. Очень надеюсь на вашу помощь.)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.02.2014, 02:45
Ответы с готовыми решениями:

яндекс карты api
зжравствуйте, пытаюсь построить маршрут на яндекс карте, но у меня ничего не получается, подскажите почему при нажатии на кнопку у меня не...

API Яндекс.Карты
Всем привет. Ребят, можно ли меткам на карте добавить label? В офф.документации не нашел или плохо искал

Переводчик с подключением Яндекс API
Консольное приложение. Задача такая. Входной файл - input.txt, в котором текст на каком либо языке (без примесей других языков),...

2
1 / 1 / 1
Регистрация: 10.12.2011
Сообщений: 16
27.02.2014, 11:27
Лично у меня были проблема с циклом при геолокации.( по аякс запрос получал список городов и циклом искал координаты, появлялась метка только последнего элемента+путаница в hintContent). помогло вместо цикла использовать $.each(list, function(key, val) {..}) в моем случаи выглядело так

JavaScript
1
2
3
4
5
6
7
  $.post('/index.php?r=city/list',{id:id_country},function(data){
      var list = JSON.parse(data);
      $.each(list, function(key, val)   {
         ....................
         ...................
      });
 });
(Ps хотя скорей всего проблема в том что ymaps.route - работает асинхронно , и итерации проходят быстрей чем получения ответа от yandex - только догадки, не уверен )
1
49 / 49 / 3
Регистрация: 15.11.2009
Сообщений: 372
28.02.2014, 00:19  [ТС]
Попробую через each()

Добавлено через 2 часа 52 минуты
Ничего не получается(

Добавлено через 41 минуту
Нашел рабочий вариант, реализация другая, но считает, тоже только для двух точек. Помогите пожалуйста переделать код так, чтобы за один раз считало расстояние для массива объектов.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<html xmlns="http://www.w3.org/1999/xhtml">
 
<head>
    <title>Summury distance. Transport</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script src="http://api-maps.yandex.ru/1.1/index.xml?key=ANpUFEkBAAAAf7jmJwMAHGZHrcKNDsbEqEVjEUtCmufxQMwAAAAAAAAAAAAvVrubVT4btztbduoIgTLAeFILaQ==" type="text/javascript"></script>
 
    <script type="text/javascript">
 
            
            function getDistanceFor2Point(Point1, Point2) {
                                  
                var router = new YMaps.Router([Point1, Point2]);
                
                YMaps.Events.observe(router, router.Events.GeocodeError, function (link, number) {
                   alert('Ошибка при геокодировании точки № ' + number);
                })
 
                YMaps.Events.observe(router, router.Events.RouteError, function (link, number) {
                  alert('Не удается проложить маршрут до точки № ' + number);
                }); 
                
                //Add
 
                YMaps.Events.observe(router, router.Events.Success, function() {
                summuryDistance = router.getDistance();    
                
                var x = document.getElementById('finallyTab').insertRow(0)
                var p1_cell=x.insertCell(0);
                var p2_cell=x.insertCell(1);
                var d_cell=x.insertCell(2);
                
                //Fill
 
                p1_cell.innerHTML=Point1;
                p2_cell.innerHTML=Point2;
                d_cell.innerHTML = Math.round(summuryDistance/1000);
                
 
               });
               
            }
    </script>
</head>
 
<body onLoad="javascript:getDistanceFor2Point('39.8554, 57.6198','37.6198, 55.7536')">
 
<table id="finallyTab" width="488" border="1">
  <tr>
    <td width="165"></td>
    <td width="214"></td>
    <td width="87"></td>
  </tr>
</table>
 
   
</body>
 
</html>
Очень надеюсь на вашу помощь.

Добавлено через 8 часов 13 минут
Неужели никто не может хоть чем-то помочь???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.02.2014, 00:19
Помогаю со студенческими работами здесь

Яндекс карты API
Прошу прощения, если пишу не в ту тему Подскажите, пожалуйста, кто пользуется. Есть ли в API Яндекса возможность добавлять точки на...

множественное геокодирование, api яндекс карты
необходимо обработать массив адресов и положить в базу, средства: php+mysql+java script. неверно обрабатывается в приведенном куске...

Как собрать станции метро по адресу (C#, Яндекс Карты API)?
Здравствуйте. Могу отблагодарить денежно. Есть поле, которое содержит адрес, нужно это поле трансформировать в станцию метро. У яндекс...

Google Maps API. Расчет времени и расстояния пути. За сколько сделаете?
Здравствуйте. Пытался разобраться в Google api, но не очень получилось, да. Вообщем, кто может сделать расчет времени и расстояния пути с...

Java Android - сделать кнопку "показать адрес на карте", которая вызывает яндекс-карты или яндекс-навигатор и гугл-карты
Доброго дня, формучане! Подскажите, как сделать возможность из моего приложения при клике по кнопке &quot;Показать на карте&quot; перейти...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru