天地图监听圆是否改变

天地图4.0截至2025年3月24日还不支持编辑监听改变,但是不妨碍我们使用技术手段进行实现,达到监听半径和圆点是否改变的方法;

效果图
核心方法
typescript 复制代码
// 定义圆默认半径
var preRadius = 5000;
// 定义圆默认中心点
var circleDefCenter = {lng: 116.40093, lat: 39.90313}
// 定时器放置重复触发
var circleEditChangeTime = null;
// 地图绑定事件
map.addEventListener('touchend', function(e) {
    circleEditChange();
});

function circleEditChange() {
    // 不在编辑状态就不处理
	if (!circle.isEditable()) {return;}
    if (circleEditChangeTime) {
        clearTimeout(circleEditChangeTime)
        circleEditChangeTime = null;
    }
    circleEditChangeTime = setTimeout(function() {
        /*  禁用: 业务不让改变中心点
  			【天地图Bug】改变中心点后, 重置到默认编辑手柄不会归位;
        */
        circle.disableEdit();
        var curCenter = circle.getCenter();
        var curRadius = circle.getRadius();
        // 中心点改变了
        if (curCenter.lng !== circleDefCenter.lng || curCenter.lat !== circleDefCenter.lat) {
            circle.setCenter(new T.LngLat(116.40093, 39.90313));
            console.log('中心点改变了');
        }
        // 表示半径改变了
        if (curRadius !== preRadius) {
            preRadius = curRadius;
            console.log('半径改变了', curRadius);
        }
        // 启用编辑
        circle.enableEdit();
    }, 200);
};
使用
typescript 复制代码
circle = new T.Circle(new T.LngLat(116.40093, 39.90313), 5000,{color:"blue",weight:5,opacity:0.5,fillColor:"#FFFFFF",fillOpacity:0.5,lineStyle:"solid"});
map.addEventListener('touchend', function(e) {
	circleEditChange();
});
其它方法
typescript 复制代码
// 判断经纬度是否在圆形范围内 is: boolean;
var is = circle.getBounds().contains(new T.LngLat(116.40093, 39.90313));
相关推荐
晚霞的不甘24 分钟前
Flutter for OpenHarmony构建全功能视差侧滑菜单系统:从动效设计到多页面导航的完整实践
前端·学习·flutter·microsoft·前端框架·交互
黎子越24 分钟前
python相关练习
java·前端·python
北极糊的狐1 小时前
若依项目vue前端启动键入npm run dev 报错:不是内部或外部命令,也不是可运行的程序或批处理文件。
前端·javascript·vue.js
XRJ040618xrj1 小时前
Nginx下构建PC站点
服务器·前端·nginx
We་ct1 小时前
LeetCode 289. 生命游戏:题解+优化,从基础到原地最优
前端·算法·leetcode·矩阵·typescript
有诺千金2 小时前
VUE3入门很简单(4)---组件通信(props)
前端·javascript·vue.js
2501_944711432 小时前
Vue-路由懒加载与组件懒加载
前端·javascript·vue.js
雨季6662 小时前
Flutter 三端应用实战:OpenHarmony “心流之泉”——在碎片洪流中,为你筑一眼专注的清泉
开发语言·前端·flutter·交互
换日线°2 小时前
前端3D炫酷展开效果
前端·3d
广州华水科技2 小时前
大坝变形监测的单北斗GNSS技术应用与发展分析
前端