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

OpenLayers 快速入门(九)Extent 介绍

看过的知识不等于学会。唯有用心总结、系统记录,并通过温故知新反复实践,才能真正掌握一二
作为一名摸爬滚打三年的前端开发,开源社区给了我饭碗,我也将所学的知识体系回馈给大家,助你少走弯路!
OpenLayers、Leaflet 快速入门 ,每周保持更新 2 个案例
Cesium 快速入门,每周保持更新 4 个案例

OpenLayers 快速入门(一)Map对象
OpenLayers 快速入门(二)Layer 对象
OpenLayers 快速入门(三)Source 对象补充
OpenLayers 快速入门(四)View 对象
OpenLayers 快速入门(五)Controls 对象
OpenLayers 快速入门(六)Interaction 对象
OpenLayers 快速入门(七)矢量数据
OpenLayers 快速入门(八)事件系统
OpenLayers 快速入门(九)Extent 介绍
OpenLayers 快速入门(十)常用 API 补充

Openlayers 中 extent 介绍

在 OpenLayers 中,extent(范围)是一个表示地理区域边界的数组,格式为 [minX, minY, maxX, maxY]。它用于定义地图的可见区域、图层范围、几何边界等

模块导入

导入 ol/extent 模块

import * as extent from "ol/extent";

createEmpty()

创建一个空范围([Infinity, Infinity, -Infinity, -Infinity])。

const emptyExtent = extent.createEmpty(); // [Infinity, Infinity, -Infinity, -Infinity]

isEmpty(extent)

检查范围是否为空。

extent.isEmpty([1, 2, 3, 4]); // false

getWidth(extent)、getHeight(extent)

计算范围的宽度和高度。

const width = extent.getWidth([0, 0, 10, 20]); // 10
const height = extent.getHeight([0, 0, 10, 20]); // 20

getCenter(extent)

返回范围的中心点坐标 [x, y]。

const center = extent.getCenter([0, 0, 10, 10]); // [5, 5]

containsCoordinate(extent, coordinate)

检查坐标是否在范围内。

extent.containsCoordinate([0, 0, 10, 10], [5, 5]); // true

containsExtent(extent1, extent2)

检查 extent1 是否完全包含 extent2。

extent.containsExtent([0, 0, 20, 20], [5, 5, 15, 15]); // true

intersects(extent1, extent2)

判断两个范围是否相交。

extent.intersects([0, 0, 10, 10], [5, 5, 15, 15]); // true

buffer(extent, value)

扩展范围(负值则缩小)。

const buffered = extent.buffer([0, 0, 10, 10], 2); // [-2,-2,12,12]

getIntersection(extent1, extent2)

返回两个范围的交集(无交集时返回 null)。

const intersection = extent.getIntersection([0, 0, 10, 10], [5, 5, 15, 15]); // [5,5,10,10]

boundingExtent(coordinates)

根据坐标数组计算最小包围范围:

const coords = [[0, 0],[5, 10],[10, 0],
];
const bbox = extent.boundingExtent(coords); // [0,0,10,10]
http://www.dtcms.com/a/293515.html

相关文章:

  • Leetcode力扣解题记录--第240题(矩阵搜索)
  • 数据科学与大数据技术和统计学有什么区别?​
  • 关于针对 DT_REG 出现红色波浪线的问题(编译错误/IDE警告),以下是 精准解决方案,保持你的代码功能完全不变:
  • 【Linux-云原生-笔记】Haproxy相关
  • 基于Python(Django)+MongoDB实现的(Web)新闻采集和订阅系统
  • 模拟实现消息队列项目
  • 使用PEghost恢复系统(笔记版)
  • OpenEuler系统架构下编译redis的RPM包
  • [Mediatek] MTK openwrt-21.02 wifi 没启动问题
  • Android Multidex 完全解析:解决64K方法数限制
  • Java 虚拟线程在高并发微服务中的实战经验分享
  • 从0开始学习R语言--Day55--弹性网络
  • TDengine 的 HISTOGRAM() 函数用户手册
  • LabVIEW激光雷达障碍物识别
  • #C语言——学习攻略:操作符的探索(二)
  • 架构师--基于常见组件的微服务场景实战
  • VI Server 操控 LabVIEW 工程
  • DeepSeek Janus Pro本地部署与调用
  • 基于Trae IDE与MCP实现网页自动化测试的最佳实践
  • CI/CD与DevOps集成方法
  • 希尔排序cc
  • 无人机减震模块技术解析
  • Java冒泡排序的不同实现
  • 无人机吊舱减震球模块运行分析
  • 如何在Pico等Android头显中实现无人机低延迟RTMP全景巡检画面播放
  • Cursor(vscode)一些设置
  • 【基于OpenCV的图像处理】图像预处理之图像色彩空间转换以及图像灰度化处理
  • 高亮匹配关键词样式highLightMatchString、replaceHTMLChar
  • 图论的题目整合(Dijkstra)
  • 货车手机远程启动功能的详细使用步骤及注意事项