xml – 如何计算GPX文件的距离?

前端之家收集整理的这篇文章主要介绍了xml – 如何计算GPX文件的距离?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个 GPX file与GPS轨道。现在我想计算这个轨道覆盖的距离。

什么是最好的计算方法

计算两点(GPX文件中的每对航点)之间的距离的传统方法是使用Haversine公式。

我有一个实现该算法的sql Server函数。这应该很容易翻译成其他语言:

create function dbo.udf_Haversine(@lat1 float,@long1 float,@lat2 float,@long2 float) returns float begin
    declare @dlon float,@dlat float,@rlat1 float,@rlat2 float,@rlong1 float,@rlong2 float,@a float,@c float,@R float,@d float,@DtoR float

    select @DtoR = 0.017453293
    select @R = 3959      -- Earth radius

    select 
        @rlat1 = @lat1 * @DtoR,@rlong1 = @long1 * @DtoR,@rlat2 = @lat2 * @DtoR,@rlong2 = @long2 * @DtoR

    select 
        @dlon = @rlong1 - @rlong2,@dlat = @rlat1 - @rlat2

    select @a = power(sin(@dlat/2),2) + cos(@rlat1) * 
                     cos(@rlat2) * power(sin(@dlon/2),2)
    select @c = 2 * atn2(sqrt(@a),sqrt(1-@a))
    select @d = @R * @c

    return @d 
end

这返回了里程的距离。对于公里,更换地球半径与公里相当。

Here是一个更深入的解释。

编辑:该功能足够快,足够准确,可以使用邮政编码数据库进行半径搜索。在this site多年来一直在做得很好(但现在不再存在链接了)。

猜你在找的XML相关文章