Форум программистов, компьютерный форум, киберфорум
JavaScript: API
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/25: Рейтинг темы: голосов - 25, средняя оценка - 4.52
49 / 49 / 3
Регистрация: 15.11.2009
Сообщений: 372

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

27.02.2014, 02:45. Показов 4817. Ответов 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): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru