精华内容
下载资源
问答
  • uniapp写的基于腾讯地图的微信小程序的电子围栏(服务范围),里面的key换成自己再腾讯地图api官网申请的,如果哪里有写的不好的地方,请多多谅解!
  • 高德web端实现多边形电子围栏demo 地图上点三个点形成多边形区域,可以通过拉拽添加点的形式添加边的数量 可判断marker是否在多边形区域区域内(jQuery需要自己添加)
  • 我在网上找的各种画电子围栏,全部都是第二个方式,不知道怎么画出来的。。。。 而第一个github上有源码,吼吼吼,issues 0!!!!! 我去,真不知道大家怎么画出来。。。。 而且第一个,明显就是对的感觉,有option,...

    解决:用下面的方法绘制:

    https://lbs.amap.com/dev/demo/location-geofence#Android

    不要用下面这个指导方案,如果你引入的包和他不一样的话,因为你引入的一般是Amap3DMap,估计下面的还是老版本,:

    https://lbs.amap.com/api/android-location-sdk/guide/additional-func/local-geofence

    我下载了官方文档,看了,下面的的确可以画出来,但是。。。。他引入的sdk包截图如下:

    Amap_location.png

    我项目包是这个:

    AMap3DMap_AmapNavi.....png

    然后,我就开始按照他官方很容易搜到的文档开始做了。。。。。结果找了一早上,都不知道自己哪里错了。。。。

    莫名感觉是自己的包和他的包不一样,所以,就在官方搜索了Amap3DMap下的 GeoFence,然后很不容易的搜到了第一个。。。

    我在网上找的各种画电子围栏,全部都是第二个方式,不知道怎么画出来的。。。。

    而第一个github上有源码,吼吼吼,issues 0!!!!!

    我去,真不知道大家怎么画出来。。。。

    而且第一个,明显就是对的感觉,有option,可以设置fill and stroke。。。

    反正,踩过坑,记录下。。。太tm坑了。。。

    展开全文
  • vue电子地图围栏

    2019-03-01 16:43:08
    vue电子地图围栏,只包含前端代码,后台需要根据自己需要连接起来
  • Vue百度地图电子围栏

    千次阅读 2020-11-12 11:25:23
    element-ui、v-region(地区选择器)、百度地图v3.0、DrawingManager(绘制工具) 1、index.html 引入百度地图v3.0、DrawingManager 2、packpage.json 引入element-ui、v-region 3、main.js .
    • 主要功能

    支持多边形、圆形、矩形、行政区域绘制 

    • 在线访问地址

    http://wecode2020.gitee.io/bmap-hurdle/

    • 码云仓库地址

    https://gitee.com/wecode2020/bmap-hurdle

    • 界面预览

    • 主要依赖引入

    element-ui、v-region(地区选择器)、百度地图v3.0、DrawingManager(绘制工具)

    1、index.html 引入百度地图v3.0、DrawingManager

    2、packpage.json 引入element-ui、v-region

    3、main.js 

    • 主要代码 Index.vue

    <template>
    
      <el-container>
        <!-- 头部 -->
        <el-header>
          <el-page-header @back="goBack" content="电子围栏绘制">
          </el-page-header>
        </el-header>
    
        <!-- 中间 -->
        <el-main>
          <!-- 地图 -->
          <div id="map-container"></div>
    
          <!-- 左侧操作区 -->
          <div class="s-control-l">
            <v-region @values="regionChange" class="form-control"></v-region>
            <el-button type="primary" size="small" style="margin-left:20px;" @click="drawRegion">绘制区域</el-button>
          </div>
    
          <!-- 右侧操作区 -->
          <div class="s-control-r">
            <el-form :inline="true" class="demo-form-inline">
              <el-form-item label="" style="margin-right:30px;">
                <el-input v-model.lazy="keyword" placeholder="请输入地名" prefix-icon="el-icon-search" clearable>
                </el-input>
              </el-form-item>
              <el-form-item label="">
                <el-radio-group v-model="radioSelect" size="mini">
                  <el-radio-button label="none"><span class="s-icon s-icon-select"></span></el-radio-button>
                  <el-radio-button label="circle"><span class="s-icon s-icon-circle"></span>
                  </el-radio-button>
                  <el-radio-button label="polygon"><span class="s-icon s-icon-polygon"></span>
                  </el-radio-button>
                  <el-radio-button label="rectangle"><span class="s-icon s-icon-rectangle"></span>
                  </el-radio-button>
                </el-radio-group>
              </el-form-item>
              <!-- 地区检索显示区 -->
              <div id="search-result"></div>
            </el-form>
          </div>
        </el-main>
    
        <!-- 尾部 -->
        <el-footer>
          <el-row type="flex" class="row-bg" justify="end" style="margin:14px 0 0 0;">
            <el-button type="" size="small" style="margin-left:20px;" @click="goBack">返回</el-button>
            <el-button type="primary" size="small" style="margin-left:20px;" @click="saveHurdle">保存</el-button>
          </el-row>
        </el-footer>
      </el-container>
    
    </template>
    <script>
    export default {
      name: "index",
    
      data() {
        return {
          center: { lng: 116.93761, lat: 40.059866 }, // 中心点坐标
          zoom: 11, // 缩放级别
          location: "吉安市",
          keyword: "",
          radioSelect: "none",
          styleOptions: {
            strokeColor: "#5E87DB", // 边线颜色
            fillColor: "#5E87DB", // 填充颜色。当参数为空时,圆形没有填充颜色
            strokeWeight: 2, // 边线宽度,以像素为单位
            strokeOpacity: 1, // 边线透明度,取值范围0-1
            fillOpacity: 0.2, // 填充透明度,取值范围0-1
          },
          labelOptions: {
            borderRadius: "2px",
            background: "#FFFBCC",
            border: "1px solid #E1E1E1",
            color: "#703A04",
            fontSize: "12px",
            letterSpacing: "0",
            padding: "5px",
          },
          map: null, // 百度地图
          drawingManager: null, // 鼠标绘制工具
          localSearch: null, // 地区检索
          region: {}, // 行政区域
        };
      },
    
      watch: {
        // 绘制类型变更
        radioSelect(nval, oval) {
          if (nval != "none") {
            this.clearOverlays();
            this.drawingManager.close();
            this.draw(nval);
          } else {
            this.drawingManager.close();
          }
        },
        // 地区检索关键字变更
        keyword(nval, oval) {
          this.localSearch.clearResults();
          this.localSearch.search(nval);
        },
      },
    
      mounted() {
        // 创建Map实例
        this.map = new BMap.Map("map-container", {
          enableMapClick: false,
          minZoom: 5,
          maxZoom: 15,
        });
        // 设置中心点坐标和地图级别
        this.map.centerAndZoom(
          new BMap.Point(this.center.lng, this.center.lat),
          this.zoom
        );
        // 开启鼠标滚轮缩放
        this.map.enableScrollWheelZoom(true);
    
        // 创建鼠标绘制工具
        this.drawingManager = new BMapLib.DrawingManager(this.map, {
          // isOpen: true, //是否开启绘制模式
          enableCalculate: true, // 绘制是否进行测距(画线时候)、测面(画圆、多边形、矩形)
          drawingToolOptions: {
            enableTips: true,
            customContainer: "selectbox_Drawing",
            hasCustomStyle: true,
            offset: new BMap.Size(5, 5), // 偏离值
            scale: 0.8, // 工具栏缩放比例
            drawingModes: [
              BMAP_DRAWING_RECTANGLE,
              BMAP_DRAWING_POLYGON,
              BMAP_DRAWING_CIRCLE,
            ],
          },
          enableSorption: true, // 是否开启边界吸附功能
          sorptionDistance: 20, // 边界吸附距离
          enableGpc: true, // 是否开启延边裁剪功能
          enbaleLimit: true, // 是否开启超限提示
          // limitOptions: {
          //     area: 50000000 // 面积超限值
          // },
          circleOptions: this.styleOptions, // 圆的样式
          polylineOptions: this.styleOptions, // 线的样式
          polygonOptions: this.styleOptions, // 多边形的样式
          rectangleOptions: this.styleOptions, // 矩形的样式
          labelOptions: this.labelOptions, // label的样式
        });
    
        // 实例化地区检索
        this.localSearch = new BMap.LocalSearch(this.map, {
          renderOptions: { map: this.map, panel: "search-result" },
        });
    
        // 加载围栏数据
        this.loadHurdle();
      },
    
      methods: {
        // 清除地图覆盖物
        clearOverlays() {
          this.map.clearOverlays();
        },
    
        // 绘制圆、矩形、多边形
        draw(type) {
          var arr = document.getElementsByClassName("bmap-btn");
          for (var i = 0; i < arr.length; i++) {
            arr[i].style.backgroundPositionY = "0";
          }
          switch (type) {
            case "marker": {
              var drawingType = BMAP_DRAWING_MARKER;
              break;
            }
            case "polyline": {
              var drawingType = BMAP_DRAWING_POLYLINE;
              break;
            }
            case "rectangle": {
              var drawingType = BMAP_DRAWING_RECTANGLE;
              break;
            }
            case "polygon": {
              var drawingType = BMAP_DRAWING_POLYGON;
              break;
            }
            case "circle": {
              var drawingType = BMAP_DRAWING_CIRCLE;
              break;
            }
          }
          // 进行绘制
          if (
            this.drawingManager._isOpen &&
            this.drawingManager.getDrawingMode() === drawingType
          ) {
            this.drawingManager.close();
          } else {
            this.drawingManager.setDrawingMode(drawingType);
            this.drawingManager.open();
          }
        },
    
        // 绘制行政区域
        drawRegion() {
          if (!this.region.value) {
            this.$message({
              message: "操作失败,请选择区域",
              type: "error",
            });
            return;
          }
          this.radioSelect = "none";
          var bdary = new BMap.Boundary();
          bdary.get(this.region.value, (rs) => {
            //获取行政区域
            this.map.clearOverlays(); //清除地图覆盖物
            var count = rs.boundaries.length; //行政区域的点有多少个
            if (count === 0) {
              alert("未能获取当前输入行政区域");
              return;
            }
            var pointArray = [];
            for (var i = 0; i < count; i++) {
              console.log(rs.boundaries[i]);
              var ply = new BMap.Polygon(rs.boundaries[i], this.styleOptions); //建立多边形覆盖物
              var str = JSON.stringify(ply.ia); //将BMap获取的行政区边界经纬度转为字符串
              this.map.addOverlay(ply); //添加覆盖物
              pointArray = pointArray.concat(ply.getPath());
            }
            this.map.setViewport(pointArray); //调整视野
          });
        },
    
        // 返回
        goBack() {},
    
        // 切换地区
        regionChange(data) {
          this.region = data.area || data.city || data.province || {};
        },
    
        // 加载围栏数据
        async loadHurdle() {
          const {
            data: { points },
          } = await this.$http.get("/api/getCurrent");
          var pointsArr = JSON.parse(points);
          var pathArr = [];
          pointsArr.forEach((item) => {
            var ply = new BMap.Polygon(item, this.styleOptions); //建立多边形覆盖物
            this.map.addOverlay(ply); //添加覆盖物
            pathArr = pathArr.concat(ply.getPath());
          });
          this.map.setViewport(pathArr); //调整视野
        },
    
        // 保存围栏数据
        saveHurdle() {
          var overlays = this.map.getOverlays();
          var pointsStrArr = [];
          overlays.forEach((item) => {
            if (item.getPath) {
              var pointsStr = this.pointsToStr(item.getPath());
              pointsStr && pointsStrArr.push(pointsStr);
            }
          });
          if (pointsStrArr.length == 0) {
            this.$message({
              message: "操作失败,您没用绘制任何有效区域",
              type: "error",
            });
            return;
          }
    
          // 后台保存需要的路径坐标数据
          const data = JSON.stringify(pointsStrArr);
          alert(data);
        },
    
        // 坐标点数组转字符串
        pointsToStr(points) {
          if (!points) return "";
          var str = "";
          points.forEach((item) => {
            str += item.lng + "," + item.lat + ";";
          });
          return str.slice(0, -1);
        },
      },
    };
    </script>
    
    <style>
    .el-container {
      height: 100%;
    }
    
    .el-main {
      position: relative;
      padding: 0;
    }
    
    .el-page-header,
    .el-footer {
      line-height: 60px;
    }
    
    .rg-select__el {
      background: #ffffff !important;
    }
    
    #map-container {
      width: 100%;
      height: 100%;
    }
    
    #search-result {
      width: 400px;
    }
    
    .s-control-l {
      display: flex;
      flex-direction: row;
      position: absolute;
      left: 30px;
      top: 30px;
      z-index: 999;
    }
    
    .s-control-r {
      display: flex;
      flex-direction: row;
      position: absolute;
      right: 30px;
      top: 30px;
      z-index: 999;
    }
    
    .s-search {
      width: 400px;
    }
    
    .s-icon {
      display: inline-block;
      width: 24px;
      height: 24px;
      background-size: 100% 100%;
      background-repeat: no-repeat;
    }
    
    .s-icon.s-icon-select {
      background-image: url();
    }
    .el-radio-button.is-active .s-icon.s-icon-select {
      background-image: url();
    }
    
    .s-icon.s-icon-circle {
      background-image: url();
    }
    .el-radio-button.is-active .s-icon.s-icon-circle {
      background-image: url();
    }
    
    .s-icon.s-icon-polygon {
      background-image: url();
    }
    .el-radio-button.is-active .s-icon.s-icon-polygon {
      background-image: url();
    }
    .s-icon.s-icon-rectangle {
      background-image: url();
    }
    .el-radio-button.is-active .s-icon.s-icon-rectangle {
      background-image: url();
    }
    </style>

     

    展开全文
  • <... <head> <... charset=utf-8"/>...电子围栏</title> <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=O**************k"></script> <s
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>电子围栏</title>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=O**************k"></script>
    <script type="text/javascript" src="http://api.map.baidu.com/library/GeoUtils/1.2/src/GeoUtils_min.js"></script>
    <!--加载鼠标绘制工具-->
    <script type="text/javascript" src="http://api.map.baidu.com/library/DrawingManager/1.4/src/DrawingManager_min.js"></script>
    <link rel="stylesheet" href="http://api.map.baidu.com/library/DrawingManager/1.4/src/DrawingManager_min.css"/>
    <style type="text/css">
            table{
                font-size:14px;
            }
    </style>
    </head>
    <body>
    <div style="float:left;width:100%;height:500px;border:1px solid gray" id="container">
    </div>
    <div style="float:left;width:100%;border:1px solid gray" id="control">
        <table style="width:100%;">
        <tr>
            <td colspan="2">
                判断点是否在指定区域内:
            </td>
        </tr>
        <tr>
            <td>
                <button onclick="ptInPolygon()">判断</button>
                <button onclick="clearPolygon()">清除</button>
            </td>
        </tr>
        </table>
    </div>
    <div id="shape">
        右键获取任意点的经纬度,坐标为:
    </div>
    </body>
    </html>
    <script type="text/javascript">
        var map = new BMap.Map("container");
        var pt = new BMap.Point(114.431151,30.468772);
        map.centerAndZoom(pt, 18);
        map.enableScrollWheelZoom();//开启滚动缩放
        map.enableContinuousZoom();//开启缩放平滑
        function $(id){
            return document.getElementById(id);
        }
        //绘制范围
        var pts = [];
        map.addEventListener("rightclick",function(e){
            $("shape").innerHTML=$("shape").innerHTML+" <br/>("+e.point.lng+","+e.point.lat+")";
            var pt = new BMap.Point(e.point.lng,e.point.lat);
            pts.push(pt);
            var ply = new BMap.Polyline(pts, {strokeColor: "red", strokeStyle:"dashed"});
            map.addOverlay(ply);
        });
        //点在多边形内
        function ptInPolygon(){
            var pt =new BMap.Point(114.431363,30.469658);
            var ply = new BMap.Polygon(pts, {strokeColor: "red", strokeStyle:"dashed"});
            var result = BMapLib.GeoUtils.isPointInPolygon(pt, ply);
            if(result == true){
                alert("点在指定区域内");
            } else {
                alert("点在指定区域外");
            }
            //演示:将面添加到地图上
            map.clearOverlays();
            var mkr = new BMap.Marker(pt);
            map.addOverlay(mkr);
            map.addOverlay(ply);
        }
        function clearPolygon() {
            $("shape").innerHTML = "";
            pts.length = 0;
            map.clearOverlays();
        }
    </script>
    

    转载:https://blog.csdn.net/WuLex/article/details/82382275

    展开全文
  • 百度地图电子围栏功能的实现

    千次阅读 2019-04-16 17:00:00
    最近公司项目需求,要做一个百度地图电子围栏的功能,在网上查了一下资料,看了很多博客,大多数都写的不是很详细,我看的云里雾里的,最后终于集合所有的几篇资料,自己做出了一个简单的demo,下面将过程记录和分享...

           最近公司项目需求,要做一个百度地图电子围栏的功能,在网上查了一下资料,看了很多博客,大多数都写的不是很详细,我看的云里雾里的,最后终于集合所有的几篇资料,自己做出了一个简单的demo,下面将过程记录和分享一下,希望给予有需要同学一些帮助,我这个人说话比较啰嗦,所以写的一定会很详细的,哈哈!闲言少叙,开始了。

    本篇内容实现的过程中将会解决如下几个问题:

    (1)实现百度地图鼠标绘制多边形功能;

    (2)实现根据给定的坐标绘制多边形的功能;

    (3)判断某个坐标点是否在绘制的区域内;

    (4)绘制的坐标点如何在数据库中保存;

    下面按照实际需求一步一步来讲解和实现:

    • 1 实现多边形绘制功能

    1.1 从百度地图官方库下载鼠标绘制多边形功能demo

      如何绘制一个多边形,我在看网上博客的时候,大部分人都是直接贴一堆代码上来,我最开始一直迷迷糊糊,以为是别人自己写的代码,所以得逐句去读,很烦。后来干脆直接去官方文档上去找,就来果然找到了,原来这个功能,百度地图官方有现成的实现,直接copy那部分代码就可以用。

    1>百度搜百度地图开放平台>开发文档>web开发>JavaScript API >示例DEMO >鼠标示例 > 鼠标绘制点线面

     

     

    进入这个地方就可以看到示例代码了,如下:

    可以把中间的代码复制到自己的html页面中,更改一下百度密钥,打开代码就能看到效果了。

    需要注意的是:改代码中用到的几个js文件,不要忘了添加。

    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
        <style type="text/css">
        body, html{width: 100%;height: 100%;margin:0;font-family:"微软雅黑";}
        #allmap {width: 100%; height:500px; overflow: hidden;}
        #result {width:100%;font-size:12px;}
        dl,dt,dd,ul,li{
            margin:0;
            padding:0;
            list-style:none;
        }
        p{font-size:12px;}
        dt{
            font-size:14px;
            font-family:"微软雅黑";
            font-weight:bold;
            border-bottom:1px dotted #000;
            padding:5px 0 5px 5px;
            margin:5px 0;
        }
        dd{
            padding:5px 0 0 5px;
        }
        li{
            line-height:28px;
        }
        </style>
        <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的密钥"></script>
        <!--加载鼠标绘制工具-->
        <script type="text/javascript" src="http://api.map.baidu.com/library/DrawingManager/1.4/src/DrawingManager_min.js"></script>
        <link rel="stylesheet" href="http://api.map.baidu.com/library/DrawingManager/1.4/src/DrawingManager_min.css" />
        <!--加载检索信息窗口-->
        <script type="text/javascript" src="http://api.map.baidu.com/library/SearchInfoWindow/1.4/src/SearchInfoWindow_min.js"></script>
        <link rel="stylesheet" href="http://api.map.baidu.com/library/SearchInfoWindow/1.4/src/SearchInfoWindow_min.css" />
        <title>鼠标绘制工具</title>
    </head>
    <body>
        <div id="allmap" style="overflow:hidden;zoom:1;position:relative;">    
            <div id="map" style="height:100%;-webkit-transition: all 0.5s ease-in-out;transition: all 0.5s ease-in-out;"></div>
        </div>
        <div id="result">
            <input type="button" value="获取绘制的覆盖物个数" onclick="alert(overlays.length)"/>
            <input type="button" value="清除所有覆盖物" onclick="clearAll()"/>
        </div>
        <script type="text/javascript">
        // 百度地图API功能
        var map = new BMap.Map('map');
        var poi = new BMap.Point(116.307852,40.057031);
        map.centerAndZoom(poi, 16);
        map.enableScrollWheelZoom();  
        var overlays = [];
        var overlaycomplete = function(e){
            overlays.push(e.overlay);
        };
        var styleOptions = {
            strokeColor:"red",    //边线颜色。
            fillColor:"red",      //填充颜色。当参数为空时,圆形将没有填充效果。
            strokeWeight: 3,       //边线的宽度,以像素为单位。
            strokeOpacity: 0.8,       //边线透明度,取值范围0 - 1。
            fillOpacity: 0.6,      //填充的透明度,取值范围0 - 1。
            strokeStyle: 'solid' //边线的样式,solid或dashed。
        }
        //实例化鼠标绘制工具
        var drawingManager = new BMapLib.DrawingManager(map, {
            isOpen: false, //是否开启绘制模式
            enableDrawingTool: true, //是否显示工具栏
            drawingToolOptions: {
                anchor: BMAP_ANCHOR_TOP_RIGHT, //位置
                offset: new BMap.Size(5, 5), //偏离值
            },
            circleOptions: styleOptions, //圆的样式
            polylineOptions: styleOptions, //线的样式
            polygonOptions: styleOptions, //多边形的样式
            rectangleOptions: styleOptions //矩形的样式
        });  
         //添加鼠标绘制工具监听事件,用于获取绘制结果
        drawingManager.addEventListener('overlaycomplete', overlaycomplete);
        function clearAll() {
            for(var i = 0; i < overlays.length; i++){
                map.removeOverlay(overlays[i]);
            }
            overlays.length = 0   
        }
    </script>
    </body>
    </html>

     

     现象如下:

     

     1.2 获取绘制多边形个个顶点的坐标

       我们画出多边形的最终目的其实都是一样的,想把这个区域的坐标信息保存到数据库,然后下次能够根据这个区域的坐标信息,把这个区域显示在地图上。那么我们首先得知道这个区域的坐标是什么,所以接下来说下如何获取绘制的区域的坐标。

    首先我们先看下代码:

    这里的添加鼠标绘制工具监听时间,用于获取绘制结果,实际上就是在这里把多边形的顶点放入overlays这个对象中,那么我们如何获取这些点的坐标呢,还是从官方文档里找答案,看下面:

    1>在刚才的JavaScript API界面侧栏找到类参考项>覆盖物类>PolyLine>getPath()

     

     

     

     就是使用这个getPath()方法来获取。

    具体用法如下:

     在上面代码中新增按钮 "获取覆盖物信息" ,然后添加一个getLayerInformation()的方法,点击进行测试,代码如下:

    //html代码
    <input type="button" value="获取绘制覆盖物信息" onclick="getLayerInformation()">
    
    //js代码
    
    function getLayerInformation(){
            console.log(overlays[0].getPath());
    }

     overlays[0]表示第一个多边形,然后我们绘制一个多边形,点击一下,看下控制台打印的结果:

    这样就可以获取了多边形顶点坐标了。

     

    2.已知经纬度坐标,绘制多边形

     接下来看一下已知一些坐标点如何绘制一个多边形,在代码中增加一个按钮 “绘制多边形” ,然后定义一个有坐标信息的数组:

    代码如下:

    <input type="button" value="绘制多边形" onclick="drawPolygon()">

     

    js代码:

     function drawPolygon(){
            let point = [
                {
                    lng:"116.291611",
                    lat:"40.061946"
                },
                {
                    lng:"116.291539",
                    lat:"40.059295"
                },
                {
                    lng:"116.296102",
                    lat:"40.057252"
                },
                {
                    lng:"116.303109",
                    lat:"40.060179"
                }
            ];
            let polArry = [];
            point.forEach(item => {
                let p = new BMap.Point(item.lng,item.lat);
                polArry.push(p);
            });
            let polygon = new BMap.Polygon(polArry,styleOptions);
            map.addOverlay(polygon);
        }

     

     结果如下:

    点击 “绘制多边形” 按钮:

    3.判断坐标点是否在某个区域内

      在不了解之前,我一直以为需要一个算法来判断是否在多边形内,后来发现,百度已经为我们写好了这个算法,我们直接使用即可。

    判断坐标点是否在某个区域,需要引入一个js文件,GeoUtils.js ,这个文件同样在百度提供的资料中可以找到,具体见下图:

     

     在引入这个文件后,我们在页面中添加两个输入框,输入经纬度,在添加一个按钮,来判断该坐标是不是在区域内:

    代码如下:

    html:

    <div id="result">
            <input type="button" value="获取绘制覆盖物个数" onclick="alert(overlays.length)"/>
            <input type="button" value="获取绘制覆盖物信息" onclick="getLayerInformation()">
            <input type="button" value="绘制多边形" onclick="drawPolygon()">
            <input type="button" value="清除所有覆盖物" onclick="clearAll()"/>
            <label for="">经度:</label> <input type="text" id="ILng">
            <label for="">纬度:</label> <input type="text" id="ILat">
            <input type="button" value="判断点是否在多边形内" onclick="IsInPolygon()">
        </div>  

     

    js:

        function IsInPolygon(){
            let lng = $("#ILng").val();
            let lat = $("#ILat").val();
            let point = new BMap.Point(lng,lat);
            let marker = new BMap.Marker(point);
            map.addOverlay(marker);
            if(BMapLib.GeoUtils.isPointInPolygon(point,polygon)){
            console.log("在区域内");
            }else{
            console.log("不在区域内");
            }
           
        }

     

     核心的部分就是这个方法:

    BMapLib.GeoUtils.isPointInPolygon(point,polygon)

     

     第一个参数是输入的坐标点,第二个参数是判断的多边形,这里我用的多边形是上一步绘制的多边形,所以测试时,先点击 “绘制多边形” ,然后再输入坐标,再点击 “判断是否在多边形内”。

    具体结果如下:

      

      

     

     

     4.在数据库中如何存储这些坐标的点

    这个问题,我只提供一个思路,因为不同的多边形坐标个数不同,所以我们不能把每一个坐标点的经度和纬度当成一个单独的字段,我给出的做法是,采用字符串拼接的方式去处理,把每个坐标的经度用 一种特殊符号拼接起来当成一个字段,纬度同理,存到数据库中,然后显示的时候,提前对这些坐标进行解析,得出实际坐标点,就可以了。

    如下所示:

     用 #  拼接

    纬度:
    lat1#lat2#lat3#lat4#lat5.....#latn
    
    经度:
    lng1#lng2#lng3#lng4#lng5......#lngn

     

    字符串拼接的方法是:split,具体用法可自行百度。

     

     

    好了,本篇内容就写到这里了,下面给出代码文件,和一个参考资料压缩包(这个包很好,很有用);

    网盘链接:

    链接:https://pan.baidu.com/s/1OYSIMJ36U4f3LH3_i35dgQ 
    提取码:xd98 

     

      

    展开全文
  • 此Demo是基于百度地图V4_5_2版本的,多边形电子围栏Demo, 完美实现了以下功能 1.手动点击地图,会自动添加Marker 2.多于两个点,会自动划线 3.多于三个点会自动画出多边形区域 4.长按Marker,可以删除和修改电子围栏区域...
  • 百度地图历史轨迹绘制,动画播放,暂停、加速、减速,车头实时角度偏移,HTML页面点开即可使用
  • 基于微信小程序做的车辆电子围栏demo,实现手动点击添加删除标记点、标记点连接生成多边形区域、保存和删除已绘制的多边形区域
  • 练手项目 无参考价值 ...腾讯地图,百度地图api研究,地址解析,路线计算,电子围栏判断等,涉及到的密钥可以去百度或者腾讯的官网申请,腾讯的地图做的还是不如百度,电子围栏是用百度的api算法实现的。
  • 距离测量、ip定位(浏览器定位)、行政区域查询、单击地图获取位置信息、获取marker点处位置信息、简易圆形电子围栏(圆可编辑大小、可移动位置)、右键菜单、中英对照、卫星地图 *简易电子围栏显示圆+开启路线回放+...
  • public class JWD { static double Rc = 6378137; // 赤道半径 double Rj = 6356725; // 极半径 double m_LoDeg, m_LoMin, m_LoSec; // longtitude 经度 double m_LaDeg, m_LaMin...
  • 最近在写百度地图电子围栏加载,研究源码,也花了一些时间。1、百度电子围栏整体思路 1)用户创造实体,赋予监控权限 2)对该实体创造电子围栏,有服务端和本地端两种方式,先创造实体,上传到的服务器中。在对...
  • 高德地图定位+围栏

    2018-04-11 11:07:08
    高德地图定位+围栏.......................................................
  • 使用高德地图js api 自动画出电子围栏因直接画多边形不太准确,需要沿路来画围栏电子围栏思路:1. 找到原点经纬度 xconst CENTER = [116.397504,39.89619]const DISTANCE = 300 //单位mconst map = new AMap.Map(...
  • 微信小程序-实现电子围栏-半径-经纬度-是否在围栏内-画圆等
  • 电子围栏地图 vue

    2020-12-31 02:31:11
    初始化天地图// tMap.jsexport default {init () {return new Promise((resolve, reject) => {// debugger// 如果已加载直接返回// 如果已加载直接返回if (typeof window.T !== 'undefined') {console...
  • 最近项目中用到电子围栏功能,于是简单了解一番,因之前的地图使用高德,故电子围栏仍使用高德,百度等其他地图类似。 该功能经过多次优化完善,基本可用。 1、主要功能: 围栏CURD; 自定义围栏半径,中心点; ...
  • vue中使用高德地图电子围栏

    千次阅读 2019-12-04 21:51:46
    vue中使用高德地图电子围栏 思路:根据项目的需求,给某个区域画电子围栏,且必须得在规定区域内画,所有首先得有个区域先规定好,从后台获取规定区域的坐标点,让后就是画矩形,这里主要是画矩形,在不在圈内,...
  • 最近项目用到高德地图,因此来写一篇文章理一下高德的使用步骤方法,希望对大家有用!先上效果图:效果图.gif1.注册+配置废话不多说,要使用高德地图首先要去高德开放平台注册成为开发者(lbs.amap.com/), 注册成为高德...
  • VUE调用高德地图电子围栏

    千次阅读 2020-07-10 09:26:29
    vue下使用高德JS API实现电子围栏功能
  • 上次基于高德地图实现了圆形围栏功能,但限于实地使用场景,故近期重新升级到多边形电子围栏,经过反复测验及优化,目前可正常使用。 1、主要功能: 多边形围栏的CURD; 自定义变数,形状; 自动计算变数及面积...
  • 百度地图调用电子围栏API实现案例

    万次阅读 2018-08-13 11:18:59
    最基础的围栏展示效果: 以下所有参考学习,也可以先看看百度API了解。 具体代码实现如下: 1.以下是用百度地图 索要引用的 js 2. 围栏新增代码案例可简单看一下: //百度地图API功能 var map = new BMap....

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 1,086
精华内容 434
关键字:

地图电子围栏