根据两个位置的经纬度,计算其距离和方位

#include <iostream>
#include <cmath>

const double EARTH_RADIUS = 6371000.0; // 地球半径 (单位:米)
const double DEG_TO_RAD = M_PI / 180.0;

// 计算两个经纬度之间的距离 (单位:米) 和方位 (单位:度)
void calculate_distance_and_bearing(double lat1, double lon1, double lat2, double lon2, double &distance, double &bearing) {
    // 计算距离
    double dLat = (lat2 - lat1) * DEG_TO_RAD;
    double dLon = (lon2 - lon1) * DEG_TO_RAD;

    double a = std::sin(dLat / 2) * std::sin(dLat / 2) +
               std::cos(lat1 * DEG_TO_RAD) * std::cos(lat2 * DEG_TO_RAD) *
               std::sin(dLon / 2) * std::sin(dLon / 2);
    double c = 2 * std::atan2(std::sqrt(a), std::sqrt(1 - a));
    distance = EARTH_RADIUS * c;

    // 计算方位
    double y = std::sin(dLon) * std::cos(lat2 * DEG_TO_RAD);
    double x = std::cos(lat1 * DEG_TO_RAD) * std::sin(lat2 * DEG_TO_RAD) -
               std::sin(lat1 * DEG_TO_RAD) * std::cos(lat2 * DEG_TO_RAD) * std::cos(dLon);
    
    bearing = std::atan2(y, x) * 180.0 / M_PI; // 转换为度
    bearing = fmod(bearing + 360.0, 360.0); // 确保结果在 0 到 360 度之间
}

int main() {
    double lat1 = 34.05; // 点 A 的纬度
    double lon1 = -118.25; // 点 A 的经度
    double lat2 = 40.71; // 点 B 的纬度
    double lon2 = -74.01; // 点 B 的经度

    double distance, bearing;
    calculate_distance_and_bearing(lat1, lon1, lat2, lon2, distance, bearing);

    std::cout << "Distance: " << distance << " meters" << std::endl;
    std::cout << "Initial Bearing: " << bearing << " degrees" << std::endl;

    return 0;
}

1. 常量定义:
   - EARTH_RADIUS:地球半径,单位为米。

2. calculate_distance_and_bearing`函数:
   - 输入:两个点的纬度和经度。
   - 输出:距离(米)和方位(度)。

3. main函数:
   - 提供经纬度,调用计算函数,并输出结果。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据两点的经纬度计算方位距离是一个常见的问题,可以使用C++中的数学库来解决。以下是计算两点之间距离方位角的示例代码: ```c++ #include <iostream> #include <cmath> using namespace std; const double PI = 3.14159265358979323846; const double EARTH_RADIUS = 6378.137; // 地球半径,单位为千米 double rad(double d) { return d * PI / 180.0; } double getDistance(double lng1, double lat1, double lng2, double lat2) { double radLat1 = rad(lat1); double radLat2 = rad(lat2); double a = radLat1 - radLat2; double b = rad(lng1) - rad(lng2); double s = 2 * asin(sqrt(pow(sin(a / 2), 2) + cos(radLat1) * cos(radLat2) * pow(sin(b / 2), 2))); s *= EARTH_RADIUS; return s; } double getAzimuth(double lng1, double lat1, double lng2, double lat2) { double radLat1 = rad(lat1); double radLat2 = rad(lat2); double radLng1 = rad(lng1); double radLng2 = rad(lng2); double y = sin(radLng2 - radLng1) * cos(radLat2); double x = cos(radLat1) * sin(radLat2) - sin(radLat1) * cos(radLat2) * cos(radLng2 - radLng1); double brng = atan2(y, x); brng = brng * 180 / PI; if (brng < 0) { brng += 360; } return brng; } int main() { double lng1 = 116.388171; double lat1 = 39.935961; double lng2 = 116.397458; double lat2 = 39.908722; double distance = getDistance(lng1, lat1, lng2, lat2); double azimuth = getAzimuth(lng1, lat1, lng2, lat2); cout << "两点之间的距离为:" << distance << "千米" << endl; cout << "两点之间的方位角为:" << azimuth << "度" << endl; return 0; } ``` 其中,getDistance函数用于计算两点之间的距离,getAzimuth函数用于计算两点之间的方位角。需要注意的是,这里使用的是WGS84坐标系,如果需要使用其他坐标系,需要进行转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值