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,只需要引用这个组件就可以方便的渲染可搜索和加标注的地图组件,并获取坐标点和地址描述。

相关推荐
轻口味24 分钟前
命名空间与模块化概述
开发语言·前端·javascript
前端小小王1 小时前
React Hooks
前端·javascript·react.js
迷途小码农零零发1 小时前
react中使用ResizeObserver来观察元素的size变化
前端·javascript·react.js
娃哈哈哈哈呀2 小时前
vue中的css深度选择器v-deep 配合!important
前端·css·vue.js
旭东怪2 小时前
EasyPoi 使用$fe:模板语法生成Word动态行
java·前端·word
ekskef_sef4 小时前
32岁前端干了8年,是继续做前端开发,还是转其它工作
前端
sunshine6414 小时前
【CSS】实现tag选中对钩样式
前端·css·css3
真滴book理喻4 小时前
Vue(四)
前端·javascript·vue.js
蜜獾云4 小时前
npm淘宝镜像
前端·npm·node.js