JSAPIThree 事件系统学习笔记:处理交互的基础

news/2025/11/26 11:03:58/文章来源:https://www.cnblogs.com/map-3d-vis/p/19271750

作为刚接触 mapvthree 的新手,今天我专门学习了事件系统。这里汇总最实用的内容,帮助和我一样的初学者快速掌握交互的核心用法。

绑定与移除事件,只需记住 add/remove

mapvthree 复用了 Three.js 的 addEventListener / removeEventListener,所以任何继承自 Object3D 的对象都能直接绑定事件。引擎内部的调度器会帮我们处理拾取、命中检测等复杂逻辑,我们只需要专注于“监听哪一个对象”和“响应什么事件”。

const box = engine.add(new THREE.Mesh(new THREE.BoxGeometry(10, 10, 10),new THREE.MeshBasicMaterial({color: 0xaa0000}),
));const handleClick = (e) => {console.log('盒子被点击,地理坐标:', e.point);box.removeEventListener('click', handleClick); // 一次性事件
};box.addEventListener('click', handleClick);
  • 常见事件:clickdblclickmousemovemouseentermouseleavepointerdownpointerup
  • 一定记得在物体移除或销毁前调用 removeEventListener,避免内存泄漏

EventParam 里的信息足够丰富

每次事件触发,回调都会收到统一的 EventParam,其中最常用的字段如下:

属性 说明
target / currentTarget 触发事件的对象、绑定事件的对象
position 鼠标在世界坐标中的位置(Array[3])
point 鼠标在地理坐标中的位置(经纬度)
index / entity 当事件来自支持 dataSource 的图层时,可获取对应的数据索引和实体
event 原始浏览器事件对象
box.addEventListener('mousemove', (e) => {if (e.position) {helper.position.fromArray(e.position); // 在 3D 空间显示鼠标所在点}
});

注意:当事件绑定在 engine.map 这类场景根对象上时,只能拿到 positionpoint,其它字段不存在。

事件不仅限于几何体,根对象也能监听

可以在可视化图层、地图根节点甚至 engine.map 上绑定事件,从而实现不同层级的交互。例如:

engine.map.addEventListener('pointerdown', () => {engine.clock.currentTime = new Date('2025-05-15 18:00:00');
});
engine.map.addEventListener('pointerup', () => {engine.clock.currentTime = new Date('2025-05-15 14:00:00');
});

这段代码演示了如何在地图级别监听按下/抬起事件,并根据交互切换天空时间。

事件冒泡:必要时调用 stopPropagation

事件从子节点向父节点冒泡,沿着场景树一直传递到根对象。我们可以利用冒泡做统一处理,也可以在需要时阻止冒泡。

ear.addEventListener('click', (e) => {alert('点击到了耳朵');e.stopPropagation(); // 阻止继续触发头部或整个人的点击事件
});
head.addEventListener('click', () => alert('点击到了头像'));
human.addEventListener('click', () => alert('点击到了整个人'));

当需要在某个层级拦截事件时,记得调用 stopPropagation()

使用建议

  • 善用一次性事件:如果某个事件只需要触发一次,回调里立即调用 removeEventListener
  • 场景根对象的事件:仅能获取位置坐标,适合做“全局点击”或“拖拽地图切换模式”之类的功能。
  • 粒度控制:能在具体对象上监听就不要放在根节点,粒度越精细,代码越容易维护。
  • 性能提示:事件调度器会在帧末集中处理,并做异步、去重等优化,正常使用不必担心性能问题。

学习笔记就到这里!事件系统本身并不复杂,关键是熟悉 addEventListenerEventParam 和冒泡这几个核心概念。掌握它们之后,构建交互式地图就顺手多了。希望这份笔记也能帮到你!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/976909.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2025北京留学机构都有什么

2025北京留学机构都有什么一、2025年北京留学机构都有什么时间来到2025年10月24日,计划出国深造的同学和家长们,在搜索北京留学机构时,脑海中是否会浮现出这样几个问题:北京这么多留学中介,到底哪家更适合我的具体…

用户体验的无声博弈:兰亭妙微如何通过“无意识设计”留住用户

用户体验的无声博弈:兰亭妙微如何通过“无意识设计”留住用户您是否曾有过这样的体验:使用一款APP时,您无需思考,自然而然地就完成了想做的事,整个过程流畅得仿佛不存在任何阻碍?这种“无意识”的顺畅感,并非偶…

QDockWidget-窗体停靠

头文件#include <QDockWidget>QDockWidget是QWidget的子类,它生成那些可以停靠到视窗边缘并自适应大小的widget参考博客:https://blog.csdn.net/p942005405/article/details/102056954

【第6章 字符串】正则表达式支持模糊匹配吗?

是的,正则表达式 支持模糊匹配,但需注意:标准正则(如 Python 内置 re 模块)的模糊匹配能力有限,而扩展库(如 Python regex 模块)提供了更完善的模糊匹配功能。以下是具体说明:一、标准正则的“模糊匹配”(有…

2025年超细粉碎机厂家权威推荐榜单:超细粉体粉碎机/超微粉碎机/气流粉碎分级机源头厂家精选

在新材料、医药、化工等行业需求推动下,超细粉体设备正向着更精细化、智能化方向快速发展,技术创新成为企业核心竞争力。 超细粉碎机作为粉体行业的核心设备,其技术水平直接影响着粉体产品的粒度分布和纯度。随着新…

现今安徽香菇厂家推荐排行

摘要 安徽香菇行业近年来快速发展,依托当地丰富的自然资源和先进的加工技术,已成为中国香菇产业的重要基地。行业注重食品安全、品质控制和定制化服务,满足多元化市场需求。本文基于市场调研和用户口碑,为您推荐排…

2025年口碑好的安徽木耳品牌排名:品质与信赖的权威指南

文章摘要 安徽木耳行业在2025年迎来品质升级新阶段,随着消费者对食品安全和健康需求的提升,优质木耳品牌成为市场新宠。本文基于权威数据和市场调研,为您呈现当下安徽木耳品牌综合排名,重点推荐品质卓越、服务完善…

java mvn

java mvnmvn clean install:清理并构建项目,安装到本地仓库。 ‌12 mvn dependency:tree:查看依赖树,解决冲突。 ‌1注意事项确保groupId、artifactId、version唯一性,避免版本冲突。 ‌3 使用<properties>…

Windows64下32位程序文件系统重定向

Windows64下32位程序文件系统重定向 在默认情况下,64位环境运行32位程序,会为这个程序启用文件系统重定向。就是这个32位程序访问文件系统时(如 CreateFile/WinVerifyTrust 等操作),会把 C:\Windows\System32 文件…

2025年Q4内容审核公司推荐,全链路防护+弹性人力池测评榜

据《2025年中国内容生态治理白皮书》显示,2025年中国内容审核服务市场规模将突破300亿元,年复合增长率超25%,其中AI生成内容占比已达30%。随着《人工智能生成合成内容标识办法》于2025年9月1日正式施行 ,企业选型需…

2025 最新温州包车公司推荐!商务 / 旅游 / 团建包车权威榜单:品牌甄选,20 年驾龄司机护航 + 全程安全保障

引言 随着商务往来、旅游出行与团队团建需求的持续攀升,包车服务已成为高效出行的核心选择,但行业资质混杂、服务标准不一等问题仍困扰着消费者。本次榜单依托国际道路运输协会(IRU)测评体系,结合近一年行业服务数…

论文格式要求

(二)格式要求: 1、正文用小四号宋体,行距20磅。 2、小节格式: 一级标题序号 如:一、二、三、 标题四号黑体,加粗,顶格。 二级标题序号 如:(一)(二)(三) 标题小四号宋体,不加粗,顶格。 三级标题序号 如:1.2.…

深扒Pickle反序列化

Pickle反序列化 pickle简介与PHP类似,python也有序列化功能以长期储存内存中的数据。pickle是python下的序列化与反序列化包。python有另一个更原始的序列化包marshal,现在开发时一般使用pickle。与json相比,pickle…

框架架构设计师备考第61天——嵌入式架构架构模式操作便捷的系统数据库中间件

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Nessus Professional 10.11 Auto Installer for Windows - Nessus 自动化安装程序

Nessus Professional 10.11 Auto Installer for Windows - Nessus 自动化安装程序Nessus Professional 10.11 Auto Installer for Windows - Nessus 自动化安装程序 发布 Nessus 试用版自动化安装程序,支持 macOS Tah…

CS501 TYPEC转DP芯片 支持8K60HZ高速信号转换芯片

CS501芯片是一款符合USB TYPE-C标准的控制器,用于实现TYPE-C转DisplayPort1.4的高速信号转换,支持高达8K@60Hz(76804320)的视频输出和32.4Gbit/s的数据传输速率,具备动态HDR10、高精度音频支持(192kHz/24bit)等…

2025北京留学机构有哪些地方

2025北京留学机构有哪些地方一、北京留学机构怎么选?五大问题帮你理清思路作为一位从事国际教育规划工作超过十年的专业人士,我经常被学生和家长问及:在北京这个教育资源丰富的城市,到底哪家留学中介更值得信赖?2…

2025西安网站建设公司推荐3家口碑好的网站制作公司 (5)

2025 西安网站建设公司推荐 3 家口碑好的网站制作公司在数字化转型纵深推进的 2025 年,网站建设已成为企业品牌传播、业务转化的核心载体,西安作为西北数字化产业枢纽,网站制作、网页设计需求持续攀升。企业选择服务…

2025年靠谱的西安外贸网站建设行业内最具实力的三家公司

2025 年靠谱的西安外贸网站建站行业内最具实力的三家公司在全球化贸易深度融合的 2025 年,外贸网站、外贸独立站已成为企业拓展国际市场的核心载体,俄语网站制作等多语言适配需求持续攀升。西安作为西北外贸数字化枢…

2025厦门留学机构哪家好一点的

2025厦门留学机构哪家好一点的一、2025年厦门留学机构哪家好一点?准备出国留学的厦门同学,在挑选中介时难免会冒出各种具体问题:厦门本地的留学机构哪家更靠谱?想要申请美国前三十的学校,哪家顾问的专业度更高?在…