-1- threejs 场景常见的方法和属性

场景的作用

场景(THREE.Scene)用于存储物体、光源、摄像机及其渲染所需要的其他的对象集合。THREE.Scene 对象又是被称为场景图,它不仅仅是一个对象数组,还包含了整个场景图树形结构中的所有节点:每个添加到 Three.js 场景的对象,甚至包括 THREE.Scene 本身都是继承自一个名为THREE.Object3D 的对象。每个 THREE.Object3D 对象也可以有自己的子对象,我们可以使用它的子对象来创建一个 Three.js 能解释和渲染的对象树。

场景的坐标系

threejs 默认是右手坐标系,即 x轴正方向向右,y轴正方向向上,z轴正方向由屏幕从里向
在这里插入图片描述

常用的属性

  1. background 设置场景的背景,例如利用这个设置天空盒子。
initSky(name = "星空", suffix = "jpg") {
      var urls = [
        require("../../../public/img/sky/" + name + "/posx." + suffix),
        require("../../../public/img/sky/" + name + "/negx." + suffix),
        require("../../../public/img/sky/" + name + "/posy." + suffix),
        require("../../../public/img/sky/" + name + "/negy." + suffix),
        require("../../../public/img/sky/" + name + "/posz." + suffix),
        require("../../../public/img/sky/" + name + "/negz." + suffix),
      ];
      var textureCube = new THREE.CubeTextureLoader().load(urls);
      scene.background = textureCube;
    },

  1. fog 控制场景中的每个物体的雾的类型。

scene.fog=new THREE.Fog( oxffffff, 0.015, 100 ) 我们在这里定义了一个白色的雾 效果(oxffffff) 后面的两个属性用来调节雾 显示0.015 near 近处)属性的值,而 100 设置的是 far (远处)属性的值 通过这两个属性你可以决定雾从什么地方开始 以及浓 加深的程度 还有另外一个方法可以设置场景中雾的浓度;你可以使用如下的定义:scene.fog=new THREE.Fog( oxffffff, 0.015) 这次我们不指定 near 属性和 far 属性 ,只给出颜色和浓度 要想获得理想的效果。
3. environment 设置场景中没有纹理物体的默认纹理,如物体有纹理不会修改其纹理。

scene.overrideMaterial=new  THREE.MeshLambertMaterial({color : Oxffffff}};
  1. children 返回场景的所有子对象。

常用的方法

方法描述作用
add ( object)在场景中添加对象 你可以像我们后面看到的那样,创建对象组向场景中添加对象,返回null
copy继承自Object3D对象copy ( object : Object3D, recursive : Boolean )若recursive为true,则object对象的子对象也将会被复制把给定对象复制到当前对象中
toJSONtoJSON: function ( meta )继承Object3D以json格式返回场景数据
childrenchildren : Object3D返回一个场景中所有对象的列表,包括相机和光源
getObjectByNamegetObjectByName ( name : String ) : Object3D创建对象的时候,可以通过name属性为对象指定一个名字,然后可以通过这个方法,根据 name 来查找该对象,并这个对象,Object3D的方法中还可以根据 id 进行查找
removeremove ( object : Object3D, … ) : null删除场景中的对象
traversetraverse ( callback : Function ) : nullchildren 属性返回场景中所有子对象的列表,通过traverse函数,可以在当前对象和它的子对象列表上执行回调
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

圣京都

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值