Вы должны сделать google.maps.LatLngBounds.union
с google.maps.Circle.getBounds()
zoomToMarkers: map => {
if (!map) { return }
const bounds = new window.google.maps.LatLngBounds()
if (map.props.children.length !== 0) {
map.props.children.forEach((child) => {
bounds.union(child.props.getBounds())
})
map.fitBounds(bounds)
}
}
доказательством концепции скрипки (из примера круга Google)
кодафрагмент:
function initMap() {
// Create the map (centered and zoomed on Chicago)
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 18,
center: {
lat: 41.878,
lng: -87.629
},
mapTypeId: 'terrain'
});
var bounds = new google.maps.LatLngBounds();
for (var city in citymap) {
// Add the circle for this city to the map.
var cityCircle = new google.maps.Circle({
strokeColor: '#FF0000',
strokeOpacity: 0.8,
strokeWeight: 2,
fillColor: '#FF0000',
fillOpacity: 0.35,
map: map,
center: citymap[city].center,
radius: Math.sqrt(citymap[city].population) * 100
});
bounds.union(cityCircle.getBounds())
}
// fit the map to the circles
map.fitBounds(bounds);
}
var citymap = {
chicago: {
center: {
lat: 41.878,
lng: -87.629
},
population: 2714856
},
newyork: {
center: {
lat: 40.714,
lng: -74.005
},
population: 8405837
},
losangeles: {
center: {
lat: 34.052,
lng: -118.243
},
population: 3857799
},
vancouver: {
center: {
lat: 49.25,
lng: -123.1
},
population: 603502
}
};
#map,
html,
body {
height: 100%;
margin: 0;
padding: 0;
}
<div id="map"></div>
<!-- Replace the value of the key parameter with your own API key. -->
<script async defer src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCkUOdZ5y7hMm0yrcCQoCvLwzdM6M8s5qk&callback=initMap">
</script>