zoukankan      html  css  js  c++  java
  • Opengl坐标转换

    有时候我们需要手动计算三维点对应的二维坐标,下面的矩阵公式就是模拟了一遍三维图形的流程。这里已假设读者具备了图形学的基础知识,比如矩阵乘法代表的三维变换,放射变换;还有齐次坐标等。

    这里不考虑模型自身的旋转平移缩放等,即假设模型三维坐标已知。有坐标:

    image

    模型视图变换矩阵:

    void APIENTRY gluLookAt (

    GLdouble eyex,

    GLdouble eyey,

    GLdouble eyez,

    GLdouble centerx,

    GLdouble centery,

    GLdouble centerz,

    GLdouble upx,

    GLdouble upy,

    GLdouble upz);

    这个矩阵可以参考OpenGL的官网:http://www.opengl.org/sdk/docs/man2/

    最好用IE或者firefox打开,chrome无法打开公式插件。

    这里列出几点需要注意的,官网上没有注意。

    clip_image002

    这是官网上的截图,其中image表示2-范数。另外向量su均需要像fUP一样用2-范数作为商归一化。最终计算一个矩阵,这里热身一下,给出所有推导过程:

    image

    image

    一点理解:f表示视线向量,UP’’表示摄影机朝向的向量,但是可以知道,如果视线向量定了,其实摄影机的角度也就定了,但是摄影机可以绕着以视线方向作为轴进行旋转,所以UP’’向量就是为了固定摄像机用的。其中叉积有这样的一个性质:

    image

    所以如果fUP’’如果是垂直的,那么就不需要进行归一化了,因为fUP’’的长度均为1,他们如果垂直,叉积的长度也为1。但是我们编程中经常使用沿着笛卡尔坐标轴的向量表示摄影机的朝向,所以这里还是需要进行归一化的。s归一化后,sf是垂直的,所以u并不需要再归一化。

    image

    在实际情况中,我们总是往简单的方向设定:

    image

    image

    并且有

    image

    那么

    image

    再归一化s’

    image

    因此

    image

    最终矩阵:

    image

    投影矩阵:

    void APIENTRY gluPerspective (

    GLdouble fovy,

    GLdouble aspect,

    GLdouble zNear,

    GLdouble zFar);

    同样,可以参考官网上API:http://www.opengl.org/sdk/docs/man2/

    clip_image001

    视口变换矩阵:

    WINGDIAPI void APIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height);

    image

    可以把上式写成矩阵的形式。

    三维坐标经过上诉三个变换,即可变换成为最终二位坐标点。最后仍需注意的是,变换后的坐标原点为窗口左下角,一般图像处理时均是左上角为原点,对Y坐标进行一次变换即可。

    Y’=Height-Y

  • 相关阅读:
    CodeForces 347B Fixed Points (水题)
    CodeForces 347A Difference Row (水题)
    CodeForces 346A Alice and Bob (数学最大公约数)
    CodeForces 474C Captain Marmot (数学,旋转,暴力)
    CodeForces 474B Worms (水题,二分)
    CodeForces 474A Keyboard (水题)
    压力测试学习(一)
    算法学习(一)五个常用算法概念了解
    C#语言规范
    异常System.Threading.Thread.AbortInternal
  • 原文地址:https://www.cnblogs.com/lvfq/p/3453105.html
Copyright © 2011-2022 走看看