• 【转载】OGRE之坐标系、向量与转换


     坐标与向量:

    OGRE跟其它的图形引擎一样使用x,z来表示水平平面, 用y来表示垂直方向.面对你的显示器,x轴是从左到右,右边是

    正方向;y轴是从下到上,上方是正方向;z轴是从里向外,外面是正方向. OGRE是用向量类来表示位置跟方向

    的,Vector2,Vector3,Vector4是OGRE中定义的三种向量,然而我们最常使用的是Vector3.

    void setDirection(x, y, z); 设定方向
    Vector3 getDirection(); 获得方向
    Vector3 getUp(); 获得向上的向量
    Vector3 getRight();获得向右的向量
    void lookAt(x, y, z); 朝向某一点
    void yaw(Real yaw); void roll( Real roll), void pitch(Real pitch);
    void rotate(Vector3 &axis, Real degree);
    void setAutoTracking(bool bEnabled, SceneNode *target = 0, const Vector3 &offset);

    const Matrix& getProjectionMatrixRS() const;   //RS表示RenderSystem,该函数将根据当前的渲染系统来决定

    返回的投影矩阵(左手或右手坐标系).
    const Matrix& getProjectionMatrixWithRSDepth() const;// 这个将返回ogre本地格式的矩阵(右手坐标系的).
    但它的深度格式根据当前渲染系统决定深度范围是(-1,1)或者是(0,1).
    const Matrix& getProjectionMatrix() const; //这个不仅返回是ogre本地格式的矩阵(右手坐标系的),而且还保

    证深度范围(-1,1). {没有RS,不受渲染系统影响...}

    const Matrix& getViewMatrix() const;

    因为支持多视口渲染(view port),OGRE为多视口维护了Z-ORDER, 根据Z-ORDER的不同来决定对相覆盖的视口的遮挡.

    需要注意的是,即使被遮挡的部分每帧也是被渲染的,应考虑其代价.
    Viewport *vpFront, *vpBack;
    vpBack= window->addViewport(camera, 0); //默认为整个客户区大小
    vpFront = window->addViewport(camera, 1, 0.0, 0.0, 0.5, 0.5); //左上角四分之一大小,叠在vpFront前面.

    vpBack->setBackgroundColour(ColourValue(1.0f, 0.0f, 0.0));
    vpFront->setBackgroundColour(ColourValue::Red));

    //设置每帧是否自动清除缓冲
    vpBack->setClearEveryFrame(true, FBT_COLOUR | FBT_DEPTH);
    vpFront->setClearEveryFrame(false);

     

     

    OGRE的2D坐标、CEGUI坐标、鼠标坐标

     

    屏幕坐标系:左上角为(0, 0)右下角为(1, 1)

    OGRE的2D坐标系:左上角为(-1, 1)右下角为(1, -1)

    CEGUI坐标系:左上角为(0, 0),单位像素

     

    转换公式(鼠标坐标=>OGRE的2D坐标)

    void setCorners(float left, float top, float right, float bottom)

    {

        left = left * 2 - 1;
        right = right * 2 - 1;
        top = 1 - top * 2;
        bottom = 1 - bottom * 2;
    }

     

    对于根据鼠标位置来产生射线:

    bool mousePressed(const OIS::MouseEvent &arg, OIS::MouseButtonID id)

    {

    ...

        CEGUI::Point mousePos = CEGUI::MouseCursor::getSingleton().getPosition();
        Ray mouseRay = mCamera->getCameraToViewportRay(mousePos.d_x/float(arg.state.width), mousePos.d_y/float(arg.state.height));

    ...
    }

    其中函数

    Ray getCameraToViewportRay(Real x, Real y) const;

    // x and y are in “normalized” (0.0 to 1.0) screen coordinates

    其中两个参数是对屏幕坐标系来说的,

    所以

    x = mousePos.d_x / float(arg.state.width)

    y = mousePos.d_y / float(arg.state.height)

     

    arg.state.width是渲染窗口的宽单位为像素

    arg.state.height是渲染窗口的高单位为像素

    mousePos.d_x是鼠标所在位置到渲染窗口左边界的距离单位为像素

    mousePos.d_y是鼠标所在位置到渲染窗口上边界的距离单位为像素

    http://blog.csdn.net/kamaliang/article/details/3959282 
  • 相关阅读:
    使用 Apache MINA 开发高性能网络应用程序
    工商银行网上支付接口PHP的demo(原创) 发送篇
    netty服务器和跨域访问
    网站集成支付宝接口
    [翻译]C#数据结构与算法 – 第五章栈与队列(Part 2)
    基于ArcGIS10.0和Oracle10g的空间数据管理平台(C#开发)ArcGIS_Engine中的数据访问
    基于ArcGIS10.0和Oracle10g的空间数据管理平台(C#开发)项目中专业名称介绍
    基于ArcGIS10.0和Oracle10g的空间数据管理平台八(C#开发)图层分类标准定义
    基于ArcGIS10.0和Oracle10g的空间数据管理平台(C#开发)背景介绍
    基于ArcGIS10.0和Oracle10g的空间数据管理平台九(C#开发)空间数据导入RDBMS上Shape格式
  • 原文地址:https://www.cnblogs.com/ylwn817/p/2437457.html
Copyright © 2020-2023  润新知