当前位置: 首页 > news >正文

太原网站优化公司福彩网站开发

太原网站优化公司,福彩网站开发,吉林省建设安全信息网官网,做论坛推广的网站overoad代码中包含一段有意思的代码#xff0c;可以从视图投影矩阵逆推出摄像机的视锥体#xff0c;本文来分析一下原理 一、平面的方程 视锥体是用平面来表示的#xff0c;所以先看看平面的数学表达。 平面方程可以由其法线N#xff08;A, B, C#xff09;和一个点Q(x0,… overoad代码中包含一段有意思的代码可以从视图投影矩阵逆推出摄像机的视锥体本文来分析一下原理 一、平面的方程 视锥体是用平面来表示的所以先看看平面的数学表达。 平面方程可以由其法线NA, B, C和一个点Q(x0,y0,z0)定义其形式为 A ( x − x 0 ) B ( y − y 0 ) C ( z − z 0 ) 0 A(x-x_{0})B(y-y_{0})C(z-z_{0})0 A(x−x0​)B(y−y0​)C(z−z0​)0          整理变为 A x B y C z D 0 AxByCzD0 AxByCzD0,       其中 D − A x 0 − B y 0 − C z 0 D−Ax_{0}−By_{0}−Cz_{0} D−Ax0​−By0​−Cz0​          方程进一步可以将方程归一化 A A 2 B 2 C 2 x B A 2 B 2 C 2 y C A 2 B 2 C 2 z D A 2 B 2 C 2 0 \frac{A}{\sqrt{A^{2}B^{2}C^{2} } } x \frac{B}{\sqrt{A^{2}B^{2}C^{2} } }y\frac{C}{\sqrt{A^{2}B^{2}C^{2} } }z\frac{D}{\sqrt{A^{2}B^{2}C^{2} } } 0 A2B2C2 ​A​xA2B2C2 ​B​yA2B2C2 ​C​zA2B2C2 ​D​0 写成通用格式 a x b y c z d 0 axbyczd0 axbyczd0 那么点 p ( x 1 , y 1 , z 1 ) p(x_{1}, y_{1}, z_{1}) p(x1​,y1​,z1​)到平面的距离为 D a x 1 b y 1 c z 1 d Dax_{1}by_{1}cz_{1}d Dax1​by1​cz1​d 一个平面会将空间分成两个半空间halfspace进一步法线的朝向的空间称为正半空间positive halfspace法线背离的空间称为反半空间negative halfspace。根据D的符号可以判断点的相对位置 D 0 点位于反半空间D 0 点位于平面上D 0 点位于正半空间 这种特性可用于判断点是否在视锥体内部。 二、OpenGL视锥体 视锥体是摄像机能看到的区域只有在视锥体内的物体才能被看到。其由近平面near、远平面far与周围四个面top、bottom、left、right组成形成一个平截头体区域。 不过在构建视锥体时一般不直接输入6个平面的方程常用另外一组更直观易懂的参数 fov – 视锥体的垂直张角Near – 视锥体的近平面距离Far – 视锥体的远平面距离aspect – 相机视口的长宽比 具体含义建下图 三、Overload对视锥体的封装 Overload对视锥体的封装在文件Frustum.h、Frustum.cpp中。先看其定义 class Frustum { public:/*** 根据视图投影矩阵提取视锥体* param p_viewProjection*/ void CalculateFrustum(const OvMaths::FMatrix4 _viewProjection);/*** 判断点是不是在视锥体内* param p_x* param p_y* param p_z*/bool PointInFrustum(float p_x, float p_y, float _z) const;/*** 判断球是不是在视锥体内* param p_x* param p_y* param p_z* param p_radius*/bool SphereInFrustum(float p_x, float p_y, loat p_z, float p_radius) const;/*** 判断立方体是不是在视锥体内* param p_x* param p_y* param p_z* param p_size*/bool CubeInFrustum(float p_x, float p_y, float _z, float p_size) const;/*** 判断包围球是不是在视锥体内* param p_boundingSphere* param p_transform*/bool BoundingSphereInFrustum(const vRendering::Geometry::BoundingSphere _boundingSphere, const OvMaths::FTransform _transform) const;/*** 返回近平面*/std::arrayfloat, 4 GetNearPlane() const;/*** 返回远平面*/std::arrayfloat, 4 GetFarPlane() const; private:float m_frustum[6][4]; // 6个平面的方程参数 };m_frustum保存着6个平面的方程参数为了提升操作便利性其定义了两个枚举作为索引 enum FrustumSide {RIGHT 0, // The RIGHT side of the frustumLEFT 1, // The LEFT side of the frustumBOTTOM 2, // The BOTTOM side of the frustumTOP 3, // The TOP side of the frustumBACK 4, // The BACK side of the frustumFRONT 5 // The FRONT side of the frustum };// 平面方程的参数索引 enum PlaneData {A 0, // The X value of the planes normalB 1, // The Y value of the planes normalC 2, // The Z value of the planes normalD 3 // The distance the plane is from the origin };函数的具体实现在文件Frustum.cpp中我们先看最基础的判断点是否在视锥体内 bool OvRendering::Data::Frustum::PointInFrustum(float x, float y, float z) const {for (int i 0; i 6; i){if (m_frustum[i][A] * x m_frustum[i][B] * y m_frustum[i][C] * z m_frustum[i][D] 0){return false;}}return true; }定义视锥体的面法线都是朝外的如果点在视锥体内点到6个面的距离必须全部小于0。进一步判断球体是否完全在视锥体内距离必须小于半径的负数。 最后分析一下CalculateFrustum它是根据一个视图投影矩阵反向构建一个视锥体具体公式怎么来的可以参考这篇文章里面将的特别详细 Fast Extraction of Viewing Frustum Planes from the World View-Projection Matrix   其本身的代码没啥好说的无非就是公式的翻译。
http://www.zqtcl.cn/news/492140/

相关文章:

  • 自己做企业网站在哪学习建网站
  • 门户网站建设 突出服务学习电子商务网站建设与管理的收获
  • 做网站排名大概要多少免费做个人网站
  • 哈尔滨网站建设效果wordpress主题 手机app
  • 收录网站源码海外域名怎么打开
  • 荥阳网站建设上海十大营销策划公司
  • 在网站挂广告一个月多少钱巫溪网站建设
  • 网站备案名称的影响吗济南网站建设招聘
  • 南城区网站建设公司y2学年做的租房网站
  • 温州网站建设咨询网站源码下载后怎么布置
  • 邢台网站推广wordpress文章数据库位置
  • wordpress 快站wordpress 安装主题 主机名
  • 老网站改版启用二级域名网站建设服务是什么意思
  • 网站建设营销话术外销网站
  • 找个人给我做电影网站好主题网站开发介绍
  • 运城公司网站建设苏州网站建设苏州
  • 湖北省住房和建设厅网站首页网站用免费空间好不好
  • 网站建设公司案例做网站小图标大全
  • 美食网站主页怎么做网络营销推广的作用
  • 上海建站价格wordpress表白系统
  • 唐山 建设工程信息网站中天钢铁 网站建设
  • 公司没有备案了网站摄影素材网站
  • 正规的网店平台有哪些北京公司排名seo
  • 网页制作素材库哪个网站上海门户网站开发
  • 做网站 分辨率应该是多少做阿里巴巴网站要多少钱
  • 有专业做外贸的网站吗千岛湖网站建设
  • 百度怎么做开锁网站中国咖啡网站建设方案
  • 新网站不被收录郑州网站建设培训学校
  • 网站群建设意见征集北京做网站报价
  • 网站建设开发费会计处理山东省住房和城乡建设厅二建查询