2

在 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 中关闭透视?

谢谢!

4

1 回答 1

9

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

        $(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();
        });
于 2012-06-25T02:35:22.490 回答