立体视觉基于OpenGL的立体图像对的软件实现方法.doc

立体视觉基于OpenGL的立体图像对的软件实现方法.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
立体视觉基于OpenGL的立体图像对的软件实现方法

立体视觉:基于OpenGL的立体图像对的软件实现方法 1、3D驱动原理与GL_STEREO ?????? 如果要让3D显示卡提供立体显示,则必须有两方面的技术:一是立体驱动,二是3D液晶快门。其中,立体驱动为显示驱动部份,能将Direct 3D(或OpenGL)相容的应用软件,由平面显示即时转化为立体显示,从表面上我们所看到的现象,就是普通显示变成了双影显示,这样双影显示就包含了左右眼各自的图象显示与显示器上;3D液晶快门则是一种高速的电子液晶快门,可根据显示立体驱动发出的信号同步调整开关,达到分离显示器上显示的左右眼图像,即时的送给左右眼睛,这样,我们所看到的显示器的双影显示就会变成立体显示。当然,这双影图像必须有在一定的角度上的偏差,而角度通过预设值来调整。 ?????? 通常,立体驱动将所产生的左右图像以交错格式、上下格式及换页格式三种方式储存在显示卡的内存中。交错格式是将左右图像各别抽取一半之后,再交错合成一张同样分辨率的影像。上下格式则将左右图像各别抽取一半压缩后,合成存入一张具有上下格式的图像。换页格式:则不作任何处理,将左右图像以原有的分辨率,分别独立存储在内存中。这三种格式以换页格式的图像质量最好。目前我们采用的是换页格式,也就是换页扫瞄模式,将左右图像交替扫瞄于显示器的屏幕,也就是先扫瞄左眼图像,再扫描右眼图像。如此不断地重复,因其扫描速度够快(如100Hz),加上人眼的视觉暂留现象,会让人感觉是同时显示在屏幕上,此时,利用显示卡发生连续的同步信号给3D液晶快门眼镜,也就是说,当显示左眼图像时,3D液晶眼镜左镜片开通,右眼镜片关闭:当显示右眼图像时,3D液晶眼镜的右镜片开通,左眼镜片关闭,如此反复,左右眼就各自看到自己的图像,而在大脑中形成立体影像。 ?????? 实时渲染三维数据,即把三维数据转换为屏幕上可显示的数据时,一般采用 OpenGL 或 DirectX 应用程序接口函数库。在 OpenGL 应用程序接口中,专门提供了渲染多视角的 Quad-Buffered Stereo(四方体立体缓存)函数,而专业的 OpenGL 显卡对 Quad-Buffered 提供硬件上的支持。例如 NVidia Quadro、ATI-Fire GL、3Dlabs Wildcat 工作??显卡。如果需要立体显示,可以在显卡的驱动的高级选项设置中启用Stereo 选项并根据相关硬件做适当调整或者交换左右眼等。 ?????? 在OpenGL了中必须先使用GL_STEREO进行宏测试显卡是否支持stereo。 2、Toe-in Method(correct) ?????? 使用这种方法时,相机是一个固定并且是产生对称的平截体,每个相机指向单一的焦距。使用Toe-in创建的图像是一个具有垂直视差的立体感,并且会产生不合适的水平增量。这种垂直视差增量会随着相机张角的增大而跳出偏移投影平面的中心。 ??? ?????? Toe-in是一种不正确的方法,但它仍然用得很多,因为它采用移动相机法并且非常容易的使用平行相机产生两个图像对。 ?????? Toe-in在OpenGL中采用gluPerspective()函数进行透视投影,左右相机位于不同位置但都是指向同一个焦点的。部分代码如下: glMatrixMode(GL_PROJECTION); // 设置投影模式 glLoadIdentity(); // 设置透视投影,相机张角,投影纵横比,最近和最远处 gluPerspective(camera.aperture,screenwidth/(double)screenheight,0.1,10000.0); if (stereo) { ????? CROSSPROD(camera.vd,camera.vu,right); ????? Normalise(right); // 获得单位矢量 ???????? // 计算相机偏移量(包括方向) ????? right.x *= camera.eyesep / 2.0; ????? right.y *= camera.eyesep / 2.0; ????? right.z *= camera.eyesep / 2.0; ????? glMatrixMode(GL_MODELVIEW); ???????? // 左右缓冲模式 ????? glDrawBuffer(GL_BACK_RIGHT); ????? glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); ????? glLoadIdentity(); ???????? // 设置相机,右眼位置为vp+right,指向焦点,方向vu ????? gluLookAt(camera.vp.x +

文档评论(0)

2017ll + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档