gpt4 book ai didi

webgl - ThreeJS 正交相机 : Adjusting size of scene to window

转载 作者:行者123 更新时间:2023-12-05 00:42:15 24 4
gpt4 key购买 nike

在 ThreeJS 中,我使用的是 OrthographicCamera,因为我有几个对象应该从前面显示,没有任何透视失真。这适用于一个问题:我创建的一堆对象应该总是大致填满屏幕,但不能太小或太大。使用例如

var factor = 4.5;
this.camera = new THREE.OrthographicCamera(-window.innerWidth / factor, window.innerWidth / factor, window.innerHeight / factor, -window.innerHeight / factor, 1, 1000);

...我可以让它在 1920x1080 像素分辨率下正常运行,但是当我将窗口大小调整为更小并重新加载页面时,对象将开始变得太大,因为它们的行为就好像它们是固定的. (当使用带透视的 CombinedCamera 时,调整大小是动态的并且效果很好。)如何使用 OrthographicCamera 解决这个问题?或者有什么技巧可以让我在 CombinedCamera 中关闭透视?

谢谢!

最佳答案

我不确定这是否有助于解决您的特定问题。我不确定这是否正确,或者是否有更好或更标准的方法来处理这个问题。但到目前为止,这是我在正交代码中使用的。它无论如何都不是完美的,但你可以尝试一下。如果您有更好的办法,请回复并告诉我。

        $(window).on('resize', function () {
// notify the renderer of the size change
renderer.setSize(window.innerWidth, window.innerHeight);
// update the camera
camera.left = -window.innerWidth / camFactor;
camera.right = window.innerWidth / camFactor;
camera.top = window.innerHeight / camFactor;
camera.bottom = -window.innerHeight / camFactor;
camera.updateProjectionMatrix();
});

关于webgl - ThreeJS 正交相机 : Adjusting size of scene to window,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11170952/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com