- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在谷歌上进行了广泛的搜索,但我还没有找到我认为实际上很常见的情况的解决方案。假设我有一个THREE.PerspectiveCamera
初始化为查看空间中的某个点:
var camera = new THREE.PerspectiveCamera(45, 2, 0.1, 100);
var target = new THREE.Vector3(1, 2, 3);
camera.lookAt(target);
现在,稍后在代码中我希望能够找到 target
的坐标只需查询 camera
.
我尝试了 this question 中的建议,根据我自己的场景进行调整:
var vector = new THREE.Vector3();
vector.applyQuaternion(camera.quaternion);
console.log(vector);
但它记录了一个坐标向量 (0, 0, 0)
而不是正确的坐标(在我的示例中,应该是 (1, 2, 3)
)。
有什么见解吗?干杯。
编辑:
好吧,我将尝试在这里结合上下文,以证明为什么 MrTrustworthy 的解决方案不幸地不适用于我的场景。我正在尝试调整 THREE.OrbitControls
出于我的目的,我注意到在使用它时,它会覆盖相机最初看到的任何位置。这也已被报道here 。基本上,在OrbitControls.js
的第36行(我正在使用可以找到的版本 here ) this.target
初始化为new THREE.Vector3()
;我发现,如果我手动将其设置为等于我用作 camera.lookAt()
参数的相同向量一切都工作得很好:我可以从同一个 POV 开始平移、绕轨道运行和缩放场景,如果我不应用控件,我就会看到场景。当然,我无法将这些信息硬编码到 OrbitControls.js
中。因为每次我想改变相机的初始“lookAt”时,它都需要我改变它;如果我要遵循 MrTrustworthy 的建议,我将不得不更改 OrbitControls.js
的第 36 行像这样阅读:this.target = object.targetRef
(或 this.target = object.targetRef || new THREE.Vecotr3()
),这也太“固执己见”(它总是要求 object
具有 targetRef
属性,而我试图坚持仅使用 Three.js 的现有对象属性和方法)。希望这有助于更好地了解我的案例。干杯。
最佳答案
如果您唯一的用例是“我希望能够通过相机对象访问相机目标位置”,您可以将引用放入相机对象中。
var camera = new THREE.PerspectiveCamera(45, 2, 0.1, 100);
var target = new THREE.Vector3(1, 2, 3);
camera.lookAt(target);
camera.targetRef = target;
//access it
var iNeedThisNow = camera.targetRef;
关于javascript - camera.lookAt() 的逆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26557252/
我正在试验光线行进,并且一直在关注 Jamie Wong's tutorial. 当移动相机部分来时,他们使用该功能 mat4 viewMatrix(vec3 eye, vec3 center, ve
您好,我对glm lookAt函数的返回值有疑问。当我以 Debug模式执行时,此时 glm函数的 ... Result[3][2] = dot(f, eye); ...在矩阵的平移z位置中的值错误。
我正在使用一个在我为 LWJGL 找到的名为 JOML 的开源数学库中计算的 LookAt 矩阵。在我的游戏中获得免费摄像头。它在左右旋转时效果很好,但向上和向下看似乎会导致严重的扭曲问题,类似于大幅
我正在编写 3d 引擎,并且遇到了 DirectX 文档中描述的 LookAt 算法: zaxis = normal(At - Eye) xaxis = normal(cross(Up, zaxis)
在虚幻中,我想要 在前向 vector 指向目标当前位置的位置旋转角色, 确保我的 Actor 的向上 vector 与我的目标的向上 vector 相同 在Unity3D中,它 super 简单。这
我在 OpenGL 2.0(固定管道)中构建了一个 lookAt 相机。我的相机跟踪它的位置、观察点和向上 vector 。到目前为止,我已经使用以下代码将相机偏转了一定程度: void Camera
我正在使用 Three.js 透视相机,我需要了解相机所注视的点。 如何使用相机的矩阵/旋转向量计算它? 最佳答案 相机向下看它的内部负 z 轴。所以选择相机负 z 轴上的任意点,如下所示: var
我尝试使用 Lookat 功能通过平移手势旋转相机。我使用 swift 和 Metal(在本例中 Metal 与 OpenGLES 的工作原理相同)。这是我的代码 查看功能: let kEye =
我在谷歌上进行了广泛的搜索,但我还没有找到我认为实际上很常见的情况的解决方案。假设我有一个THREE.PerspectiveCamera初始化为查看空间中的某个点: var camera = new
我正在使用 glm::lookAt 获取一个矩阵来改变世界。这工作正常,我可以生成矩阵,将其输入着色器,一切正常。我现在需要做的是通过 lookAt 矩阵转换任意 vector (即 100,100,
我目前正在尝试使用 Source SDK 在 C++ 中编写一个 LookAt 函数。我做了一些研究,发现了很多链接,但其中很多都是关于 Unity 或 Glm 的,并且使用的是四元数和旋转矩阵,但我
假设我有以下顶点着色器代码: attribute vec4 vPos; uniform mat4 MVP; uniform mat4 LookAt; void main{ gl_Positi
我一直在尝试编写一个 View 矩阵/查看矩阵,但我的代码中的某个地方有错误,我需要帮助找到它。当我使用我的函数时,我得到一个空白屏幕,而不是我应该得到的三角形的测试 View 。 public st
据我所知,“lookat”方法是在场景中放置/旋转相机的最简单方法之一。所以我在我的光线追踪代码中实现了 ( https://www.scratchapixel.com/lessons/mathema
大家好,我正在尝试做一个使用 glm 库中的 lookAt 的 Camera 类。我有 4 个点,第一个是 eye,即相机在空间中的位置,第二个是 look,即相机正在注视的点,第三个是 upp,用于
我正在努力解决以下问题。我正在处理骨骼动画,我希望(即)玩家的头部跟随空间中的另一个物体。我的上轴是 +Z 我的前轴是 +Y,四元数的大小在 W 中。我尝试使用 gluLookAt 的 mesa 代码
我需要设置场景的初始“lookAt”点,这将是屏幕和控件旋转的中心。如果可能的话,我更愿意设置一个点(或一个对象的位置),而不是旋转 Angular 。 控件是OrbitControl。如果我只是在控
我正在关注 tutorial学习 OpenGL,他们使用 glm::lookAt() 函数来构建 View ,但我无法理解 glm::lookAt() 的工作原理,显然,有没有 GLM 的详细文档。谁
在 SparkAR 中,我想要一个元素(称为 toRotate),它总是看着相机,类似于已经问过的 here (但接受的解决方案对我来说并不令人满意,我没有足够的声誉来回答它的评论)。 问题在于该元素
在 Three.js 中,我希望相机指向 3D 空间中的某个点。 为此,我尝试使用 camera.lookAt 函数,如下所示: camera.lookAt(new THREE.Vector3(-10
我是一名优秀的程序员,十分优秀!