关于 Threejs在宽高一定的页面内绘制

el-dialog 页面中使用 Three.js 绘制物体并绑定双击事件。首先,在 el-dialog 中创建一个 canvas 元素用于渲染 Three.js;

在使用的el-dialog页面中使用threejs绘制物体 并给物体绑定双击事件;对应物体之间有联系的绘制箭头线

<template><div><el-dialog title="Three.js Cubes" :visible.sync="dialogVisible" width="50%"><canvas id="canvas" @dblclick="onCanvasDoubleClick"></canvas></el-dialog></div>
</template><script>
import * as THREE from 'three';
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js';export default {data() {return {dialogVisible: false,scene: null,camera: null,renderer: null,controls: null, // 用于控制相机和旋转的对象cubes: [], // 保存立方体对象的数组arrowHelpers: [] // 保存箭头线对象的数组};},mounted() {this.initThree();},methods: {initThree() {// 获取canvas元素const canvas = document.getElementById('canvas');// 创建场景this.scene = new THREE.Scene();// 创建相机this.camera = new THREE.PerspectiveCamera(75, canvas.clientWidth / canvas.clientHeight, 0.1, 1000);this.camera.position.z = 5;// 创建渲染器this.renderer = new THREE.WebGLRenderer({ canvas });this.renderer.setSize(canvas.clientWidth, canvas.clientHeight); // 设置渲染器大小// 设置渲染器背景色this.renderer.setClearColor(0xffffff);// 添加鼠标控制this.controls = new OrbitControls(this.camera, this.renderer.domElement);this.controls.enableDamping = true;this.controls.dampingFactor = 0.25;this.controls.rotateSpeed = 0.35;// 添加网格const gridHelper = new THREE.GridHelper(10, 10); // 设置网格大小this.scene.add(gridHelper);// 创建多个立方体并添加到场景中for (let i = 0; i < 5; i++) {const geometry = new THREE.BoxGeometry();const material = new THREE.MeshBasicMaterial({ color: Math.random() * 0xffffff });const cube = new THREE.Mesh(geometry, material);cube.position.x = (i - 2) * 2; // 设置不同位置this.scene.add(cube);this.cubes.push(cube); // 将立方体对象添加到数组中}// 在立方体之间绘制箭头线const startPoint = new THREE.Vector3(0, 0, 0);const endPoint = new THREE.Vector3(2, 0, 0);const direction = new THREE.Vector3().subVectors(endPoint, startPoint);const length = direction.length();const arrowHelper = new THREE.ArrowHelper(direction.normalize(), startPoint, length, 0xff0000);this.scene.add(arrowHelper);this.arrowHelpers.push(arrowHelper);// 渲染循环const animate = () => {requestAnimationFrame(animate);this.controls.update(); // 更新控制器this.renderer.render(this.scene, this.camera);};animate();},onCanvasDoubleClick(event) {// 获取双击位置const x = event.clientX;const y = event.clientY;// 将屏幕坐标转换为Three.js中的坐标const canvas = document.getElementById('canvas');const rect = canvas.getBoundingClientRect();const mouseX = ((x - rect.left) / canvas.clientWidth) * 2 - 1;const mouseY = -((y - rect.top) / canvas.clientHeight) * 2 + 1;// 创建一个Three.js射线const raycaster = new THREE.Raycaster();raycaster.setFromCamera(new THREE.Vector2(mouseX, mouseY), this.camera);// 检测射线与物体的交点const intersects = raycaster.intersectObjects(this.cubes, true);// 如果有交点,则触发双击事件if (intersects.length > 0) {alert('Double click event triggered on the object!');}}}
};
</script><style>
#canvas {width: 100%;height: 100%;
}
</style>

场景。

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

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

相关文章

【原创教程】三菱Q与MERLIN II LS激光打标机控制说明

一、控制流程说明 1.硬件连接→2.软件通讯连接→3.编写远程控制PLC程序→4.编写通讯命令。 二、硬件连接1.用RJ45口普通网线将PLC和打标机连接。 三、软件通讯连接 1.打标机侧工控机-更改操作权限-点击菜单栏Setup,在下拉菜单中,点击Level,在下一级菜单点击Supervisor(左下…

关于python的字节串与字符串的转换

1. 背景 我写了一个RC4加密的程序&#xff0c;如下所示。 data b"204EF6D2FB3B" key b123# 加密&#xff08;引用传递&#xff09; dll.RC4_enc_dec(data,key) print(加密结果&#xff1a;,data) # ba\xc0\x8b\xc7\xa3B\xc9c!0\xc8# 解密 dll.RC4_enc_dec(data,…

C++中的结构体——结构体案例1_2

案例描述 学校正在做毕设项目&#xff0c;每位老师指导5名学生&#xff0c;总共有3名老师&#xff0c;需求如下 设计学生和老师的结构体&#xff0c;其中在老师的结构体中&#xff0c;有老师的姓名和一个存放5名学生的数组作为成员 学生的成员有姓名、考试分数&#xff0c;创…

51.Python-web框架-Django开始第一个应用的增删改查

目录 1.概述 2.创建应用 创建app01 在settings.py里引用app01 3.定义模型 在app01\models.py里创建模型 数据库迁移 4.创建视图 引用头 部门列表视图 部门添加视图 部门编辑视图 部门删除视图 5.创建Template 在app01下创建目录templates 部门列表模板depart.ht…

Controller 自动化日志输出

Starter库 1.定义注解 Target(ElementType.METHOD) Retention(RetentionPolicy.RUNTIME) Documented public interface TraceLog {/*** 日志类型** return*/String type() default ""; }2.定义捕获日志接口方法 public interface ITraceLogProcess {void afterThr…

uniapp条件编辑语法

uniapp中的“条件编译”&#xff1a;#ifdef详细解释_uniapp #ifdef-CSDN博客 uniapp 多端兼容 #ifdef #ifndef #endif 和 平台标识 - 简书

计算机图形学入门10:着色

1.真实的世界 经过前面的变换&#xff0c;再到三角形遍历&#xff0c;深度缓存后&#xff0c;屏幕上每个像素都有了对应的颜色&#xff0c;显示的结果大概是如下左图的样子&#xff0c;我们发现物体每个面的颜色都一样&#xff0c;看起来不够真实。而如下右图显得更加真实&…

迁移学习和从头训练(from scratch)的区别

例如对于图像分类任务&#xff0c;有自己的数据集&#xff0c;打算利用 resnet 来实现&#xff0c;有2种实现方式&#xff0c; 第一种&#xff1a;利用在 ImageNet 上已经预训练过的预训练权重来进行 fine-tuning。第二种&#xff1a;不使用在 ImageNet 上已经预训练过的预训练…

2024年中漫谈

不知不觉&#xff0c;2024年已来到了6月&#xff0c;博主不禁感叹时光易逝&#xff0c;岁月的车轮滚滚向前&#xff0c;永不止步&#xff0c;此刻无关贫穷与富裕&#xff0c;伟大与平凡。 于是乎&#xff0c;宇宙&#xff08;时空&#xff09;看似毫无终点&#xff0c;一望无垠…

C++中的23种设计模式

目录 摘要 创建型模式 1. 工厂方法模式&#xff08;Factory Method Pattern&#xff09; 2. 抽象工厂模式&#xff08;Abstract Factory Pattern&#xff09; 3. 单例模式&#xff08;Singleton Pattern&#xff09; 4. 生成器模式&#xff08;Builder Pattern&#xff0…

C# Task 包含 await ConfigureAwait CancellationTokenSource

Task以下是 Task 类的一些关键特性和用法&#xff1a;以下是一些使用 Task 的示例&#xff1a;创建并启动一个任务使用 await 等待任务完成处理任务异常使用 Task<TResult> 获取结果取消任务总结 await暂停方法执行&#xff1a;非阻塞调用&#xff1a;任务结果获取&#…

哈默纳科Harmonic谐波减速机应用领域有哪些

在制造设备中&#xff0c;精确控制速度与位置的需求日益凸显&#xff0c;这为谐波减速机的广泛应用提供了广阔的舞台。哈默纳科Harmonic谐波减速机以结构紧凑、高精度、高刚度、高可靠性、便于安装维护等优势&#xff0c;在工业机器人和自动化系统中发挥着举足轻重的作用。 一、…

C# 使用 webview2 嵌入网页

需求&#xff1a;C#客户端程序, 窗口里嵌入一个web网页&#xff0c;可通过URL跳转的那种。并且&#xff0c;需要将登录的身份验证信息&#xff08;token&#xff09;设置到请求头里。 核心代码如下&#xff1a; // 打开按钮的点击事件 private void openBtn_Click(object sen…

Docker 学习总结(82)—— docker 磁盘空间如何清理

一、删除停止的容器: docker container prune 二、删除未使用的网络: docker network prune 三、删除未使用的卷: docker volume prune 四、清理悬空镜像&#xff08;没有标签的镜像&#xff0c;通常是构建过程中产生的中间层&#xff09;: docker image prune 五、清理…

低-零功率技术在军事中的应用

“低-零功率”概念最先由美国国防部提出&#xff0c;主要是针对诸如俄罗斯等大国的远程传感器&#xff0c;帮助美军破除“灰色地带挑衅”的威胁。由于“灰色地带”冲突仅依托小规模军事力量&#xff0c;其强度维持在不足以引发美国及其盟国进行直接干预的程度&#xff0c;因此&…

二维码扫描,没有生成,生成比较复杂

一&#xff0c;增加远程依赖 app构建脚本中加&#xff1a; implementation com.journeyapps:zxing-android-embedded:4.3.0 二&#xff0c;注册表改一下 <?xml version"1.0" encoding"utf-8"?> <manifest xmlns:android"http://sch…

2024COSP上海国际户外展邀您一起享受户外徒步之旅,感受低碳新生活

在现在快节奏的生活中&#xff0c;我们常常忘记了那些慢慢走过的时光。科技的快速发展让我们得以快速穿越大地&#xff0c;却也让我们失去了与自然亲密接触的机会。许多壮丽的风景&#xff0c;并不是坐在车窗后、屏幕前就能够完全领略的&#xff0c;它们需要你放慢脚步&#xf…

Elasticsearch集群安全性:访问控制与加密通信

在现今的数据驱动世界中&#xff0c;Elasticsearch因其强大的搜索和分析功能而广受欢迎。然而&#xff0c;随着数据量的增长和安全性需求的提高&#xff0c;如何确保Elasticsearch集群的安全性成为了重要的议题。本文将探讨Elasticsearch集群的访问控制和加密通信两个关键的安全…

这总商务会议图怎么绘制?一行代码搞定...

今天这篇推文小编给大家介绍一个一直想绘制的图表-议会图(parliament diagrams),当然这也是柱形图系列变形的一种。绘制这种图表也是超级简单的&#xff0c;只需使用R-ggpol包进行绘制即可&#xff0c;当然&#xff0c;改包还提供其他优秀的绘图函数&#xff0c;下面就一起来看…

什么牌子充电宝质量好耐用呢?认准这几个充电宝,凭实力出圈

在快节奏的现代生活中&#xff0c;科技的不断进步使得各类移动设备如手机、平板和笔记本电脑成为人们生活中不可或缺的部分。为了应对这些设备不断增长的能源需求&#xff0c;充电宝市场的崛起迅猛并呈现出持续增长的态势。 在选购移动电源时&#xff0c;如何识别性能出众、质量…