6

我正在将 Leaflet 与 Mapbox 一起使用,我想设置地图的视图,以便:

  1. 所有标记都可见
  2. 中心设置为特定点

使用 setView 和 fitbounds 分别处理每个点很容易,但我不知道如何同时拥有这两个点,因为 setView 更改了边界,而 fitBounds 更改了中心。一个解决方案可能是定义一个中心和一个缩放,但我怎么知道哪个缩放可以让我的所有标记都可见?

编辑

我实施了 IvanSanchez 建议的解决方案,它按预期工作:

let ne=leafletBounds.getNorthEast();
let sw=leafletBounds.getSouthWest();
let neSymetric=[ne.lat + (center.lat - ne.lat)*2, ne.lng + (center.lng - ne.lng)*2];
let swSymetric=[sw.lat +(center.lat - sw.lat)*2, sw.lng + (center.lng - sw.lng)*2];
leafletBounds.extend(L.latLngBounds(swSymetric, neSymetric));
4

2 回答 2

4

获取边界,并通过沿所需中心点应用点对称来创建第二个L.Bounds实例。创建一个L.Bounds包含原始边界和对称边界的新边界。带着它跑fitBounds()

于 2016-06-27T10:33:57.507 回答
0

我找到了另一个解决方案。使用 fitBound() 调整地图后,您可以简单地调用 map.panTo([lat, lng])。我正在使用 VueJs 并在 mount() 生命周期挂钩中调用它。

我正在拟合边界,因此您可以看到用户的位置以及远处的地理特征,但随后我使用 panTo,因此用户的真实位置在 fitBounds 之后位于地图的中心。到目前为止,它似乎可以无缝运行。

于 2017-08-18T06:30:34.863 回答