three.js学习记录(鼠标控制)

一、鼠标控制 - 轨道控制器(OrbitControls)

  1. 从nodeModules中导入OrbitControls,OrbitControls 是一个附加组件,必须显式导入

import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";

注意:从官网上粘贴的引入路径有时候是不对的,手动从自己的node_modules中找一下OrbitControls.js文件的路径,核实准确才有效。

  1. 通过new OrbitControls实例化一个controls,OrbitControls有两个参数,分别是camera(相机),domElement(用于事件监听的HTML元素,即当下绘制在界面的canvas元素)

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

  1. 在动画循环requestAnimationFrame中实时更新,不断加载位置的变化 【方案一】

一般多用【方案一】

function animate() {

requestAnimationFrame( animate );

controls.update();

renderer.render( scene, camera );

}

requestAnimationFrame( animate );

注意:如果此处没有用动画requestAnimationFrame,仅仅只是new OrbitControls(camera, renderer.domElement),则鼠标控制的效果是看不到的,即使鼠标在移动的过程中相机camera的位置是在不断变化的,但这个位置并没实时渲染到canvas上。

  1. 如果不使用requestAnimationFrame进行渲染相机位置的变化,还可以通过监听Orbitcontrol的change事件进行渲染,【方案二】

controls.addEventListener('change',() => {

renderer.render( scene, camera );

})

  1. 惯性enableDamping(默认为false),鼠标控制相机旋转时,false情况下鼠标抬起的一瞬间,旋转效果就立即停止;设置为true时,必须配合动画requestAnimationFrame,在动画中通过update方法更新控制器,即当鼠标抬起,物体的旋转会有个缓冲过程,慢慢停下(更符合物体运动规律)

    const controls = new OrbitControls(camera, renderer.domElement)
    controls.enableDamping = true
    controls.addEventListener('change',() => {
    controls.update();
    renderer.render( scene, camera );
    })

效果如下:

鼠标控制

相关推荐
AI成长日志18 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
_李小白19 小时前
【OSG学习笔记】Day 38: TextureVisitor(纹理访问器)
android·笔记·学习
杨云龙UP19 小时前
从0到1快速学会Linux操作系统(基础),这一篇就够了!
linux·运维·服务器·学习·ubuntu·centos·ssh
头疼的程序员20 小时前
计算机网络:自顶向下方法(第七版)第八章 学习分享(三)
网络·学习·计算机网络
_李小白20 小时前
【OSG学习笔记】Day 37: NodeVisitor(顶点访问器)
笔记·学习
程序员雷欧21 小时前
大模型应用开发学习第八天
大数据·人工智能·学习
晓晓hh21 小时前
JavaSE学习——set集合和Map映射
学习
لا معنى له1 天前
Var-JEPA:联合嵌入预测架构的变分形式 —— 连接预测式与生成式自监督学习 ----论文翻译
人工智能·笔记·学习·语言模型
世人万千丶1 天前
Flutter 框架跨平台鸿蒙开发 - 宠物语言翻译器应用
学习·flutter·华为·开源·harmonyos·鸿蒙
AI成长日志1 天前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试