当前位置: 首页 > news >正文

turfjs多边形切割多边形求交集

文章目录

  • 前言
    • 分割矢量多边形
  • 一、安装turf
  • 二、加载高德
  • 三、绘制图形
  • 四、计算交集
  • 六、绘制图像
  • 七、效果


前言

分割矢量多边形

一、安装turf

npm i @turf/turf

二、加载高德

AMapLoader.load({
    key: "你的key", // 申请好的Web端开发者Key,首次调用 load 时必填
    version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
    plugins: ["AMap.PolygonEditor", "AMap.LngLat", "AMap.Polygon"], // 需要使用的的插件列表,如比例尺'AMap.Scale'}).then((AMap) => {
  //此处处理后续操作
}

三、绘制图形

    map = new AMap.Map("container", {
      // 设置地图容器id
      viewMode: "3D", // 是否为3D地图模式
      zoom: 13, // 初始化地图级别
      center: [116.471354, 39.994257],
    });
   // 创建两个多边形
    const polygonPath1 = [
      [-73.982, 40.76],
      [-73.979, 40.749],
      [-73.979, 40.748],
      [-73.981, 40.748],
      [-73.982, 40.76],
    ];

    var polygon1 = new AMap.Polygon({
      path: polygonPath1,
      fillColor: "#FFC0CB",
      strokeColor: "#000000",
      strokeWeight: 2,
    });
    map.add(polygon1); // 添加至地图
 
    const polygonPath2 = [
      [-73.983, 40.751],
      [-73.981, 40.751],
      [-73.981, 40.749],
      [-73.983, 40.749],
      [-73.983, 40.751],
    ];
    var polygon2 = new AMap.Polygon({
      path: polygonPath2,
      fillColor: "#FFC0CB",
      strokeColor: "#000000",
      strokeWeight: 2,
    });
    map.add(polygon2); // 添加至地图

   
 

四、计算交集

  // 将图形转化格式
   var turfPolygon1 = turf.polygon([polygonPath1.map((p) => [p[0], p[1]])]);
   var turfPolygon2 = turf.polygon([polygonPath2.map((p) => [p[0], p[1]])]);
   //可以判断是否存在交集
   console.log(turf.booleanOverlap(turfPolygon1, turfPolygon2), 89); ///相交了
   // 计算两个多边形的交集
   var intersection = turf.intersect(
      turf.featureCollection([turfPolygon1, turfPolygon2])
    );
    console.log(intersection, 88); //交集数据

  //    `Tips:` 计算第二个多边形截取第一个多边形后 第一个多边形的数据
    var difference = turf.difference(
      turf.featureCollection([turfPolygon1, turfPolygon2])
    );
    console.log(difference, 88); //差异(原多边形剩余部分)
    var polygon3 = new AMap.Polygon({
      path: [difference.geometry.coordinates],
      fillColor: "red",
      strokeColor: "#000000",
      strokeWeight: 2,
    });
    map.add(polygon3); // 添加至地图

六、绘制图像

 var polygon3 = new AMap.Polygon({
      path: [intersection.geometry.coordinates],
      fillColor: "red",
      strokeColor: "#000000",
      strokeWeight: 2,
    });
    map.add(polygon3); // 添加至地图
    
   

七、效果

在这里插入图片描述
剩余部分效果:

在这里插入图片描述在这里插入图片描述

相关文章:

  • centos 如何将 nginx reload权限给其他用户
  • Linux安装部署Elasticsearch8 全过程记录
  • Nodejs使用redis
  • 解决leetcode第3480题删除一个冲突对后的最大子数组数目
  • Jocker靶机全面解析:漏洞挖掘、渗透测试与防御策略
  • RuoYi-Vue路由,Node
  • HOVER:人形机器人的多功能神经网络全身控制器
  • Leetcode-回溯-组合型
  • Vue 中如何使用 nextTick?
  • 解决uni-app授权弹框华为审核拒绝
  • OpenAI--Agent SDK简介
  • linux入侵排查-综合日志分析
  • halcon几何测量(一)3d_position_of_rectangle
  • 【QT:多线程、锁】
  • 自然语言处理 | 文本清洗的20种核心策略:从数据噪声到信息价值
  • YunSDR AIR:从架构革新到智能融合的演进之路
  • HTML 专栏总结:回顾与展望
  • ABAP PDF预览
  • 「自动驾驶背后的数学:从传感器数据到控制指令的函数嵌套」—— 揭秘人工智能中的线性函数、ReLU 与复合函数
  • win10搭建opengl环境搭建并测试--输出立方体球体和碗型并在球体上贴图
  • 王毅会见俄罗斯外长拉夫罗夫
  • 大家聊中国式现代化|陶希东:打造高水平安全韧性城市,给群众看得见的安全感
  • 屋顶上的阳光与火光:战争如何改变了加沙的能源格局
  • 张家界乒乓球公开赛设干部职级门槛引关注,回应:仅限嘉宾组
  • 泽连斯基公布与特朗普会晤细节,强调实现全面、无条件停火
  • 传媒湃︱《金陵晚报》副刊“雨花石”5月起改为免费刊登