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
|
import { useEffect } from 'react';
import maplibregl from 'maplibre-gl';
import { map } from './core/MapView';
const MapCamera = ({
latitude, longitude, positions,
}) => {
useEffect(() => {
if (positions) {
const coordinates = positions.map((item) => [item.longitude, item.latitude]);
if (coordinates.length) {
const bounds = coordinates.reduce((bounds, item) => bounds.extend(item), new maplibregl.LngLatBounds(coordinates[0], coordinates[1]));
const canvas = map.getCanvas();
map.fitBounds(bounds, {
padding: Math.min(canvas.width, canvas.height) * 0.1,
duration: 0,
});
}
} else {
map.jumpTo({
center: [longitude, latitude],
zoom: Math.max(map.getZoom(), 10),
});
}
}, [latitude, longitude, positions]);
return null;
};
export default MapCamera;
|