javascript - 三.js 初始化与靠近相机的对象
问题描述
在我的 three.js 项目中,我像这样设置我的场景和相机:
var container = document.getElementById('container');
renderer = new THREE.WebGLRenderer({ antialias: true });
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
renderer.setAnimationLoop(render);
renderer.outputEncoding = THREE.sRGBEncoding;
renderer.toneMapping = THREE.ACESFilmicToneMapping;
renderer.toneMappingExposure = 1.25;
container.appendChild(renderer.domElement);
window.addEventListener('resize', onWindowResize, false);
stats = new Stats();
container.appendChild(stats.dom);
//
camera = new THREE.PerspectiveCamera(40, window.innerWidth / window.innerHeight, 0.1, 100);
camera.position.set(3.5, 2, - 2.5);
controls = new OrbitControls(camera, container);
controls.target.set(0, 0.5, 0);
controls.update();
scene = new THREE.Scene();
scene.background = new THREE.Color(0xeeeeee);
scene.environment = new RoomEnvironment(renderer);
scene.fog = new THREE.Fog(0xeeeeee, 10, 50);
...
好吧,我的场景是这样开始的:
我想开始加倍我的对象,像这样:
我尝试:
camera.zoom.set(2);
但什么也没发生所以我尝试定义一个vector3(2,2,2)并缩放我的对象:
myobj.scale.set(myVector3);
没有什么。
有人可以帮助我用更大的对象开始我的场景吗?
非常感谢提前
解决方案
如果你这样做:
camera.zoom.set(2);
您必须确保像这样更新项目矩阵:
camera.updateProjectionMatrix();
关于另一个问题,Vector3.set()
只接受三个标量作为参数。您不能将该方法与 type 的单个参数一起使用Vector3
。所以你可以这样做:
myobj.scale.set(myVector3.x, myVector3.y, myVector3.z);
甚至更好:
myobj.scale.copy(myVector3);
推荐阅读
- html - 使用 Bootstrap 在 10 列网格中拟合任意数量的元素
- python - 尝试访问 Azure Databricks 中的 Azure DBFS 文件系统时出现挂载错误
- c# - 在 Windows 窗体 C# 应用程序中使用报表查看器打印报表时出现问题
- sql - 是否可以在一个函数调用中执行多个替换?
- regex - 不能为空格的字母和空格的正则表达式
- python - 映射日期时间引发 KeyError
- sql-server - SQL Server 中的“生成脚本”在“从 (mydbname) 获取对象列表”时失败
- bash - bash 本机字符串操作显示混乱的输出
- c++ - 为什么这个错误会变成(C2664 error c++ Visual Studio)
- jar - 如何使用 java 11 在类路径中动态加载 jar