手写一个简单的 OrbitControls 轨道控制器

2024-04-13 05:20

本文主要是介绍手写一个简单的 OrbitControls 轨道控制器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

手写一个简单的 OrbitControls 轨道控制器

相信使用过THREE.JS的同学,都知道 OrbitControls 这个的轨道控制器,他是绕着一个观察点,来进行什么什么的… 反正就是那么个意思。
所以很明显OrbitControls的运动轨迹是一个球体,他是绕着球体进行运动的。
所以也很明显,我们只有知道每一点,球体的坐标 (x, y, z) 就可以实现这个效果,然后再把这个坐标,赋值给 相机对象就可以实现了

2.那么我们应该怎么获取到球体的坐标呢

在这里插入图片描述
这是我画的可视化图解,我们可以发现,球上的一点 P(x, y, z) 与 它的角度的之间的关系。
最后得出

x = R * Math.sin(theat) * Math.cos(phi);
y = R * Math.cos(theat);
z = R * Math.sin(theat) * Math.sin(phi); 

所以这就是前面的理论部分,接下来我们就要完成具体的编码

class OrbitiControls {constructor(camera, domElement) {this.camera = camera;this.domElement = domElement;// 创建一个鼠标位置对象this.mouse = {x: 0,y: 0,down: false}// 绕着的目标this.target = new Vector3(0,0,0);// 计算轨道球体半径this.radius = this.camera.position.distanceTo(this.target);// 记录旋转的角度this.rotate = {theta: Math.atan2(this.camera.position.x, this.camera.position.z),phi: Math.acos(this.camera.position.y / this.radius)}this.domElement.addEventListener('mousedown', this.onMouseDown.bind(this));this.domElement.addEventListener('mouseup', this.onMouseUp.bind(this));this.domElement.addEventListener('mousemove', this.onMouseMove.bind(this));}onMouseDown() {// 当鼠标按下时this.mouse.down = true;}onMouseUp() {// 当鼠标抬起时this.mouse.down = false;}onMouseMove(event) {if (this.mouse.down) {let x = event.movementX;let y = event.movementY;if (x > 3) x = 3;if (x < -3) x = -3;if (y > 3) y = 3;if (y < -3) y = -3;this.rotate.theta -= x * 0.01;this.rotate.phi -= y * 0.01;// 限制phi的范围if (this.rotate.phi < 0.1) {this.rotate.phi = 0.1;}if (this.rotate.phi > Math.PI - 0.1) {this.rotate.phi = Math.PI - 0.1;}//  根据角度计算相机位置this.camera.position.x =this.radius * Math.sin(this.rotate.phi) * Math.cos(this.rotate.theta);this.camera.position.y = this.radius * Math.cos(this.rotate.phi);this.camera.position.z =this.radius * Math.sin(this.rotate.phi) * Math.sin(this.rotate.theta);this.camera.lookAt(this.target);console.log(this.camera);}}}

这篇关于手写一个简单的 OrbitControls 轨道控制器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

详解如何在SpringBoot控制器中处理用户数据

《详解如何在SpringBoot控制器中处理用户数据》在SpringBoot应用开发中,控制器(Controller)扮演着至关重要的角色,它负责接收用户请求、处理数据并返回响应,本文将深入浅出地讲解... 目录一、获取请求参数1.1 获取查询参数1.2 获取路径参数二、处理表单提交2.1 处理表单数据三、