Что ты имеешь в виду без мерцания.
Мигает ли это при добавлении маршрутов с помощью кнопки «Добавить маршрут»?
Если да, вы можете показать загрузчик поверх карты на секунду или две, а затем скрыть его.
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>