【openlayers系统学习】4.3VectorTile 功能交互(指针悬停在要素上时,绘制矩形框)

本文主要是介绍【openlayers系统学习】4.3VectorTile 功能交互(指针悬停在要素上时,绘制矩形框),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三、 VectorTile 功能交互(指针悬停在要素上时,绘制矩形框)

矢量切片的好处是我们可以与要素交互,因为我们在客户端上有数据。但需要注意的一件事是矢量切片针对渲染进行了优化。这意味着要素仅包含过滤和渲染所需的属性,并且几何图形针对渲染分辨率进行了优化并在图块边界附近进行了剪裁。

在本练习中,当指针悬停在要素上时,我们将在要素周围绘制一个框。

添加用于显示边界框的矢量图层

我们将在单独的图层上绘制悬停要素的边界框。需要以下导入,我们将它们添加到 main.js​ 中的其他导入旁边:

import VectorLayer from 'ol/layer/Vector';
import VectorSource from 'ol/source/Vector';
import {Stroke, Style} from 'ol/style';

接下来,我们可以为图层创建一个源,图层,并将其分配给地图:

const source = new VectorSource();
new VectorLayer({map: map, // 将图层与地图对象关联source: source,style: new Style({stroke: new Stroke({color: 'red',width: 4,}),}),
});

与地图交互 Interacting with the map

现在是时候向地图添加一个 pointermove​ 监听器了,它获取指针位置处的所有要素并将它们的边界框添加到图层中。为此,我们需要两个额外的导入:

import Feature from 'ol/Feature';
import {fromExtent} from 'ol/geom/Polygon';

最后,我们可以添加代码来清除源的当前内容,并将指针位置处的特征的边界框添加为新内容:

// 监听地图上的 pointermove 事件
map.on('pointermove', function (event) {// 清除之前添加到源中的所有要素source.clear();// 在鼠标指针所在像素位置下查找要素map.forEachFeatureAtPixel(event.pixel,function (feature) {// 获取要素的几何信息const geometry = feature.getGeometry();// 将要素的范围转换为新的要素,并添加到源中source.addFeature(new Feature(fromExtent(geometry.getExtent())));},{// 设置命中容差为 2 像素hitTolerance: 2,});
});

注:观察一下这里的feature​和geometry​对象,将他们打印出来

image

这两个对象是完全一样的:

image

直接调用feature.getExtent()​也是可以的

image

现在,将鼠标悬停在地图上时,结果应如下所示:

image

这篇关于【openlayers系统学习】4.3VectorTile 功能交互(指针悬停在要素上时,绘制矩形框)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1007666

相关文章

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作