web3d-three.js场景设计器-TransformControls模型控制器

14fe3076823b4b498b4d29b4f66eb633.gif

场景设计器-TransformControls 控制器

  • 该控制器可以指定模型进入可控制模式-如图
  • 有三种控制方式
    • translate  --移动模式

    • rotate  -- 旋转模式

    • scale -- 缩放模式

  • 方便布局过程中快捷对模型进行摆放操作。

  • 引入方式

    • import { TransformControls } from 'three/examples/jsm/controls/TransformControls.js';

  • 使用方式

    •  // 对TransformControls的使用

            this.transformControls = new TransformControls(this.camera, this.renderer.domElement);

            this.scene.add(this.transformControls);

  • 选取操作

    •    // 模型移动

          initChange(transformControls) {

          var changeRaycaster = new THREE.Raycaster();

          var changeMouse = new THREE.Vector2();

       

          this.renderer.domElement.addEventListener('click',  (event)=> {

              changeMouse.x = (event.offsetX / this.renderer.domElement.clientWidth) * 2 - 1;

              changeMouse.y = -(event.offsetY /  this.renderer.domElement.clientHeight) * 2 + 1;

              changeRaycaster.setFromCamera(changeMouse, this.camera);

              var intersects = changeRaycaster.intersectObjects(this.modelsArray);  //

              // console.log('相机的模型', intersects, intersects.length);

              if (intersects.length > 0) {

                  var selectedObject = intersects[0].object;

                  transformControls.attach(selectedObject);

                  // 为移动模式

                  transformControls.setMode("translate");

                  // 为旋转模式

                  //transformControls.setMode("rotate");

                  // 为缩放模式

                  //transformControls.setMode("scale");

       

              } else {

                  // 如果点击的不是模型,那么解除模型与TransformControls的附加

                  transformControls.detach();

              }

          });



       

          transformControls.addEventListener('dragging-changed',  (event)=> {

              this.controls.enabled = !event.value;

       

              //mapControls.enabled = !event.value;  // 如果TransformControls正在拖动,则禁用MapControls

          });

      }

 

 

 

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

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

相关文章

数据结构之哈希——学习笔记

今天看网课学习了哈希的数据结构,写下这一篇博客记录自己的学习过程。 1.哈希简介: 我们发现某些时候映射到小集合的时候会同时有多个值映射到一个下标里面,所以接下来是这种情况的解决方案1: 我们考虑当两个数字映射之后的结果…

提升网络安全重要要素IP地址

在数字化时代,网络安全已经成为人们关注的焦点。本文将深入探讨网络安全与IP地址之间的紧密联系,以及IP地址在构建数字世界的前沿堡垒中的关键作用。 网络安全是当今数字社会中不可忽视的挑战之一。而IP地址,作为互联网通信的基础协议&#…

视频融合云平台/智慧监控平台EassyCVR告警警告出错是什么原因?该如何解决?

视频集中存储/云存储/视频监控管理平台EasyCVR能在复杂的网络环境中,将分散的各类视频资源进行统一汇聚、整合、集中管理,实现视频资源的鉴权管理、按需调阅、全网分发、智能分析等。AI智能/大数据视频分析EasyCVR平台已经广泛应用在工地、工厂、园区、楼…

Graceful Response 构建 Spring Boot 下优雅的响应处理

一、Graceful Response Graceful Response 是一个 Spring Boot 技术栈下的优雅响应处理器,提供一站式统一返回值封装、全局异常处理、自定义异常错误码等功能,使用Graceful Response进行web接口开发不仅可以节省大量的时间,还可以提高代码质…

计算机网络期末知识汇总

一、计算机网络概述 1.Internet 的中文译名并不统一。 现有的 Internet 译名有两种: 因特网,这个译名是全国科学技术名词审定委员会推荐的,但却长期未得 到推广; 互联网,这是目前流行最广的、事实上的标准译名。现…

Spark MLlib简介与机器学习流程

在大数据领域,机器学习是一个关键的应用领域,可以用于从海量数据中提取有价值的信息和模式。Apache Spark MLlib是一个强大的机器学习库,可以在分布式大数据处理环境中进行机器学习任务。本文将深入介绍Spark MLlib的基本概念、机器学习流程以…

游戏进度恢复--备忘录模式

缘起 某日,部门Leader给小明布置了一个任务:编码出游戏某个场景,游戏角色有生命力、攻击力、防御力等数据,打Boss前和后数据是不一样的,我们允许玩家若感觉与Boss决斗效果不理想可以让游戏恢复到决斗前。 小明的代码 …

IP代理测试:关于Ping测试你需要知道的一切干货

您在访问互联网时是否遇到过持续滞后或花费很长时间等待网站加载的情况?为了避免这种情况,您可以测试 ping 以查看连接速度。如果您使用代理,此 ping 测试还会显示代理服务器的响应速度。 ping 测试是一个很有价值的工具,可以帮助…

Linux第9步_通过终端查看U盘文件

学习完“USB设置”后,我们学习通过终端来查看U盘文件。前面讲解过使用鼠标打开U盘,但是在实际使用中,更多的还是采用命令来实现对U盘的操作。 1、在桌面,右击鼠标,弹出下面的界面: 2、点击上图中的“打开终端”&#…

RocketMQ源码 发送消息源码分析

前言 DefaultMQProducer 是默认生产者组件,是生产者客户端中,绝大部分关于生产者和broker、nameSrv进行网络通信的功能入口。其中,包含发送各种形式(同步、异步、事务、顺序)的消息,针对发送消息部分的实现…

企业微信 get请求 设置可信域名

import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController;RestController public class ValidController {GetMapping("/xxxxx.txt")public String getText() {//返回下载的txt里的内容return &…

真核微生物基因序列鉴定工具EukRep工具的安装和详细使用方法

介绍 EukRep是一种用于鉴定并分析环境中的真核微生物的工具。它基于16S rRNA基因序列,可以帮助研究人员确定和分类环境样品中存在的真核微生物群落。 EukRep 从宏基因组数据集中分类真核和原核序列 安装 要求Python3 推荐使用conda安装: $ conda cre…