018-场景遍历和世界坐标系

该系类文章主要用于记录学习three.js的过程,包括做的一些demo,笔记,以及个人思考;主要学习的课程是 神光的小册《three.js通关秘籍》,感兴趣的可以购买学习,质量还是可以的

坐标系

坐标系的分类的详细解释

坐标系一般分为世界坐标系局部坐标系 ,还有group坐标系

局部坐标系:就是某个物体相对所在group中的坐标

自身坐标系:就是某个物体自身的坐标

世界坐标系:全局坐标系就是把局部坐标系与group坐标系进行合并,所得到的坐标系

坐标系的操作方法

  • 如何获取坐标
ini 复制代码
# 获取全局坐标
const pos = new THREE.Vector3();
mesh.getWorldPosition(pos);
#  获取group坐标
console.log(group.position);
# 获取局部坐标(自身坐标)
console.log(mesh.position);

遍历场景

通常情况下,我们的场景非常的复杂,可能包括很多的分组,分组里面又包含了很多物体,很多时候我们需要获取某一个物体,然后再进行操作,那么如何获取呢?

遍历场景这棵树结构

ini 复制代码
scene.traverse((obj) => {
    if(obj.isMesh) {
        obj.material.color = new THREE.Color('pink');
    }
});

找到某个物体

ini 复制代码
# 通过取名字获取
# 给mesh设置名字
mesh.name = 'abc';
mesh.name = 'eeee';
# 通过名字获取(当然也可以用 id  来获取,设置的时候也用id)
const target1 = scene.getObjectByName('abc');
const target2 = scene.getObjectById('eeee');
相关推荐
望道同学22 分钟前
PMP/信息系统项目管理师 9 张 思维导图【考试必备】
前端·后端·程序员
局i1 小时前
Vue 中 v-text 与 v-html 的区别:文本渲染与 HTML 解析的抉择
前端·javascript·vue.js
菜鸟冲锋号2 小时前
问题:增量关联(实时同步新数据) 这个场景中,如果hudi_pay 变更了一条数据,hudi_order_pay_join 结果的数据会跟着变化吗
服务器·前端·数据库
贩卖黄昏的熊2 小时前
typescript 快速入门
开发语言·前端·javascript·typescript·ecmascript·es6
拾柒SHY2 小时前
XSS-Labs靶场通关
前端·web安全·xss
前端婴幼儿2 小时前
前端主题切换效果
前端
一 乐2 小时前
水果销售|基于springboot + vue水果商城系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
Qin_jiangshan2 小时前
如何成为前端架构师
前端
dolt022 小时前
基于deepseek实现的ai问答小程序
前端·开源
一只小bit3 小时前
Qt 快速开始:安装配置并创建简单标签展示
开发语言·前端·c++·qt·cpp