studio_proj_c.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. * + 3度分带法 (适用于1:1万~1:50万地图)
  24. * - 理论: 3度带中央经线=3度带带号*3.0 , 带号= 3度带带号=(经度+1.5°)/3取整
  25. * - 带号计算: int zone_num = floor((经度 + 1.5°) / 3.0);
  26. * - 中央经线: double central = floor((经度 + 1.5°) / 3.0) * 3.0;
  27. *
  28. * + 6度分带法 (适用于1:1万以下小比例地图)
  29. * - 理论: 6度带中央经线=6度带带号*6.0 - 3.0 , 带号= 6度带带号=(经度+6°)/6取整
  30. * - 带号计算: zone_num = floor((经度 + 6°) / 6.0);
  31. * - 中央经线: double central = floor((经度 + 6°) / 6.0) * 6.0 - 3.0;
  32. * ----------------------------------------------------------------*/
  33. /// 经纬度 转 高斯克吕格投影
  34. /// \param central 中央经线 (度)
  35. /// \param lon 经度 (度)
  36. /// \param lat 纬度 (度)
  37. /// \param gx 高斯坐标 x(m)
  38. /// \param gy 高斯坐标 y(m)
  39. void lonlat_to_gauss(const double central, const double lon, const double lat, double *gx, double *gy);
  40. /// 高斯克吕格投影 转 经纬度
  41. /// \param central 中央经线 (度)
  42. /// \param gx 高斯坐标 x(m)
  43. /// \param gy 高斯坐标 y(m)
  44. /// \param lon 经度 (度)
  45. /// \param lat 纬度 (度)
  46. void gauss_to_lonlat(const double central, const double gx, const double gy, double *lon, double *lat);
  47. /// 经纬度 转 墨卡托投影
  48. /// \param lon 经度 (度)
  49. /// \param lat 纬度 (度)
  50. /// \param mctx 墨卡托投影 x(m)
  51. /// \param mcty 墨卡托投影 y(m)
  52. void lonlat_to_mercator(const double lon, const double lat, double *mctx, double *mcty);
  53. /// 墨卡托投影 转 经纬度
  54. /// \param mctx 墨卡托投影 x(m)
  55. /// \param mcty 墨卡托投影 y(m)
  56. /// \param lon 经度 (度)
  57. /// \param lat 纬度 (度)
  58. void mercator_to_lonlat(const double mctx, const double mcty, double *lon, double *lat);
  59. /// 墨卡托投影 转 高斯投影
  60. /// \param central 中央经线 (度)
  61. /// \param gx 墨卡托投影 x(m)
  62. /// \param gy 墨卡托投影 y(m)
  63. /// \param mctx 高斯投影 x(m)
  64. /// \param mcty 高斯投影 y(m)
  65. void gauss_to_mercator(const double central, const double gx, const double gy, double *mctx, double *mcty);
  66. /// 高斯投影 转 墨卡托投影
  67. /// \param central 中央经线 (度)
  68. /// \param mctx 墨卡托投影 x(m)
  69. /// \param mcty 墨卡托投影 y(m)
  70. /// \param gx 高斯投影 x(m)
  71. /// \param gy 高斯投影 y(m)
  72. void mercator_to_gauss(const double central, const double mctx, const double mcty, double *gx, double *gy);
  73. /// 经纬坐标系 转 地心地固直角坐标系
  74. /// \param lon 经度 (度)
  75. /// \param lat 纬度 (度)
  76. /// \param height 高程 (m)
  77. /// \param x 地心地固直角坐标系 x (m)
  78. /// \param y 地心地固直角坐标系 y (m)
  79. /// \param z 地心地固直角坐标系 z (m)
  80. void lonlat_to_ecef(const double lon, const double lat, const double height, double *x, double *y, double *z);
  81. /// 经纬坐标系 转 地心地固直角坐标系
  82. /// \param x 地心地固直角坐标系 x (m)
  83. /// \param y 地心地固直角坐标系 y (m)
  84. /// \param z 地心地固直角坐标系 z (m)
  85. /// \param lon 经度 (度)
  86. /// \param lat 纬度 (度)
  87. /// \param height 高程 (m)
  88. void ecef_to_lonlat(const double x, const double y, const double z, double *lon, double *lat, double *height);
  89. #endif // STUDIO_PROJ_C_H