<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.6.4/jquery.js"></script>
<script type="text/javascript">
var EARTH_RADIUS = 6378137.0; //单位M
var PI = Math.PI; function getRad(d) {
return d * PI / 180.0;
} /**
* caculate the great circle distance
* @param {Object} lat1(纬度1)
* @param {Object} lng1(经度1)
* @param {Object} lat2(纬度2)
* @param {Object} lng2(经度2)
*/
//第一种方法:这种算法是把地球当作规则的球面来计算的咯,这种方法不是很精准咯,这个还要取决你定位的精准度咯
function getGreatCircleDistance(lat1, lng1, lat2, lng2) {
var radLat1 = getRad(lat1);
var radLat2 = getRad(lat2); var a = radLat1 - radLat2;
var b = getRad(lng1) - getRad(lng2); var s = * Math.asin(Math.sqrt(Math.pow(Math.sin(a / ), ) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / ), )));
s = s * EARTH_RADIUS;
s = Math.round(s * ) / 10000.0; alert(s);
}
//第一种方法:地球是椭圆的,所以会有这种算法
function getFlatternDistance(lat1, lng1, lat2, lng2) {
var f = getRad((lat1 + lat2) / );
var g = getRad((lat1 - lat2) / );
var l = getRad((lng1 - lng2) / ); var sg = Math.sin(g);
var sl = Math.sin(l);
var sf = Math.sin(f); var s, c, w, r, d, h1, h2;
var a = EARTH_RADIUS;
var fl = / 298.257; sg = sg * sg;
sl = sl * sl;
sf = sf * sf; s = sg * ( - sl) + ( - sf) * sl;
c = ( - sg) * ( - sl) + sf * sl; w = Math.atan(Math.sqrt(s / c));
r = Math.sqrt(s * c) / w;
d = * w * a;
h1 = ( * r - ) / / c;
h2 = ( * r + ) / / s;
alert( d * ( + fl * (h1 * sf * ( - sg) - h2 * ( - sf) * sg)));
}
$(function () {
getFlatternDistance(28.89596, 105.443985, 28.896462, 105.444291);
});
</script>
</head>
<body>
63.3422
</body>
</html>

js计算地球两个经纬度之间的距离的更多相关文章

  1. IOS 计算两个经纬度之间的距离

    IOS 计算两个经纬度之间的距离 一 丶 -(double)distanceBetweenOrderBy:(double) lat1 :(double) lat2 :(double) lng1 :(d ...

  2. java如何计算两个经纬度之间的距离?

    /*计算两个经纬度之间的距离 结果单位:米 */public static double getDistance(String lat1Str, String lng1Str, String lat2 ...

  3. 计算两个经纬度之间的距离(python算法)

    EARTH_REDIUS = 6378.137 def rad(d): return d * pi / 180.0 def getDistance(lat1, lng1, lat2, lng2): r ...

  4. reactjs中使用高德地图计算两个经纬度之间的距离

    第一步下载依赖 npm install --save react-amap 第二步,在组件中使用 import React, { Component } from 'react' import { L ...

  5. java计算两个经纬度之间的距离

    /** * 计算点 是否在一个固定点的半径范围内 * @2016年10月20日 * @param a 经度1 已知 * @param b 纬度1 已知 * @param x 经度2 * @param ...

  6. sql 计算地球2个坐标之间的距离

    show variables like '%func%'; set global log_bin_trust_function_creators=1; use scm_wuliudelimiter $ ...

  7. PHP计算两个已知经纬度之间的距离

    /** *求两个已知经纬度之间的距离,单位为千米 *@param lng1,lng2 经度 *@param lat1,lat2 纬度 *@return float 距离,单位千米 **/ privat ...

  8. 高德地图 API 计算两个城市之间的距离

    1. 目前在项目中,遇到一个需求不会做,就是要计算两个城市之间的距离,而这两个城市的输入是可变的,如果要使用数据库来先存储两地之间的距离,调用的时候再来调用,那么存数据的时候,要哭的,因为光是省级区域 ...

  9. Java计算两个经纬度间的距离最简单的方式

    开发中经常会遇到计算两个点(经纬度)之间的距离或者计算最近门店的场景,下面简单实现一下如何计算两个经纬度之间相隔的距离. 1.导入geodesy的maven依赖 或者到阿里云maven仓库下载jar包 ...

随机推荐

  1. matlab 将多个盒图放在一张图上

    1.boxplot 将多个盒图放在一张图上 x1 = normrnd(5,1,100,1)';x2 = normrnd(6,1,200,1)';X = [x1 x2];G = [zeros(size( ...

  2. 10 行 Python 代码写的模糊查询

    导语: 模糊匹配可以算是现代编辑器(在选择要打开的文件时)的一个必备特性了,它所做的就是根据用户输入的部分内容,猜测用户想要的文件名,并提供一个推荐列表供用户选择. 样例如下: Vim (Ctrl-P ...

  3. 创建django项目

    python /usr/local/lib/python3.4/dist-packages/Django-1.9.10-py3.4.egg/django/bin/django-admin.py sta ...

  4. Redis 学习(二)

    Redis可以存储以下5种数据类型 1. String 字符串 整数 浮点 2. List   一个链表 3. Set  无序收集器 4. Hash  无序散列表 5. Zset   有序集合

  5. VMware安装Centos7,已将该虚拟机配置为使用64为,却无法执行64位操作

    在新建虚拟机之后,相信很多人都遇到了这个问题,这个问题的本质就是电脑是否支持虚拟化,虽然不是很清楚这是什么 解决方案就是,重启电脑(这边的电脑不是虚拟机而是主机),进入BIOS界面(不同电脑进入BIO ...

  6. 用gulp打包带参数资源做法与asp.net/java项目结合的自动构建方案探讨

    先探讨方案,后续再实现. gulp打包前端教程配置:http://www.cnblogs.com/EasonJim/p/6209951.html 可能存在以下场景: 1.整个服务端采用接口的形式暴露给 ...

  7. linux下重启apache

    基本的操作方法: 本文假设你的apahce安装目录为/usr/local/apache2,这些方法适合任何情况 apahce启动命令: 推荐/usr/local/apache2/bin/apachec ...

  8. 【整理】Word OpenXML常用标签

    一.背景 最近在做关于Word内容自动标引,需要了解Word的底层结构,顺便梳理一下OpenXML的标签含义,方便后续开发,提高对OpenXML标签的查找效率,也是一个熟悉的过程. 二.内容 < ...

  9. 如何接触学习java

    信息科技必将是未来的潮流,Java语言必将在时代的进步中发挥不可估量的作用,未来,掌握好一门实用而且有良好应用前景的技术是你们的首要任务. 零基础怎么学Java 多年Java教育培训经验事实表明,零基 ...

  10. Socket异步通讯

    1.可以通过多线程来解决(一会补上) 2.Socket在tcp/udp两种通信协议下的异步通信: 基于TCP的异步通信: BeginAccept方法和endeaccept方法 包含在System.Ne ...