three.js如何实现简易3D机房?(四)点击事件+呼吸灯效果

接上一篇:

three.js如何实现简易3D机房?(三)显示信息弹框/标签:http://t.csdnimg.cn/5W2wA

目录

八、点击事件

1.实现效果

2.获取相交点

3.呼吸灯效果

4.添加点击事件

5.问题解决


八、点击事件

1.实现效果

2.获取相交点

官方射线拾取的原理:由相机位置为射线起点,鼠标点击位置为射线方向发射射线,所有被射线穿过的所有几何体都会被捕捉到,距离越近捕捉到的几何体越靠前

在threeD/init.js中


// 获取鼠标和射线的相交点
export function getIntersectPoint (event) {// 鼠标控制对象const mouse = new THREE.Vector2();// 初始化射线辅助器const raycaster = new THREE.Raycaster();// 将鼠标位置归一化为设备坐标。x 和 y 方向的取值范围是 (-1 to +1)let rect = renderer.domElement.getBoundingClientRect()mouse.x = ((event.clientX - rect.left) / rect.width) * 2 - 1;mouse.y = -((event.clientY - rect.top) / rect.height) * 2 + 1;//通过鼠标点击的位置(二维坐标)和当前相机的矩阵计算出射线位置raycaster.setFromCamera(mouse, camera);// 获取与射线相交的对象数组,其中的元素按照距离排序,越近的越靠前return raycaster.intersectObjects(scene.children, true);
}
3.呼吸灯效果

在threeD/init.js中

import { EffectComposer } from 'three/addons/postprocessing/EffectComposer.js';
import { RenderPass } from "three/addons/postprocessing/RenderPass"
import { OutlinePass } from "three/addons/postprocessing/OutlinePass"
import { ShaderPass } from "three/addons/postprocessing/ShaderPass"
// SMAA抗锯齿通道
import { SMAAPass } from 'three/addons/postprocessing/SMAAPass.js';
// 颜色修正
import { GammaCorrectionShader } from 'three/addons/shaders/GammaCorrectionShader.js';export let composer, renderPass, outlinePassexport function addOutlineEffect (selectedObjects, color) {composer = new EffectComposer(renderer);renderPass = new RenderPass(scene, camera);composer.addPass(renderPass);outlinePass = new OutlinePass(new THREE.Vector2(width, height), scene, camera);outlinePass.selectedObjects = selectedObjectsoutlinePass.edgeStrength = 8; // 发光的强度outlinePass.edgeGlow = 1; // 光晕outlinePass.usePatternTexture = false // 是否使用父级的材质outlinePass.edgeThickness = 8; // 边框的宽度outlinePass.downSampleRatio = 1 // 边框弯曲度outlinePass.pulsePeriod = 3; // 呼吸灯闪烁的速度outlinePass.visibleEdgeColor.set(color); // 呼吸显示的颜色outlinePass.hiddenEdgeColor.set(color); // 呼吸消失的颜色outlinePass.clear = truecomposer.addPass(outlinePass);//获取.setPixelRatio()设置的设备像素比const pixelRatio = renderer.getPixelRatio();// 抗锯齿const smaaPass = new SMAAPass(width * pixelRatio, height * pixelRatio);composer.addPass(smaaPass);// 模型颜色修正const gammaCorrectionShader = new ShaderPass(GammaCorrectionShader);composer.addPass(gammaCorrectionShader);
}

4.添加点击事件

业务逻辑:

(1)获取鼠标和射线的交点

(2)判断点击的几何体是否为设备,是则停止当前随机信息展示,清除前一个信息弹框;不是则清除呼吸灯和弹框,并继续开启随机显示正常设备信息的定时任务;

(3)在点击的几何体是设备的情况下,再次判断是否为报警设备,是只添加呼吸灯效果,否添加呼吸灯和信息弹框

在index.vue中

import {scene,composer,outlinePass,getDomInfo,init,createControls,initLight,createCSS3DRenderer,getIntersectPoint,addOutlineEffect,watchDom,renderResize,renderLoop,
} from './component/threeD/init.js';onMounted(async () => {init(threeDemoRef.value);importModel();createControls();initLight();createCSS3DRenderer(threeDemoRef.value);watchDom(threeDemoRef.value);renderResize(threeDemoRef.value);renderLoop();
});// 重置(清除呼吸灯和弹框,并继续随机显示正常设备的信息)
const resetRandomDialog = () => {if (outlinePass) {composer.removePass(outlinePass);clearDialog();createNormalDialog();}
};window.addEventListener('click', onClick, false);const onClick = (event: any) => {event.preventDefault();const intersects = getIntersectPoint(event);if (intersects.length) {const selectedDevice = intersects[0].object.parent;if (selectedDevice.name && selectedDevice.name.includes('AU')) {// 1.停止当前随机信息展示state.intervalId ? clearInterval(state.intervalId) : '';// 2.清除前一个弹框clearDialog();// 3.报警设备只添加呼吸灯效果,正常设备添加呼吸灯+弹框state.selectedDevice = { ...selectedDevice };const alarmName = state.alarmInfo.map((item: any) => item.name);if (alarmName.includes(selectedDevice.name)) {addOutlineEffect([selectedDevice], 0x8b1616);} else {addOutlineEffect([selectedDevice], 0x21793b);model.traverse((obj: any) => {if (obj.name.includes('AU') && obj.name == selectedDevice.name) {state.normalInfo.forEach((item: any) => {if (item.name == selectedDevice.name) {state.randomObject = { ...selectedDevice };insertDialogHtml(obj, item);}});}});}} else {resetRandomDialog();}} else {resetRandomDialog();}
};

到这儿差不多功能就已经全部实现了,但是问题来了,因为随机事件还在继续,切换到其他页面的时候会报错,最后就是一些小问题的解决了

5.问题解决
onUnmounted(() => {// 停止定时器clearInterval(state.intervalId);// 从场景中移除模型scene.remove(model.value);// 释放模型资源model.traverse((child: any) => {if (child instanceof THREE.Mesh) {child.geometry.dispose();child.material.dispose();}});// 停止点击事件window.removeEventListener('click', onClick);
});

完结,撒花

✿✿ヽ(°▽°)ノ✿                                        ✿✿ヽ(°▽°)ノ✿                                          ✿✿ヽ(°▽°)ノ✿

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

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

相关文章

现代重工业如何避免短路危害的发生

短路是电路中一部分被短接的现象,其危害主要表现在以下几个方面: 产生大电流与高热量:短路会导致电路中产生极大的电流,有时可达上万甚至十几万安培。这种大电流会产生大量的热量,不仅会使设备过热,还可能…

Cyber RT 开发工具

在Cyber RT中还提供了一些工具,这些工具可以拓展Cyber RT功能、提高开发调试效率,本章主要介绍这些工具的使用。 本章内容: 1.cyber record工具的应用; 2.常用命令工具的使用; 学习收获: 1.可以通过cyber record将发布的话题消息…

Service Mesh:重塑微服务市场

摘要 今天我们不谈技术,不谈架构,也不谈具体的产品,我们来聊一聊在未来一两年之内,Service Mesh技术会在微服务相关的市场带来什么样的变化? 大家好,我是敖小剑,今天给大家带来的这个主题叫做…

JVM垃圾回收机制(GC)

目录 1.什么是垃圾回收 2.GC对于虚拟机各块的影响 3.垃圾回收具体是怎么展开的 3.1引入计数 3.2可达性分析(JVM使用的就是这种方法) 3.2.1.标记清除 3.2.2.复制算法 3.3.3标记整理 3.3分代回收 1.什么是垃圾回收 在C语言等编程语言中,采用的是动态内存管理,我们使用mal…

SQL无列名注入

SQL无列名注入 ​ 前段时间,队里某位大佬发了一个关于sql注入无列名的文章,感觉好像很有用,特地研究下。 关于 information_schema 数据库: ​ 对于这一个库,我所知晓的内容并不多,并且之前总结SQL注入的…

【Java JVM】Class 文件的加载

Java 虚拟机把描述类的数据从 Class 文件加载到内存, 并对数据进行校验, 转换解析和初始化, 最终形成可以被虚拟机直接使用的 Java 类型, 这个过程被称作虚拟机的类加载机制。 与那些在编译时需要进行连接的语言不同, 在 Java 语言里面, 类的加载, 连接和初始化过程都是在程序…

如何打造企业工厂的多元化展示?VR数字工厂告诉你

随着数字化进程推进以及互联网大数据等技术的发展,很多行业逐渐开始了数字化转型,而企业工厂也需要与时俱进。VR数字工厂需要多元化展现自身实力,并打造专属于自己的AI数字人名片,力求在市场中凸显自己,那么如何利用VR…

短剧系统开发:一种新型的娱乐方式

一、引言 随着科技的快速发展,人们的生活方式也在逐渐改变。在娱乐领域,短剧作为一种新型的娱乐方式,正在受到越来越多人的喜爱。短剧以其短小精悍、情节紧凑、易于观看等特点,迅速占领了市场。因此,开发一款短剧系统…

计算机的基础知识

计算机的特点及应用: 图灵说–计算就是基于规则的符号串变换从20世纪80年代开始,发达国家开始研制第五代计算机,研究的目标是能够打破以往计算机固有的体系结构,使计算机能够具有像人一样的思维、推理和判断能力,向智…

AI最新!雷军、许礼进、曹文泽、屠红燕发声

源自:上海证券报 “人工智能技术与咨询” 发布 尽快出台专项,以智能制造系统软件、AI大模型和通用仿生机器人的部署应用为重点产业突破方向,支持打造以大模型为代表的人工智能与制造业深度融合的应用场景; 加快整合人形机器人产…

未来娱乐新境界:探秘充气式球幕影院的奇妙世界

充气式球幕影院,这一融合科技与创意的娱乐新宠,正在引领我们踏上一场前所未有的奇妙旅程。它不仅仅是对视觉和感官体验的极致追求,更以其独特的魅力,让我们在观影中沉浸于前所未有的震撼与享受。 半球形梦幻观影空间: …

基础50刷题之一(交替合并字符串)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、题目二、力扣官方题解(双指针)三、文心一言解释总结 前言 刚上研一,有人劝我好好学C,当时用的不多就没学&a…