根据卫星的方位角和仰角画卫星星空图(QT实现)

Posted haoming Hu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了根据卫星的方位角和仰角画卫星星空图(QT实现)相关的知识,希望对你有一定的参考价值。

作者:haomingHu
email:hhm_master@163.com

需求:在0183格式中,根据GNGSV中的卫星仰角和方位角去绘制卫星星空图

如图:

目标:实现一个卫星的映射

名词解释:

方位角:从标准方向的北端起,顺时针方向到直线的水平角称为该直线的方位角。方位角的取值范围为0°~360°。,就是卫星相 对于测量点的方向,正北方向为0 度,顺时针递增。

仰角: 视线在水平线以上时,在视线所在的垂直平面内,视线与水平线所成的角叫做仰角.就是在地平面上,要抬头多少度,才能望到卫星,水平方向为 0 度,头顶的垂直方向为 90 度。

elevation:仰角 、(0-90)azimuth:方位角(0-360)

先用QT画一个圆环

代码如下:

 painter.translate(180,180);//坐标变换  //y轴向下边为正方向
      painter.setRenderHint(QPainter::Antialiasing, true);

      painter.setPen(QPen(QColor("#98F5FF"), 2));
      painter.setBrush(QColor(	255 ,250 ,250));
      painter.drawEllipse(QPointF(0, 0), 180, 180);

      painter.setPen(QPen(QColor("#76EEC6"), 2));
      painter.setBrush(QColor(	255 ,250 ,250));
      painter.drawEllipse(QPointF(0, 0), 120, 120);

      painter.setPen(QPen(QColor("#FFE4B5"), 2));
      painter.setBrush(QColor(	255 ,250 ,250));
      painter.drawEllipse(QPointF(0, 0), 60, 60);

      painter.setPen(QPen(QColor("#696969"), 3));
      painter.drawLine(QPointF(0, 180), QPointF(0,-180));
      painter.drawLine(QPointF(-180,0), QPointF(180,0));

这里需要注意,一定要将坐标原点搬到圆心,否则等下画的卫星就不正确了。坐标平移使用到的函数是:translate
参数为原来坐标系统的圆心坐标,而且平移之后y轴的正方向向下

现在给定参数:

      int elevation =35;
      int azimuth =33;

计算过程:

      int elevation =35;
      int azimuth =33;
      int cosLen = cos(elevation*3.141592/180)*180;
      int y = cos(azimuth*3.141592/180)*cosLen;
      int x = sin(azimuth*3.141592/180)*cosLen;

      qDebug()<< x<<y<<cosLen;
      painter.setPen(QPen(QColor("#FF0000"), 2));
      painter.setBrush(QColor("#FFFAFA"));
      painter.drawEllipse(QPointF(x,-y),10,10);

      painter.setBrush(QColor(255,48,48));
      painter.drawText(QPointF(x-9,-y+5),"13");

最终效果:

计算过程解释:
int elevation =35;
int azimuth =33;
int cosLen = cos(elevation*3.141592/180)180;
int y = cos(azimuth
3.141592/180)cosLen;
int x = sin(azimuth
3.141592/180)*cosLen;

  int cosLen = cos(elevation*3.141592/180)*180;  这个是使用仰角计算卫星投射到X-Y平面的点,距离远点的距离

int y = cos(azimuth*3.141592/180)cosLen;
int x = sin(azimuth
3.141592/180)*cosLen;
这两个则是用这个距离分别计算投影到X-Y轴的距离。

首先假设空间中的卫星和三维坐标系的原点组成一个向量,方位角可以理解为先将这个向量投影到X-Y面,然后得到的新向量与Y轴的夹角,因为三维坐标系绕着X轴转到90°,Z轴和Y轴是重合,所以就可以用正余弦关系计算出最终的二维平面坐标

以上是关于根据卫星的方位角和仰角画卫星星空图(QT实现)的主要内容,如果未能解决你的问题,请参考以下文章

Android GNSS 可视卫星星空图/卫星天顶图 原理及画法介绍

Android GNSS 可视卫星星空图/卫星天顶图 原理及画法介绍

Android GNSS 可视卫星星空图/卫星天顶图 原理及画法介绍

如何从距离、方位角和仰角获取 3D 坐标

MAtlab中view函数具体怎么用

从北斗到Mate 50:星空中的中国式浪漫