首页 > 其他分享 >threejs中OrbitControls的用法

threejs中OrbitControls的用法

时间:2024-09-02 17:55:03浏览次数:18  
标签:threejs OrbitControls controls 用法 相机 camera renderer js

OrbitControls 是 Three.js 库中一个非常流行的相机控制组件,它允许用户通过鼠标(或触控设备)来旋转、缩放和平移场景中的相机,从而从不同的角度和距离观察场景。

threejs中OrbitControls的用法_threejs

下面是如何在 Three.js 中使用 OrbitControls的方法:

1. 引入 OrbitControls

首先需要从 Three.js 的 CDN 或本地路径中引入 OrbitControls。例如:

https://unpkg.com/three@versionbuild/three.min.js
https://unpkg.com/three/examples/jsm/controls/OrbitControls.js

2. 创建场景、相机和渲染器

在使用 OrbitControls 之前,需先设置好Threejs 场景,包括场景(scene)、相机(camera)和渲染器(renderer)等:

const scene = new THREE.Scene();
    const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
    const renderer = new THREE.WebGLRenderer();
    renderer.setSize(window.innerWidth, window.innerHeight);
    document.body.appendChild(renderer.domElement);
    //相机位置
    camera.position.z = 5;

3. 初始化 OrbitControls

接下来,初始化 OrbitControls,并将它与之前创建的相机相关联。

const controls = new THREE.OrbitControls(camera, renderer.domElement);

注:上面代码中,camera 是你之前创建的相机,renderer.domElement 是渲染器的 DOM 元素,通常是 canvas 元素,它是用户与 OrbitControls 交互的表面。

4. 配置 OrbitControls

OrbitControls 提供了许多配置选项,例如,你可以禁用缩放或平移功能,或者改变阻尼(damping)来使相机运动更平滑。

// 禁用缩放
    controls.enableZoom = false;
    // 启用自动旋转
    controls.autoRotate = true;
    // 设置阻尼系数
    controls.dampingFactor = 0.05;

5. 渲染循环

在渲染循环中,调用 controls.update() 来确保控制器正确响应用户的鼠标行为。

function animate() {
        requestAnimationFrame(animate);
        // 更新控制器
        controls.update();
        // 渲染场景
        renderer.render(scene, camera);
    }
    animate();

通过以上步骤,就可以在 Three.js 项目中使用 OrbitControls 来提供丰富的相机控制功能的。

此外,需要注意的是:threejs开发的项目,是JS语法、运行于浏览器,他人只需在浏览器中右键查看网页源码,便可得获得源码,可以分析功能逻辑、可以复制、可以运行调试。为了防止代码被任意分析、复制、盗用。threejs开发的功能在发布前通常需要先用JShaman、JS-Obfuscator、JsJiaMi.Online等工具进行JS代码混淆加密,以解决其公开透明特性带来的代码不安全问题。

JShaman:https://www.jshaman.com/
JsJiami:https://www.jsjiami.online/
JS-Obfuscator:https://www.js-obfuscator.com/

threejs中OrbitControls的用法_渲染器_02

标签:threejs,OrbitControls,controls,用法,相机,camera,renderer,js
From: https://blog.51cto.com/jsjiami/11899799

相关文章

  • C++中namespace的用法
    我们在现实的项目开发中一般会有着大量的代码,而且代码都是多人编写的,也许一个项目会有10个功能,每一个人都要完成一个功能。但是敲过代码的都知道,一般在编写程序的时候如果多人没有实现约定去完成,那就会出现代码冲突的情况,那么,为了解决这样的冲突,我们C++中使用了命名空间namesp......
  • Prop效验与Prop默认值用法及循环遍历数组
    Prop效验与使用在HBuilderX里面你把组件传过去,向之前的那样的写法是没有默认值的,写了才有值,否则为空,所以我们可以用另一种方法,写法如下虽然这样写了但是不是完全体的,我们可以给他定个默认值和类型,就像那个String一样,可以约束对象只能是这个的类型这样子另一个页面......
  • computed计算属性及方法对比和循环遍历统计以及watch和watchEect监听的用法
    1.computed计算属性及方法对比1.了解computed计算属性和用法在我们的一些应用中可以看的应用会给我们提供一些计算类的功能比如取名,它会给你提供两个输入框,然后在你给这两个输入框输入值的时候会在下方生成你输入这个两个值的结合值,就比如你先输入了一个姓氏,然后输入一个名,下......
  • 【c++实用】CMakeLists 基本用法(一)
    指令解释cmake_minimum_required(VERSION3.24):指令指定了所需的最低CMake版本a.作用:确保在执行CMake配置时,使用的CMake版本不低于3.24。如果安装的CMake版本低于指定的版本,CMake将会输出错误信息,并拒绝继续执行后续命令b.兼容性:有助于确保项目构建脚......
  • Threejs路径规划案例V1
       最近在做一个路径规划的例子,大概场景是在一个xy坐标系中,有几个障碍物,一个车要绕过这些障碍物到达目的地,本来用java来实现,但是java调试太不直观了,我就想起用threejs把场景简单搭建出来,规划好的路线也直接展示出来,就可以实时查看路径规划的怎么样了。先来一张效果图:首先是添加t......
  • 【C#】一个喜欢用Python的菜狗在尝试Linq之后总结的常见用法以及示例
    1.筛选(Where)筛选集合中的元素。类似python中列表推导式中的if示例int[]numbers={1,2,3,4,5,6};varevenNumbers=numbers.Where(n=>n%2==0);foreach(varnuminevenNumbers){Console.WriteLine(num);}//输出:2,4,6python中的实现[if......
  • Mockito用法总结
    Mockito的是用来做什么的Mockito主要用于单元测试过程中模拟被调用方法的依赖<dependency><groupId>org.mockito</groupId><artifactId>mockito-core</artifactId><version>4.8.0</version><scope>test</scope></depende......
  • Vue 过滤器(Filter)的理解与用法
    Vue.js是一个渐进式JavaScript框架,它提供了丰富的功能来构建用户界面。其中,过滤器(Filter)是一个非常有用的特性,它允许我们在模板中对数据进行格式化处理。本文将详细介绍Vue过滤器的概念、用法以及一些最佳实践。1.过滤器的基本概念1.1什么是过滤器?过滤器是Vue提供的一种......
  • Linux中cd命令的基本用法!
    cd命令是Linux中最常见的命令之一,全拼changedirectory,其命令主要用于切换当前工作目录,本篇文章为大家介绍一下Linux中cd命令的常见用法,一起来看看吧。常见的cd命令用法:1、进入当前工作目录下的目录:cd./2、进入其他目录:cd/home/user/documents/3、......
  • C++学习随笔——C++11的array、forward_list、tuple的用法
    1.std::arraystd::array是C++11引入的一个封装了原生数组的容器,它结合了C++标准库容器的优点和C风格数组的效率。#include<array>#include<iostream>intmain(){std::array<int,5>arr={1,2,3,4,5};//初始化一个大小为5的数组//访问元素......