天地图监听多边形是否改变

天地图4.0截止2025年3月24日,并没有提供多边形改变后的回调函数,其实多边形的应用在地图GIS系统中有很多用处,比方说点子围栏编辑告警;离不开多边形的绘制和编辑能力;

效果图
核心方法
typescript 复制代码
/*
 多边形默认经纬度
 应该是天地图BUG,直接用等于用了相同的引用改变会同步改变,后面无法计算是否改变;
*/
var prePolygonLngLats = JSON.parse(JSON.stringify(polygon.getLngLats()[0]));
// change定时器,防止重复触发
var polygonEditChangeTime = null;
// 绑定地图事件;曲线救国;
map.addEventListener('touchend', function(e) {
    handlePolygonChange();
});
// 绑定触发事件
function handlePolygonChange() {
   // 不在编辑状态直接退出
   if (!polygon.isEditable()) {
        return;
    }
    if (polygonEditChangeTime) {
        clearTimeout(polygonEditChangeTime)
        polygonEditChangeTime = null;
    }
    polygonEditChangeTime = setTimeout(() => {
        var curBou = polygon.getLngLats()[0]
        var isChange = handlePolygonCompare(prePolygonLngLats, curBou);
        if (isChange) {
            console.log('多边形改变了', isChange);
        };
        prePolygonLngLats = JSON.parse(JSON.stringify(polygon.getLngLats()[0]));
    }, 200);
}
// 比较经纬度是否一致
function handlePolygonCompare(oldArray, newArray) {
    // 如果长度不同,直接返回true(表示改变了)
    if (oldArray.length !== newArray.length) {
        return true;
    }
    // 如果长度相同,逐项对比
    for (let i = 0; i < oldArray.length; i++) {
        if (oldArray[i].lng !== newArray[i].lng || oldArray[i].lat !== newArray[i].lat) {
            return true; // 只要有一项不同,返回true
        }
    }
    // 如果所有项都相同,返回false
    return false;
}
调用
typescript 复制代码
map.addEventListener('touchend', function(e) {
    handlePolygonChange();
});
相关推荐
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦2 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
喵个咪2 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
摆烂大大王3 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao4 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色4 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆4 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6
lichenyang4534 小时前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端
IT_陈寒5 小时前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端
kyriewen5 小时前
AI生成代码快如闪电,但我修了三个小时——它到底帮了谁?
前端·javascript·ai编程