React工程中用百度地图实现可检索和标注功能

前言:

项目需要设置学员上课签到的打卡定位经纬度,所以需要调用地图api来获取坐标点。

调研后决定使用百度地图api,项目是react技术栈,所以使用了 React-BMapGL npm包,这个包也是百度地图官方推荐的方案。

应用:

  1. 先注册百度账号,申请认证成为开发者,然后在应用管理中增加应用获取 ak
xml 复制代码
<script type="text/javascript" src="//api.map.baidu.com/api?type=webgl&v=1.0&ak=您的密钥">
</script>
  1. 安装 react-bmapgl

npm install react-bmapgl --save

  1. 在项目中使用
jsx 复制代码
import ZoomControl from "react-bmapgl/Control/ZoomControl";
import Map from "react-bmapgl/Map";
import AutoComplete from "react-bmapgl/Services/AutoComplete";
    // 创建地理编码实例, 并配置参数获取乡镇级数据
    myGeo = new BMapGL.Geocoder({ extensions_town: true });


    const mapRef = useRef(null);


    const onMapClick = (e) => {
        const pt = e.latlng;
        // 根据坐标得到地址描述
        myGeo.getLocation(new BMapGL.Point(pt.lng, pt.lat), function (result) {
          if (result) {
            const surroundingPois = result?.surroundingPois || [];
            const surroundingAddress = `${surroundingPois?.[0]?.address || ""}${
              surroundingPois?.[0]?.title || ""
            }`;
            setAddress(surroundingAddress || result.address);
            setPlace(surroundingAddress || result.address);
          }
        });
    };


    const setPlace = (myValue) => {
        let mapInstance = mapRef.current.map;
        mapInstance.clearOverlays(); //清除地图上所有覆盖物
        var local = new BMapGL.LocalSearch(mapInstance, {
          //智能搜索
          onSearchComplete: () => {
            let pp = local.getResults().getPoi(0).point; //获取第一个智能搜索的结果
            mapInstance.centerAndZoom(pp, 15);
            mapInstance.addOverlay(new BMapGL.Marker(pp)); //添加标注
            if (scope) {
              const circle = new BMapGL.Circle(pp, scope, {
                strokeColor: "#f00",
                strokeWeight: 2,
                fillColor: "#ff0",
                fillOpacity: 0.3,
              });
              mapInstance.addOverlay(circle); //添加范围
            }
            setPoint(pp);
          },
        });
        local.search(myValue);
      };
    <Input
         style={{ marginBottom: 20 }}
         id='selectAddressInput'
         value={address}
         onChange={(e) => handleChangeInput(e)}
         placeholder='请输入地点'
         maxLength={100}
    />
    <AutoComplete
        input='selectAddressInput'
        onConfirm={(e) => {
          const { province, city, district, street, business } = e.item.value;
          setAddress(`${province}${city}${district}${street}${business}`);
          setPlace(`${province}${city}${district}${street}${business}`);
          setTimeout(() => {
            let arr = document.querySelectorAll(".tangram-suggestion-main");
            arr[arr.length - 1].style.display = "none";
            }, 300);
          }}
     />
    <Map
        ref={mapRef}
        center={new BMapGL.Point(116.404449, 39.914889)}
        zoom={12}
        onClick={onMapClick}
        enableDoubleClickZoom={false}
        enableScrollWheelZoom={true}
    >
         <ZoomControl />
    </Map>

默认展示

搜索地点

选中地点,改变中心并且加标注

代码讲解:

以上代码引入了 Map ZoomControl AutoComplete 三个组件,分别是地图,缩放控件,结果提示服务。

  1. 创建创建地理编码实例 new BMapGL.Geocoder()

  2. 当点击地图时,根据坐标点可以得到地址描述 myGeo.getLocation,设置地址描述

  3. 设置点击的地点,通过Ref获取地图实例,清除地图上的覆盖物,输入地址描述调用检索服务查询第一个智能搜索地点的坐标点,然后将中心定在这个坐标点(centerAndZoom),并添加标注(addOverlay(new BMapGL.Marker(pp)))

  4. 结果提示服务在点击确认服务后,会根据检索服务返回的数值重新设置地址描述,重置中心点和更新标注。

总结:

将这个组件封装后可以作为表单组件使用,只需求提供 value 属性和 onChange 方法即可,value作为初始值,onChange时将最新值回调传出,后续应用就不用再研究百度地图具体的api,只需要引用这个组件就可以方便的渲染可搜索和加标注的地图组件,并获取坐标点和地址描述。

相关推荐
han_几秒前
一篇看懂国内外主流大模型:GPT、Claude、Gemini、DeepSeek、通义千问有什么区别?
前端·人工智能·llm
一行代码一行诗++9 分钟前
注释是什么和注释该怎么写(C语言)
java·前端·javascript
涂兵兵_青石疏影16 分钟前
beginPath-vs-save详解
前端
陈振wx:zchen200817 分钟前
前端-面试题-JavaScript
javascript·前端面试题
泽_浪里白条28 分钟前
我在 Superset 6.x 做自定义图表 + Embedded SDK 集成的实战复盘(附踩坑清单)
前端·数据可视化
幽络源小助理1 小时前
小六壬排盘工具源码 自适应双端 纯原生HTML+JS
前端·javascript·html
Championship.23.242 小时前
Open Source Pipeline Skill深度解析:自动化开源贡献全流程
前端·javascript·html
Bigger2 小时前
🧠 前端岗位的"结构性调整":现象背后的冷思考
前端·程序员·ai编程
薯老板2 小时前
vue组件之间的通信
前端·vue.js
迪菲赫尔曼2 小时前
从 0 到 1 打造工业级推理控制台:UltraConsole(Ultralytics + FastAPI + React)开源啦!
前端·yolo·react.js·计算机视觉·开源·fastapi