8

我有一个从增强现实应用程序中的相机校准派生的投影矩阵,只要屏幕纵横比与相机图像纵横比匹配,一切都很好。当相机图像与屏幕边缘不匹配时,您将在跟踪中出现失真。

问题场景:

  • iPad 上的 1280x720 视频
  • iPhone 5S 上的 640x480 视频。

工作场景:

  • iPad 上的 640x480 视频
  • iPhone 5S 上的 1280x720 视频。

目标:我想以一般方式处理此屏幕/相机纵横比不匹配。

信箱格式示例

存在这个问题是因为视图在屏幕的纵横比中具有标准化的设备坐标(iPad 为 4:3),而投影矩阵具有相机图像的纵横比(720p 为 16:9)。背景图像需要与投影矩阵匹配,否则增强现实的幻觉会失败,因此如果我想在“适合”和“填充”之间切换,我需要更改投影矩阵以匹配图像大小。

注意:我希望在没有 OpenGL 特定解决方案的情况下处理这个问题。所以我正在寻找一个涉及操纵投影矩阵的更一般的数学答案。

4

2 回答 2

1

但是,我意识到我需要将相机的投影矩阵映射到屏幕投影矩阵或缩放它。

纵横比实际上只是决定了屏幕上的内容(即您获得的周边视觉量) - 它不应该从根本上改变投影(假设您保持近端和远端剪辑相同)。

首先要注意的是没有真正安全的映射(即不是屏幕视图中的每个坐标在相机视图中都有对应的,反之亦然)。

为避免失真,您实际上有两个选项 - 剪辑到两个选项中较窄的一个(丢弃信息)或使用信箱按比例缩小并保持原始纵横比(丢弃屏幕区域)。

两者都觉得应该可以将一个简单的比例因子应用于最终的剪辑空间变换(假设你在截锥体的两侧同样剪辑,你应该能够乘以你想要的轴的剪辑空间坐标剪辑(比例 > 1),或多个向下(比例 < 1),如果你想要信箱)。要使信箱工作,您需要使用 glViewport 或 glScissor 来阻止正在绘制的信箱之外的图元。

于 2015-03-07T00:39:00.427 回答
0

避免处理投影矩阵

简单的方法,虽然不如数学解决方案在智力上令人满意,但是将您的场景放置在相机图像大小的视图中。然后将该视图放在包含视图中。然后调整整个视图的大小以匹配屏幕或填充屏幕大小。

于 2015-03-18T07:24:36.203 回答