Leaflet中定位单个或多个实体图形视图

效果

在这里插入图片描述

代码

定位单个实体

const latlngs = [
    [45.51, -122.68],
    [37.77, -122.43],
    [34.04, -118.2]
];

const polyline = L.polyline(latlngs, {color: 'red'}).addTo(map);

// 将地图缩放到折线
map.fitBounds(polyline.getBounds());

定位多个实体

const polyline1 = L.polyline([
  [51.5, -0.1],
  [51.6, -0.2],
]);

const polyline2 = L.polyline([
  [51.7, -0.3],
  [51.8, -0.4],
]);

// 添加到地图
polyline1.addTo(map);
polyline2.addTo(map);

// 创建一个空的 LatLngBounds 对象,用于存储所有 polyline 的边界框
let bounds = new L.LatLngBounds(polyline1.getBounds()); // 获取 polyline1 的边界初始化

// 将每条 polyline 的边界框扩展到整体边界框中
bounds.extend(polyline1.getBounds());
bounds.extend(polyline2.getBounds());

// 定位视图到合并后的整体边界框
map.fitBounds(bounds);

注意

虽然获取了polyline1作为初始化,但依然需要extend添加扩展,否则无法定位到该实体

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值