【C++】开源:坐标转换和大地测量GeographicLib库配置使用

😏*★,°* :.☆( ̄▽ ̄)/$:.°★ 😏

这篇文章主要介绍坐标转换和大地测量GeographicLib库配置使用。
无专精则不能成,无涉猎则不能通。------梁启超

欢迎来到我的博客,一起学习,共同进步。

喜欢的朋友可以关注一下,下次更新不迷路🥞

文章目录

    • [:smirk:1. 项目介绍](#:smirk:1. 项目介绍)
    • [:blush:2. 环境配置](#:blush:2. 环境配置)
    • [:satisfied:3. 使用说明](#:satisfied:3. 使用说明)

😏1. 项目介绍

项目Github地址:https://github.com/geographiclib/geographiclib

GeographicLib是一个用于处理地理坐标转换和大地测量(geodesy)的开源库,它提供了一系列工具和算法,用于在地球表面上执行各种地理计算。

主要特点:

1.精确的地理计算:GeographicLib库提供了高精度的地理计算方法,能够处理大地测量中的复杂数学问题,如计算两个地点之间的距离、方向、初始方位角等。
2.支持多种椭球体和大地基准:支持多种地球椭球体模型(如WGS84、GRS80等)和大地基准,可以根据需要选择合适的模型进行地理计算。
3.跨平台兼容性:GeographicLib库可以在多种操作系统上运行,包括Linux、Windows和macOS等,使其具有较好的跨平台兼容性。
4.多种接口和语言支持:提供了C++、Python和其他语言的接口,使得开发人员可以在不同的编程环境中使用GeographicLib的功能。

GeographicLib库广泛应用于地理信息系统(GIS)、地图制作、航海、航空、地理学研究等领域

😊2. 环境配置

Ubuntu可以apt安装:

bash 复制代码
sudo apt install libgeographic-dev geographiclib-tools

程序g++编译:

bash 复制代码
g++ -o main main.cpp -lGeographic

😆3. 使用说明

计算两个地点之间的大圆距离:

cpp 复制代码
#include <iostream>
#include <GeographicLib/Geodesic.hpp>

int main() {
    // Create a Geodesic object for WGS84 ellipsoid
    GeographicLib::Geodesic geod(GeographicLib::Constants::WGS84_a(), GeographicLib::Constants::WGS84_f());

    // Coordinates of Philadelphia, PA
    double lat1 = 39.9526, lon1 = -75.1652;

    // Coordinates of Los Angeles, CA
    double lat2 = 34.0522, lon2 = -118.2437;

    // Calculate distance between the two points
    double s12;
    geod.Inverse(lat1, lon1, lat2, lon2, s12);

    std::cout << "Distance between Philadelphia, PA and Los Angeles, CA: " << s12 / 1000.0 << " km\n";

    return 0;
}

官方给出的经纬度和UTM坐标系的转换:

cpp 复制代码
// Example of using the GeographicLib::UTMUPS class

#include <iostream>
#include <iomanip>
#include <exception>
#include <string>
#include <GeographicLib/UTMUPS.hpp>

using namespace std;
using namespace GeographicLib;

int main() {
  try {
    // See also example-GeoCoords.cpp
    {
      // Sample forward calculation
      double lat = 33.3, lon = 44.4; // Baghdad
      int zone;
      bool northp;
      double x, y;
      UTMUPS::Forward(lat, lon, zone, northp, x, y);
      string zonestr = UTMUPS::EncodeZone(zone, northp);
      cout << fixed << setprecision(2)
           << zonestr << " " << x << " " << y << "\n";
    }
    {
      // Sample reverse calculation
      string zonestr = "38n";
      int zone;
      bool northp;
      UTMUPS::DecodeZone(zonestr, zone, northp);
      double x = 444e3, y = 3688e3;
      double lat, lon;
      UTMUPS::Reverse(zone, northp, x, y, lat, lon);
      cout << lat << " " << lon << "\n";
    }
  }
  catch (const exception& e) {
    cerr << "Caught exception: " << e.what() << "\n";
    return 1;
  }
}

以上。

相关推荐
一只特立独行的猪6111 小时前
Java面试——集合篇
java·开发语言·面试
大得3692 小时前
go注册中心Eureka,注册到线上和线下,都可以访问
开发语言·eureka·golang
小强在此2 小时前
基于开源鸿蒙(OpenHarmony)的【智能家居综合应用】系统
华为·开源·智能家居·团队开发·harmonyos
周哈里窗的编程2 小时前
CSP-CCF★201912-2回收站选址★
c++·算法·图论
小珑也要变强3 小时前
队列基础概念
c语言·开发语言·数据结构·物联网
未来可期LJ4 小时前
【C++ 设计模式】单例模式的两种懒汉式和饿汉式
c++·单例模式·设计模式
Trouvaille ~5 小时前
【C++篇】C++类与对象深度解析(六):全面剖析拷贝省略、RVO、NRVO优化策略
c++·c++20·编译原理·编译器·类和对象·rvo·nrvo
little redcap5 小时前
第十九次CCF计算机软件能力认证-乔乔和牛牛逛超市
数据结构·c++·算法
AI原吾5 小时前
掌握Python-uinput:打造你的输入设备控制大师
开发语言·python·apython-uinput
机器视觉知识推荐、就业指导5 小时前
Qt/C++事件过滤器与控件响应重写的使用、场景的不同
开发语言·数据库·c++·qt