/*******************************************************************************
|
* File Name : GPS.h
|
* Description :
|
* Created on : 2019��3��11��
|
* Author : www.hido-studio.com
|
*******************************************************************************/
|
#ifndef _GPS_H_
|
#define _GPS_H_
|
|
/*******************************************************************************
|
* Include Files *
|
*******************************************************************************/
|
#include "HIDO_TypeDef.h"
|
#include "GPIO.h"
|
|
/*******************************************************************************
|
* Macro *
|
*******************************************************************************/
|
/* IM23A NAVI 数据 STATUS 状态字定义 */
|
#define IM23A_STATUS_FINIT (0x00000001U) // 1 滤波器未初始化标志
|
#define IM23A_STATUS_READY (0x00000002U) // 2 滤波器收敛完成标志
|
#define IM23A_STATUS_INACCURATE (0x00000004U) // 3 滤波器收敛过程中
|
#define IM23A_STATUS_TILT_REJECT (0x00000008U) // 4 倾角过大标志位
|
#define IM23A_STATUS_GNSS_REJECT (0x00000010U) // 5 GNSS 定位数据差标志位
|
#define IM23A_STATUS_FRESET (0x00000020U) // 6 滤波器重置标志位
|
#define IM23A_STATUS_FIX_RLS1 (0x00000040U) // 7 倾斜测量安装角估计阶段 1
|
#define IM23A_STATUS_FIX_RLS2 (0x00000080U) // 8 倾斜测量安装角估计阶段 2
|
#define IM23A_STATUS_FIX_RLS3 (0x00000100U) // 9 倾斜测量安装角估计阶段 3
|
#define IM23A_STATUS_FIX_RLS4 (0x00000200U) // 10 倾斜测量安装角估计阶段 4
|
#define IM23A_STATUS_FIX_RLS_OK (0x00000400U) // 11 倾斜测量安装角估计完成
|
#define IM23A_STATUS_DIR1 (0x00002000U) // 12 初始化晃动方向 1
|
#define IM23A_STATUS_DIR2 (0x00004000U) // 13 初始化晃动方向 2
|
#define IM23A_STATUS_GNSS_LOST (0x00010000U) // 14 滤波器判定 GNSS 数据无效
|
#define IM23A_STATUS_FINIT_OK (0x00020000U) // 15 初始化完成标志
|
#define IM23A_STATUS_PPS_READY (0x00040000U) // 16 收到 PPS 信号
|
#define IM23A_STATUS_SYNC_READY (0x00080000U) // 17 模块时间同步成功
|
#define IM23A_STATUS_GNSS_CONNECT (0x00100000U) // 18 模块解析到 RTK 数据
|
|
/*******************************************************************************
|
* Type Definition *
|
*******************************************************************************/
|
typedef enum
|
{
|
GPS_STATE_INVALID = 0,
|
GPS_STATE_VALID,
|
} E_GPSState;
|
|
typedef enum
|
{
|
GPS_LAT_SIGN_NORTH = 0,
|
GPS_LAT_SIGN_SOUTH,
|
} E_GPSLatSign;
|
|
typedef enum
|
{
|
GPS_LON_SIGN_EAST = 0,
|
GPS_LON_SIGN_WEST,
|
} E_GPSLonSign;
|
|
typedef enum
|
{
|
GPS_PIN_REST,
|
GPS_PIN_EN,
|
|
GPS_PIN_LAST,
|
} E_GPSPin;
|
|
typedef struct
|
{
|
HIDO_UINT16 m_u16Speed;
|
HIDO_UINT16 m_u16Dir; //direction
|
HIDO_DOUBLE m_dLat; //latitude
|
HIDO_DOUBLE m_dLon; //longitude
|
E_GPSState m_eState;
|
HIDO_UINT16 m_u16Year;
|
HIDO_UINT8 m_u8Mon; //month
|
HIDO_UINT8 m_u8Day;
|
HIDO_UINT8 m_u8Hour;
|
HIDO_UINT8 m_u8Min; //minute
|
HIDO_UINT8 m_u8Sec; //second
|
}ST_GPS;
|
|
/* GPRMI数据包结构 */
|
typedef struct
|
{
|
HIDO_UINT32 m_u32UTCTime; // <1> UTC时间, hhmmss.ss格式 (centisecond)
|
HIDO_UINT16 m_u16WeekNumber; // <2> 周数 (IM23A无此字段, 默认0)
|
HIDO_UINT32 m_u32TimeOfWeek; // <3> 周内秒 (IM23A无此字段, 默认0)
|
HIDO_DOUBLE m_dLatitude; // <4> 纬度(°), 正数为北纬
|
HIDO_DOUBLE m_dLongitude; // <5> 经度(°), 正数为东经
|
HIDO_FLOAT m_fAltitude; // <6> 高程(m)
|
HIDO_FLOAT m_fLatStdDev; // <7> 纬度标准差(m) / 预留
|
HIDO_FLOAT m_fLonStdDev; // <8> 经度标准差(m) / 预留
|
HIDO_FLOAT m_fAltStdDev; // <9> 高程标准差(m) / 预留
|
HIDO_FLOAT m_fEastVelocity; // <10> 东方向速度(m/s)
|
HIDO_FLOAT m_fNorthVelocity; // <11> 北方向速度(m/s)
|
HIDO_FLOAT m_fUpVelocity; // <12> 天顶方向速度(m/s)
|
HIDO_FLOAT m_fHorizontalVelStdDev; // <13> 定位精度(来自IM23A字段11)
|
HIDO_FLOAT m_fHeadingAngle; // <14> 航向角(°) [IM23A原始为弧度,已转换为0-360°]
|
HIDO_FLOAT m_fPitchAngle; // <15> 俯仰角(°) [IM23A原始为弧度,已转换]
|
HIDO_FLOAT m_fRollAngle; // <16> 横滚角(°) [IM23A原始为弧度,已转换]
|
HIDO_FLOAT m_fHeadingAngleStdDev; // <17> 航向角标准差(°) / 预留
|
HIDO_FLOAT m_fPitchAngleStdDev; // <18> 俯仰角标准差(°) / 预留
|
HIDO_FLOAT m_fRollAngleStdDev; // <19> 横滚角标准差(°) / 预留
|
HIDO_FLOAT m_fBaselineDistance; // <20> 基线距离(m) / 预留
|
HIDO_UINT8 m_u8SatelliteCount; // <21> 卫星数量(如协议缺省则返回0)
|
HIDO_UINT8 m_u8FixedAmbiguityCount; // <22> 载波整周固定观测量个数(默认0)
|
HIDO_UINT8 m_u8PositionQuality; // <23> 定位质量指示(来自状态字低8位)
|
HIDO_BOOL m_bValid; // 数据有效标志
|
|
/* IM23A扩展字段 */
|
HIDO_FLOAT m_fAccelBiasX; // 加速度计 X 零偏
|
HIDO_FLOAT m_fAccelBiasY; // 加速度计 Y 零偏
|
HIDO_FLOAT m_fAccelBiasZ; // 加速度计 Z 零偏
|
HIDO_FLOAT m_fGyroBiasX; // 陀螺仪 X 零偏
|
HIDO_FLOAT m_fGyroBiasY; // 陀螺仪 Y 零偏
|
HIDO_FLOAT m_fGyroBiasZ; // 陀螺仪 Z 零偏
|
HIDO_FLOAT m_fImuTemperature; // 传感器温度(°C)
|
HIDO_UINT32 m_u32StatusFlags; // 状态字段(参见IM23A_STATUS_xxx宏定义)
|
}ST_GPRMI;
|
|
/* GPIMU数据包结构 */
|
typedef struct
|
{
|
HIDO_UINT32 m_u32UTCTime; // <1> UTC时间, hhmmss.sss格式
|
HIDO_FLOAT m_fAccelX; // <2> x轴加速度(g)
|
HIDO_FLOAT m_fAccelY; // <3> y轴加速度(g)
|
HIDO_FLOAT m_fAccelZ; // <4> z轴加速度(g)
|
HIDO_FLOAT m_fGyroX; // <5> 陀螺x轴角速度(°/s)
|
HIDO_FLOAT m_fGyroY; // <6> 陀螺y轴角速度(°/s)
|
HIDO_FLOAT m_fGyroZ; // <7> 陀螺z轴角速度(°/s)
|
HIDO_FLOAT m_fTemperature; // <8> 传感器温度(℃)
|
HIDO_UINT8 m_u8Checksum; // <9> 异或校验和
|
HIDO_BOOL m_bValid; // 数据有效标志
|
}ST_GPIMU;
|
|
/* GPGIG数据包结构 (fmig报文,包含位置信息、解状态和差分龄期) */
|
typedef struct
|
{
|
HIDO_UINT32 m_u32UTCTime; // UTC时间
|
HIDO_DOUBLE m_dLatitude; // 纬度(°), 正数为北纬
|
HIDO_DOUBLE m_dLongitude; // 经度(°), 正数为东经
|
HIDO_UINT8 m_u8SatelliteCount; // 卫星数量
|
HIDO_UINT8 m_u8SolutionStatus; // 解状态 (0=无效, 1=单点, 2=伪距差分, 4=RTK固定解, 5=RTK浮点解)
|
HIDO_UINT8 m_u8DifferentialAge; // 差分龄期(秒)
|
HIDO_FLOAT m_fHRMS; // 水平精度HRMS
|
HIDO_FLOAT m_fVRMS; // 垂直精度VRMS
|
HIDO_FLOAT m_fHDOP; // 水平精度因子
|
HIDO_FLOAT m_fVDOP; // 垂直精度因子
|
HIDO_BOOL m_bValid; // 数据有效标志
|
}ST_GPGIG;
|
|
/*******************************************************************************
|
* Global Function *
|
*******************************************************************************/
|
|
/*******************************************************************************
|
* Function Name : GPS_GetState
|
* Description : ��ȡGPS��λ״̬
|
* Input : None
|
* Output : None
|
* Return : ��λ״̬ 0 1 2 3
|
* Author : www.hido-studio.com
|
* Modified Date: : 2021��1��8��
|
*******************************************************************************/
|
HIDO_UINT8 GPS_GetState(HIDO_VOID);
|
|
/*******************************************************************************
|
* Function Name : GPS_PinRegister
|
* Description : GPSģ��ܽ�ע��
|
* Input : _ePin �ܽŶ���
|
* : _pstGPIOx GPIOx
|
* : _u16GPIOPin GPIO_PIN_x
|
* Output : None
|
* Return : None
|
* Author : www.hido-studio.com
|
* Modified Date: : 2021��1��8��
|
*******************************************************************************/
|
HIDO_VOID GPS_PinRegister(E_GPSPin _ePin, GPIO_TypeDef *_pstGPIOx, HIDO_UINT16 _u16GPIOPin);
|
|
/*******************************************************************************
|
* Function Name : GPS_Poll
|
* Description : GPS��ѯ����
|
* Input : None
|
* Output : None
|
* Return : None
|
* Author : www.hido-studio.com
|
* Modified Date: : 2021��1��8��
|
*******************************************************************************/
|
HIDO_VOID GPS_Poll(void);
|
|
/*******************************************************************************
|
* Function Name : GPS_Init
|
* Description : GPSģ���ʼ��
|
* Input : None
|
* Output : None
|
* Return : None
|
* Author : www.hido-studio.com
|
* Modified Date: : 2021��1��8��
|
*******************************************************************************/
|
HIDO_VOID GPS_Init(void);
|
|
/*******************************************************************************
|
* Function Name : GPS_GetGPRMI
|
* Description : 获取最新的GPRMI数据
|
* Input : _pstGPRMI - 存储GPRMI数据的结构体指针
|
* Output : None
|
* Return : HIDO_OK - 成功, HIDO_ERR - 失败
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年11月11日
|
*******************************************************************************/
|
HIDO_INT32 GPS_GetGPRMI(ST_GPRMI *_pstGPRMI);
|
|
/*******************************************************************************
|
* Function Name : GPS_GetGPIMU
|
* Description : 获取最新的GPIMU数据
|
* Input : _pstGPIMU - 存储GPIMU数据的结构体指针
|
* Output : None
|
* Return : HIDO_OK - 成功, HIDO_ERR - 失败
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年11月11日
|
*******************************************************************************/
|
HIDO_INT32 GPS_GetGPIMU(ST_GPIMU *_pstGPIMU);
|
|
/*******************************************************************************
|
* Function Name : GPS_GetCurrentENU
|
* Description : 获取当前ENU坐标(相对于开机后第一个固定解)
|
* Input : _enu - 存储ENU坐标的数组指针 [东, 北, 天]
|
* Output : None
|
* Return : HIDO_OK - 成功, HIDO_ERR - 失败或原点未初始化
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年12月3日
|
*******************************************************************************/
|
HIDO_INT32 GPS_GetCurrentENU(float _enu[3]);
|
|
/*******************************************************************************
|
* Function Name : GPS_GetGPGIG
|
* Description : 获取最新的GPGIG数据(fmig报文,包含位置信息、解状态和差分龄期)
|
* Input : _pstGPGIG - 存储GPGIG数据的结构体指针
|
* Output : None
|
* Return : HIDO_OK - 成功, HIDO_ERR - 失败或数据无效
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年12月4日
|
*******************************************************************************/
|
HIDO_INT32 GPS_GetGPGIG(ST_GPGIG *_pstGPGIG);
|
|
/*******************************************************************************
|
* Function Name : GPS_UploadGGA
|
* Description : 每秒上传一次GGA报文到4G(拼接fmin和fmig数据,经纬度来自fmig)
|
* Input : None
|
* Output : None
|
* Return : None
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年12月4日
|
*******************************************************************************/
|
HIDO_VOID GPS_UploadGGA(HIDO_VOID);
|
|
/*******************************************************************************
|
* Function Name : GPS_FormatGGA
|
* Description : 将fmin和fmig数据格式化为标准GGA报文(经纬度优先使用fmig数据)
|
* Input : _pstGPRMI - fmin数据
|
* : _pstGPGIG - fmig数据(包含经纬度信息)
|
* : _pcBuffer - 输出缓冲区
|
* : _u32BufferSize - 缓冲区大小
|
* Output : _pcBuffer
|
* Return : 实际写入的字符数,失败返回0
|
* Author : www.hido-studio.com
|
* Modified Date: : 2025年12月4日
|
*******************************************************************************/
|
HIDO_UINT32 GPS_FormatGGA(const ST_GPRMI *_pstGPRMI, const ST_GPGIG *_pstGPGIG,
|
HIDO_CHAR *_pcBuffer, HIDO_UINT32 _u32BufferSize);
|
|
#endif /* _GPS_H_ */
|