studio_proj_c.h 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /**
  2. ******************************************************************************
  3. * @file : studio_proj_c.h
  4. * @author : wangyingjie
  5. * @brief : 经纬度 转 高斯投影,墨卡托投影,地心地固直角坐标系 C 语言版
  6. * : 中央经线计算公式: double central = (int)(lon / 3) * 3;
  7. * @attention : None
  8. * @date : 2025/5/9
  9. ******************************************************************************
  10. */
  11. #ifndef STUDIO_PROJ_C_H
  12. #define STUDIO_PROJ_C_H
  13. #include <math.h>
  14. #define AO_M_PI 3.14159265358979323846 /* pi */
  15. #define DEG2RAD_C(deg) ((deg) * AO_M_PI / 180.0)
  16. #define RAD2DEG_C(rad) ((rad) * 180.0 / AO_M_PI)
  17. #define WGS84_A_C 6378137.0 // 长半轴
  18. #define INVF_C 298.257223563 // 扁率的倒数
  19. #define WGS84_B_C 6356752.3142 // 短半轴
  20. #define WGS84_F_C 1 / INVF_C // 扁率
  21. #define WGS84_E2_C ((2 * WGS84_F_C) - (WGS84_F_C * WGS84_F_C)) // 第一偏心扁率的平方
  22. /// 经纬度 转 高斯克吕格投影
  23. /// \param central 中央经线 (度)
  24. /// \param lon 经度 (度)
  25. /// \param lat 纬度 (度)
  26. /// \param gx 高斯坐标 x(m)
  27. /// \param gy 高斯坐标 y(m)
  28. void lonlat_to_gauss(const double central, const double lon, const double lat, double *gx, double *gy);
  29. /// 高斯克吕格投影 转 经纬度
  30. /// \param central 中央经线 (度)
  31. /// \param gx 高斯坐标 x(m)
  32. /// \param gy 高斯坐标 y(m)
  33. /// \param lon 经度 (度)
  34. /// \param lat 纬度 (度)
  35. void gauss_to_lonlat(const double central, const double gx, const double gy, double *lon, double *lat);
  36. /// 经纬度 转 墨卡托投影
  37. /// \param lon 经度 (度)
  38. /// \param lat 纬度 (度)
  39. /// \param mctx 墨卡托投影 x(m)
  40. /// \param mcty 墨卡托投影 y(m)
  41. void lonlat_to_mercator(const double lon, const double lat, double *mctx, double *mcty);
  42. /// 墨卡托投影 转 经纬度
  43. /// \param mctx 墨卡托投影 x(m)
  44. /// \param mcty 墨卡托投影 y(m)
  45. /// \param lon 经度 (度)
  46. /// \param lat 纬度 (度)
  47. void mercator_to_lonlat(const double mctx, const double mcty, double *lon, double *lat);
  48. /// 墨卡托投影 转 高斯投影
  49. /// \param central 中央经线 (度)
  50. /// \param gx 墨卡托投影 x(m)
  51. /// \param gy 墨卡托投影 y(m)
  52. /// \param mctx 高斯投影 x(m)
  53. /// \param mcty 高斯投影 y(m)
  54. void gauss_to_mercator(const double central, const double gx, const double gy, double *mctx, double *mcty);
  55. /// 高斯投影 转 墨卡托投影
  56. /// \param central 中央经线 (度)
  57. /// \param mctx 墨卡托投影 x(m)
  58. /// \param mcty 墨卡托投影 y(m)
  59. /// \param gx 高斯投影 x(m)
  60. /// \param gy 高斯投影 y(m)
  61. void mercator_to_gauss(const double central, const double mctx, const double mcty, double *gx, double *gy);
  62. /// 经纬坐标系 转 地心地固直角坐标系
  63. /// \param lon 经度 (度)
  64. /// \param lat 纬度 (度)
  65. /// \param height 高程 (m)
  66. /// \param x 地心地固直角坐标系 x (m)
  67. /// \param y 地心地固直角坐标系 y (m)
  68. /// \param z 地心地固直角坐标系 z (m)
  69. void lonlat_to_ecef(const double lon, const double lat, const double height, double *x, double *y, double *z);
  70. /// 经纬坐标系 转 地心地固直角坐标系
  71. /// \param x 地心地固直角坐标系 x (m)
  72. /// \param y 地心地固直角坐标系 y (m)
  73. /// \param z 地心地固直角坐标系 z (m)
  74. /// \param lon 经度 (度)
  75. /// \param lat 纬度 (度)
  76. /// \param height 高程 (m)
  77. void ecef_to_lonlat(const double x, const double y, const double z, double *lon, double *lat, double *height);
  78. #endif // STUDIO_PROJ_C_H