基于实时3D引擎计算角度的基本方法
2011-08-20 20:43
232 查看
最近给单位做几何算法时,突然发现单位以前做的图形核心算法,和我以前做过的算法。真的很不一样。不过如果我以前没做过计算角度的话,那么我现在肯定要花很多时间去研究几何算法。而现在是轻车熟路了。细想一下,计算角度要算一个算法领域的大门槛,自己如果不能很好的理解和运用角度知识,那么随便什么图形引擎都是用不好的。
如果你算过角度。那么我提醒一点,我指的是图形上的角度标准定义,和自己的角度标准定义,以及换算方法。
我举个例子
这是OGRE引擎的角度标准。OGRE用的是相对角度,即过+180度,以-1度重新换算。过-180度,以+1度重新换算。
这是TrueLife引擎的角度标准,TrueLife用的也是相对角度,不过TrueLife是过+180,则以-180开始。过了-1,则以+1开始。
然后介绍一下实现角度换算的基本方法和注意事项
这是我在MSVC++中基于OGRE手写的换算方法,作用是根据两个2D坐标,计算出坐标2所处的角度。写的比较简单,主要是将原理表达清楚。
//stand geometry formula
//Calculates the arctangent angle and quadrant of a given number.
long double RadiansTan(long double Y, long double X)
{
__asm
{
FLD Y
FLD X
FPATAN
FWAIT
}
}
//return high precision floating value from OGRE
long double CalcAngle(long double x1,long double y1,long double x2,long double y2)
{
//Converts radians to degrees.
return (RadiansTan(y2 - y1, x2 - x1)*(180/3.14159265358979));
}
//return high precision floating value fro TrueLife
long double CalcAngleForTrueLife(long double x1,long double y1,long double x2,long double y2)
{
//Converts radians to degrees.
return (RadiansTan(y1 - y2, x1 - x2)*(180/3.14159265358979));
}
//Calc Radians office for all engine
//_Angle=0..360
void CalcRadiansOffice(long double &x, long double &y, float _OffceLength, long double _Angle)
{
float _T = (float)(_Angle*(3.14159265358979/180));
x = x+_OffceLength * cos(_T);
y = y+_OffceLength * sin(_T);
}
Out Test//
long double x=0,y=0,t=0;
t=CalcAngle(0,0,1,2);//+63.xxxxxxx..
t=CalcAngle(0,0,1,-2);//-63.xxxxxx
t=CalcAngleForTrueLife(0,0,1,2);//-116.xxxxxxxxxx
t=CalcAngleForTrueLife(0,0,1,-2);//+116.xxxxxxxxxxxx
CalcRadiansOffice(x, y, 20, 45);
以上几个函数,相互搭配,可轻松搞定变化无穷的角度计算问题。不存在效率问题。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wangwang123654/archive/2009/12/10/4980095.aspx
如果你算过角度。那么我提醒一点,我指的是图形上的角度标准定义,和自己的角度标准定义,以及换算方法。
我举个例子
这是OGRE引擎的角度标准。OGRE用的是相对角度,即过+180度,以-1度重新换算。过-180度,以+1度重新换算。
这是TrueLife引擎的角度标准,TrueLife用的也是相对角度,不过TrueLife是过+180,则以-180开始。过了-1,则以+1开始。
然后介绍一下实现角度换算的基本方法和注意事项
这是我在MSVC++中基于OGRE手写的换算方法,作用是根据两个2D坐标,计算出坐标2所处的角度。写的比较简单,主要是将原理表达清楚。
//stand geometry formula
//Calculates the arctangent angle and quadrant of a given number.
long double RadiansTan(long double Y, long double X)
{
__asm
{
FLD Y
FLD X
FPATAN
FWAIT
}
}
//return high precision floating value from OGRE
long double CalcAngle(long double x1,long double y1,long double x2,long double y2)
{
//Converts radians to degrees.
return (RadiansTan(y2 - y1, x2 - x1)*(180/3.14159265358979));
}
//return high precision floating value fro TrueLife
long double CalcAngleForTrueLife(long double x1,long double y1,long double x2,long double y2)
{
//Converts radians to degrees.
return (RadiansTan(y1 - y2, x1 - x2)*(180/3.14159265358979));
}
//Calc Radians office for all engine
//_Angle=0..360
void CalcRadiansOffice(long double &x, long double &y, float _OffceLength, long double _Angle)
{
float _T = (float)(_Angle*(3.14159265358979/180));
x = x+_OffceLength * cos(_T);
y = y+_OffceLength * sin(_T);
}
Out Test//
long double x=0,y=0,t=0;
t=CalcAngle(0,0,1,2);//+63.xxxxxxx..
t=CalcAngle(0,0,1,-2);//-63.xxxxxx
t=CalcAngleForTrueLife(0,0,1,2);//-116.xxxxxxxxxx
t=CalcAngleForTrueLife(0,0,1,-2);//+116.xxxxxxxxxxxx
CalcRadiansOffice(x, y, 20, 45);
以上几个函数,相互搭配,可轻松搞定变化无穷的角度计算问题。不存在效率问题。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wangwang123654/archive/2009/12/10/4980095.aspx
相关文章推荐
- 基于实时3D引擎计算角度的基本方法
- 基于实时3D引擎计算角度的基本方法
- 基于全表扫描计算总体成本cost方法
- RDD论文翻译 --弹性分布式数据集:一种基于内存的集群计算的容错性抽象方法
- 基于距离的计算方法
- 基于Spark机器学习和实时流计算的智能推荐系统
- 肖康-基于Storm利用空闲资源构建实时计算平台
- 基于xmpp实现android端实现即时通讯---asmack基本方法(三)
- Spark构建推荐引擎之二:基于Spark Streaming 实时推荐计算
- 向量的计算和基本方法
- ArcGIS基于DEM计算水流方向的方法(D8算法)
- RDD(转):一种基于内存的集群计算的容错性抽象方法(二)
- 数据块内部偏移量的基本计算方法
- PCA 分解的基本推导和计算方法
- 基于sklearn 的auc 计算方法
- 基于Spark机器学习和实时流计算的智能推荐系统
- javacpp-opencv图像处理3:使用opencv原生方法遍历摄像头设备及调用(增加实时帧率计算方法)
- 基于Spark实时计算商品关注度
- 实用计算机视觉 -- 一种基于直方图的最优阈值计算方法
- 《神经网络和深度学习》系列文章十:[热身]一个基于矩阵的快速计算神经网络输出的方法