百度地图API:JavaScript开源库几何运算判断点是否在多边形内(电子围栏)

百度地图JavaScript开源库,是一套基于百度地图API二次开发的开源的代码库。目前提供多个lib库,帮助开发者快速实现在地图上添加Marker、自定义信息窗口、标注相关开发、区域限制设置、几何运算、实时交通、检索与公交驾车查询、鼠标绘制工具等功能。

判断点是否在多边形内,主要使用的GeoUtils类。它提供若干几何算法,用来帮助用户判断点与矩形、 圆形、多边形线、多边形面的关系,并提供计算折线长度和多边形的面积的公式。 主入口类是GeoUtils。

引入JS封装库

html 复制代码
    <script type="text/javascript" src="//api.map.baidu.com/api?v=3.0&ak=3HGqGo***"></script>
    <script type="text/javascript" src="//api.map.baidu.com/library/GeoUtils/1.2/src/GeoUtils_min.js"></script>

构建HTML地图容器

html 复制代码
<div style="float:left;width:600px;height:500px;padding: 15px;" id="container"></div>

核心代码

javascript 复制代码
var map = new BMap.Map("container");
    var pt = new BMap.Point(116.404, 39.915);
    map.centerAndZoom(pt, 16);
    map.enableScrollWheelZoom();//开启滚动缩放

    //电子围栏
    var pts = [];
    var pt1 = new BMap.Point(116.395, 39.910);
    var pt2 = new BMap.Point(116.394, 39.914);
    var pt3 = new BMap.Point(116.403, 39.920);
    var pt4 = new BMap.Point(116.402, 39.914);


    pts.push(pt1);
    pts.push(pt2);
    pts.push(pt3);
    pts.push(pt4);

    var opts = {
        fillColor: 'blue',
        fillOpacity: 0.3,
        strokeColor: 'blue',
        strokeStyle: "dashed",
        strokeWeight: 1,
        strokeOpacity: 0.5
    }
    var ply = new BMap.Polygon(pts, opts);
    map.addOverlay(ply);

    //地图监听事件
    map.addEventListener('click', function (e) {
        var x = e.point.lng;
        var y = e.point.lat;
        var newPoint = new BMap.Point(x, y);
        var mkr = new BMap.Marker(newPoint);
        map.addOverlay(mkr);

        //判断时间
        ptInPolygon(newPoint, ply);
    })

    var allOverlay = map.getOverlays();
    console.log(allOverlay[0]);

    //点在多边形内
    function ptInPolygon(pt, ply) {
        var result = BMapLib.GeoUtils.isPointInPolygon(pt, ply);
        if (result == true) {
            $("#control").append("操作在电子围栏内<br>");
        } else {
            $("#control").append("超出电子围栏<br>");
        }
    }

封装函数及优化


@漏刻有时

相关推荐
晚枫歌F4 分钟前
io_uring的介绍和实现
开发语言·php
时光追逐者16 分钟前
TIOBE 公布 C# 是 2025 年度编程语言
开发语言·c#·.net·.net core·tiobe
花归去18 分钟前
echarts 柱状图曲线图
开发语言·前端·javascript
老前端的功夫22 分钟前
TypeScript 类型魔术:模板字面量类型的深层解密与工程实践
前端·javascript·ubuntu·架构·typescript·前端框架
2501_9418705636 分钟前
面向微服务熔断与流量削峰策略的互联网系统稳定性设计与多语言工程实践分享
开发语言·python
modelmd41 分钟前
Go 编程语言指南 练习题目分享
开发语言·学习·golang
Nan_Shu_6141 小时前
学习: Threejs (2)
前端·javascript·学习
羊群智妍1 小时前
跨境、合规、垂类全覆盖 2026 GEO五强服务商适配指南
百度·微信·微信公众平台·新浪微博·segmentfault
G_G#1 小时前
纯前端js插件实现同一浏览器控制只允许打开一个标签,处理session变更问题
前端·javascript·浏览器标签页通信·只允许一个标签页
带土11 小时前
4. C++ static关键字
开发语言·c++