2025Mapbox零基础入门教程(14)定位功能

实现Mapbox中定位功能的关键在于通过高德地图API获取当前位置信息,并将这些信息转换为经纬度坐标。

首先,通过调用高德地图的IP定位接口获取所在城市信息;其次,利用城市信息调用地理逆编码接口获取经纬度坐标;最后,使用Mapbox的flyTo方法将地图定位到指定坐标。整个过程中涉及了多个API的调用和数据的处理,如字符串的拼接、JSON的解析等,以实现准确的定位效果。

实现定位功能

复制代码
class MyLocationControl {
  onAdd(map) {
    this._map = map;
    this._container = document.createElement("div");
    this._container.className = "mapboxgl-ctrl my-location-control";
    this._container.textContent = "定位";
    return this._container;
  }

  onRemove() {
    this._container.parentNode.removeChild(this._container);
    this._map = undefined;
  }
}

const myLocationControl = new MyLocationControl();
map.addControl(myLocationControl, "top-left");
const myLocationControlBtn = document.querySelector(".my-location-control");
myLocationControlBtn.onclick = function () {
  // 获取当前的位置 navigator.geolocation.getCurrentPosition();
};

设置图标样式:

复制代码
.my-location-control {
  background-color: aqua; 
  border: 1px solid black; 
  border-radius: 5px; 
  padding: 4px;
}

使用高德API进行定位

找到高德API的IP定位接口,并发送请求,请求参数包括高德API key和默认IP地址,获取定位结果,并打印到控制台。

逆地理编码获取经纬度

使用高德API的逆地理编码接口,将城市名称转换为经纬度坐标。

使用flyTo或easeTo方法,将地图移动到当前位置,增加动画效果。

复制代码
class MyLocationControl {
  onAdd(map) {
    this._map = map;
    this._container = document.createElement("div");
    this._container.className = "mapboxgl-ctrl my-location-control";
    this._container.textContent = "定位";
    return this._container;
  }

  onRemove() {
    this._container.parentNode.removeChild(this._container);
    this._map = undefined;
  }
}
const GAODEKEY = "6306a665fdfd4bb5cac88647eb9dc34";
const myLocationControl = new MyLocationControl();
map.addControl(myLocationControl, "top-left");
const myLocationControlBtn = document.querySelector(".my-location-control");
myLocationControlBtn.onclick = async function () {
    // 获取当前的位置 navigator.geolocation.getCurrentPosition()
    const res = await fetch("https://restapi.amap.com/v3/ip?key=" + GAODEKEY);
    const data = await res.json();
    const _res = await fetch(
        `https://restapi.amap.com/v3/geocode/geo?address=${data.city}&key=${GAODEKEY}`
    );
    const _data = await _res.json();
    const lngLat = _data.geocodes[0].location.split(",");
    lngLat.map((item) => Number(item));
    map.flyTo({
        center: lngLat,
    });
};
相关推荐
小蜜蜂嗡嗡20 分钟前
【flutter对屏幕底部有手势区域(如:一条横杠)导致出现重叠遮挡】
前端·javascript·flutter
伍哥的传说1 小时前
Vue 3 useModel vs defineModel:选择正确的双向绑定方案
前端·javascript·vue.js·definemodel对比·usemodel教程·vue3.4新特性·vue双向绑定
胡gh6 小时前
页面卡成PPT?重排重绘惹的祸!依旧性能优化
前端·javascript·面试
胡gh7 小时前
简单又复杂,难道只能说一个有箭头一个没箭头?这种问题该怎么回答?
javascript·后端·面试
言兴7 小时前
# 深度解析 ECharts:从零到一构建企业级数据可视化看板
前端·javascript·面试
山有木兮木有枝_7 小时前
TailWind CSS
前端·css·postcss
烛阴8 小时前
TypeScript 的“读心术”:让类型在代码中“流动”起来
前端·javascript·typescript
杨荧8 小时前
基于Python的农作物病虫害防治网站 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python
Moment9 小时前
毕业一年了,分享一下我的四个开源项目!😊😊😊
前端·后端·开源
程序视点9 小时前
Escrcpy 3.0投屏控制软件使用教程:无线/有线连接+虚拟显示功能详解
前端·后端