单片机论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3988|回复: 0
收起左侧

计算两个经纬度直线距离 安卓app开发

[复制链接]
hongniu 发表于 2015-6-25 15:18 | 显示全部楼层 |阅读模式
.Net计算方式
public static class CCalculationGPSCoordinateDistance
    {
        private const double dEARTH_RADIUS = 6378.137;  // 地球半径

        private static double Rad(double d)
        {
            return (d * Math.PI / 180.0);
        }

        /// <summary>
        /// 计算两个坐标的距离
        /// </summary>
        /// <param >第一个坐标纬度</param>
        /// <param >第一个坐标经度</param>
        /// <param >第二个坐标纬度</param>
        /// <param >第二个坐标经度</param>
        /// <returns>两个坐标间的距离</returns>

        public static double GetDistance(double dLngPre, double dLatPre, double dLngNext, double dLatNext)
        {
            double dRadLatPre = Rad(dLatPre);
            double dRadLatNext = Rad(dLatNext);
            double a = dRadLatPre - dRadLatNext;
            double b = Rad(dLngPre) - Rad(dLngNext);
            double s = 2 * Math.Asin(Math.Sqrt(Math.Pow(Math.Sin(a / 2), 2) + Math.Cos(dRadLatPre) * Math.Cos(dRadLatNext) * Math.Pow(Math.Sin(b / 2), 2)));
            s = s * dEARTH_RADIUS;
            s = Math.Round(s * 10000) / 10000;
            return s;
        }
    }


数据库计算方法

DECLARE @dEarthRadius FLOAT  -- 地球半径
SET @dEarthRadius = 6378.137 -- 设置地球半径

DECLARE @dLng FLOAT    -- 上一条数据的纬度
DECLARE @dLat FLOAT    -- 上一条数据的经度
DECLARE @dTemLng FLOAT       -- 当前纬度
DECLARE @dTemLat FLOAT       -- 当前经度

DECLARE @dTemA FLOAT -- 临时变量A
DECLARE @dTemB FLOAT -- 临时变量B
DECLARE @dMeters FLOAT -- 两点间的距离(单位:米)
DECLARE @dTemPre FLOAT  -- 临时变量
DECLARE @dTemNext FLOAT -- 临时变量

SET @dTemPre = (@dTemLat * PI() / 180.0)
SET @dTemNext = (@dLat * PI() / 180.0)
SET @dTemA = @dTemPre - @dTemNext
SET @dTemB = (@dTemLng * PI() / 180.0) - (@dLng * PI() / 180.0)
SET @dMeters = ROUND((2 * ASIN(SQRT(POWER(SIN(@dTemA / 2),2)
      +COS(@dTemPre)* COS(@dTemNext) * POWER(SIN(@dTemB / 2),2)))) * @dEarthRadius,5) * 1000 -- 舍入精确度并把km装换成m





回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|单片机论坛 |51Hei单片机16群 联系QQ:125739409;技术交流QQ群7344883

Powered by 单片机教程网

快速回复 返回顶部 返回列表