Google Map несколько маршрутов с обновлением в реальном времени для новых маршрутов - PullRequest
0 голосов
/ 26 июня 2018

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

jsfiddle.net / mattlokk / mp3q292r / 15 /

1 Ответ

0 голосов
/ 26 июня 2018

Что ты имеешь в виду без мерцания.

Мигает ли это при добавлении маршрутов с помощью кнопки «Добавить маршрут»?

Если да, вы можете показать загрузчик поверх карты на секунду или две, а затем скрыть его.

var routes = [];
var colors = ["blue", "red", "green", "black", "cyan", "brown", "purple"];
var map, directionsService;

function initialize() {
  routes.push({
    origin: new google.maps.LatLng(34.04429454929703, -118.22793351693724),
    destination: new google.maps.LatLng(33.688522885631706, -116.15151750131224),
    travelMode: google.maps.DirectionsTravelMode.DRIVING,
    waypoints: []
  });

  routes.push({
    origin: new google.maps.LatLng(32.69561555501597, -117.06338273568724),
    destination: new google.maps.LatLng(34.525395303965354, -117.27212297006224),
    travelMode: google.maps.DirectionsTravelMode.DRIVING,
    waypoints: []
  });

  var mapOptions = {
    center: new google.maps.LatLng(42.5584308, -70.8597732),
    zoom: 3,
    mapTypeId: google.maps.MapTypeId.ROADMAP
  };

  map = new google.maps.Map(document.getElementById("map_canvas"), mapOptions);
  directionsService = new google.maps.DirectionsService();

  for (var i = 0; i < routes.length; i++) {
    directionsService.route(routes[i], displayRoute(colors[i]));
  }

};

function displayRoute(color) {
  return function(response, status) {
    if (status == google.maps.DirectionsStatus.OK) {
      directionsDisplay = new google.maps.DirectionsRenderer({
        polylineOptions: {
          strokeColor: color
        },
        suppressMarkers: false,
        suppressInfoWindows: true
      });
      directionsDisplay.setMap(map);
      directionsDisplay.setDirections(response);
    }
  }
}

document.getElementById('add-route').addEventListener('click', function(e) {

  var origin = new google.maps.LatLng(34.04429454929703 + Math.random(), -118.22793351693724 - Math.random());
  var destination = new google.maps.LatLng(33.688522885631706 + Math.random(), -116.15151750131224 - Math.random());
  var route = {
    origin: origin,
    destination: destination,
    travelMode: google.maps.DirectionsTravelMode.DRIVING,
    waypoints: []
  };

  routes.push(route);

  var color = colors[routes.length - 1];
  directionsService.route(route, displayRoute(color));

  if (routes.length === colors.length) {
    this.style.display = 'none';
  }
});


document.getElementById('add-waypoint').addEventListener('click', function(e) {

  var rand = Math.floor(Math.random() * routes.length);
  var route = routes[rand];
  route.waypoints.push({
    location: new google.maps.LatLng(34.04429454929703 + Math.random(), -118.22793351693724 - Math.random()),
    stopover: true
  });

  var color = colors[rand];
  directionsService.route(route, displayRoute(color));
});
html,
body,
#map_canvas {
  margin: 0;
  padding: 0;
  height: 100%
}

.as-console-wrapper {
  display: none !important;
}

#add-route {
  position: absolute;
  top: 1px;
  right: 1px;
}

#add-waypoint {
  position: absolute;
  top: 1px;
  right: 80px;
}
<script async defer type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key=AIzaSyC7lDrYPDmJz1JsQh2rbWA9uRZHcFk_xJY&callback=initialize"></script>

<div id="map_canvas"></div>

<button id="add-waypoint" title="Randomly adding waypoint">Add Waypoint</button>
<button id="add-route" title="Add random route">Add Route</button>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...