如何利用起始点、距离和方位角计算终点? [英] How to calculate endPoint using initial point, distance and azimuth?

查看:52
本文介绍了如何利用起始点、距离和方位角计算终点?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要使用起点、距离和方位角找到终点。以下是每一项的值:

latitude: 37.624942,
longitude": -7.896333,
azimute: 233.0
distance : 20.0

以下是我的函数:

private List<double> findEndPoint(string latitudeStart, string longitudeStart, string azimute,double distancia) 
{
    List<double> endPoint = new List<double>();

    double latitudeStartDouble = Convert.ToDouble(latitudeStart, System.Globalization.CultureInfo.InvariantCulture);
    double longitudeStartDouble = Convert.ToDouble(longitudeStart, System.Globalization.CultureInfo.InvariantCulture);
    double azimuteDouble = Convert.ToDouble(azimute, System.Globalization.CultureInfo.InvariantCulture);
    double azimuteRadians = ConvertToRadians(azimuteDouble);

    
    double R = 6371.0; // Raio da Terra em km

    

    double latitudeEnd = Math.Asin(Math.Sin(latitudeStartDouble) * Math.Cos(distancia / R) +
        Math.Cos(latitudeStartDouble) * Math.Sin(distancia / R) * Math.Cos(azimuteRadians));

    endPoint.Add(latitudeEnd);

    double longitudeEnd = longitudeStartDouble + Math.Atan2(
        Math.Sin(azimuteRadians) * Math.Sin(distancia / R) * Math.Cos(latitudeStartDouble),
        Math.Cos(distancia / R) - Math.Sin(latitudeStartDouble) * Math.Sin(latitudeEnd));

    endPoint.Add(longitudeEnd);

    return endPoint;
}

返回:

latitude: -0.0760588400705975
longitude:-7.8988473639987093

纬度一定是错的,但我不知道为什么它会给我这个值。

推荐答案

我需要处理弧度,然后将其转换回度:

private List<double> findEndPoint(string latitudeStart, string longitudeStart, string azimute,double distancia) 
    {
        List<double> endPoint = new List<double>();

        double latitudeStartDouble = Convert.ToDouble(latitudeStart, System.Globalization.CultureInfo.InvariantCulture);
        latitudeStartDouble = ConvertToRadians(latitudeStartDouble);

        double longitudeStartDouble = Convert.ToDouble(longitudeStart, System.Globalization.CultureInfo.InvariantCulture);
        longitudeStartDouble = ConvertToRadians(longitudeStartDouble);

        double azimuteDouble = Convert.ToDouble(azimute, System.Globalization.CultureInfo.InvariantCulture);
        double azimuteRadians = ConvertToRadians(azimuteDouble);


        double R = 6371; // Raio da Terra em km

        

        double latitudeEnd = Math.Asin(Math.Sin(latitudeStartDouble) * Math.Cos(distancia / R) +
            Math.Cos(latitudeStartDouble) * Math.Sin(distancia / R) * Math.Cos(azimuteRadians));

        latitudeEnd = ConvertToDegrees(latitudeEnd);
        endPoint.Add(latitudeEnd);

        double longitudeEnd = longitudeStartDouble + Math.Atan2(Math.Sin(azimuteRadians) * Math.Sin(distancia / R) * Math.Cos(latitudeStartDouble),
            Math.Cos(distancia / R) - Math.Sin(latitudeStartDouble) * Math.Sin(latitudeEnd));

        longitudeEnd = ConvertToDegrees(longitudeEnd);
        endPoint.Add(longitudeEnd);

        return endPoint;
    }

这篇关于如何利用起始点、距离和方位角计算终点?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆