前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ArcGis中关于图形相交关系的判断及应用

ArcGis中关于图形相交关系的判断及应用

作者头像
inline705
发布2021-12-09 15:25:52
1.8K0
发布2021-12-09 15:25:52
举报
文章被收录于专栏:vue+ArcGis

一、前言

大家好,我是inline,一个专注前端领域的同学。今天给大家说一说在ArcGis中关于图形相交关系的判断及应用。

二、geometryEngine

引入ArcGis的几何引擎模块geometryEngine

代码语言:javascript
复制
"esri/geometry/geometryEngine",
复制代码

首先看一下官方对几何引擎的解释

几何引擎,用于测试、测量和分析两个或多个 2D 几何之间的空间关系。如果需要多个几何图形,则所有几何图形都必须具有相同的空间参考,这些方法才能按预期工作。

通俗讲就是geometryEngine可以判断多个2D图形的空间关系,但判断前必须要给这些几何图形设置相同的空间参考。

空间参考就是SpatialReference,以WKID或定义字符串WKT的形式来定义投影和地理坐标系

今天我们要讲的是geometryEngine下的intersects方法

intersects

intersects用来判断一个几何图形是否与另一个几何图形相交,以参数的形式接收两个几何图形

代码语言:javascript
复制
// 用法
intersects(geometry1, geometry2)
复制代码

应用一

判断多图形重叠时更改图形状态,效果图如下:

可以看到我们在进行图形的拖动时 如果图形重叠或图形超出划定范围时所拖动的图形会变红进行提示

代码语言:javascript
复制
// 根据图形相交关系返回布尔值
let intersects = geometryEngine.intersects(图形一, 图形二);
if(intersects){

}
复制代码

应用二

地图打点,判断点位是否在图形内

代码语言:javascript
复制
let pt = {
  type: 'point',
  x: this.mapViewr.center.x,
  y: this.mapView.center.y,
  lat: this.mapView.center.latitude,
  lon: this.mapView.center.longitude,
  spatialReference: this.mapView.spatialReference,   // 图形的空间参考
};
复制代码
代码语言:javascript
复制
// 接收点位图形及点位信息
let isInside = geometryEngine.intersects(graphic.geometry, pt);
if (isInside === false) {
  this.$message.error('点位不在图形内')
  return
}
复制代码

写在最后

文章如有不足之处请指出,一起学习交流,万分感谢~~~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年11月27日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、前言
  • 二、geometryEngine
  • intersects
    • 应用一
      • 应用二
        • 写在最后
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档