Phonegap坐标之间的地理位置距离

时间:2016-02-18 11:11:42

标签: javascript android cordova gps geolocation

我试着用javascript计算两个坐标之间的距离 更具体地说,是一组静态坐标与从地理定位cordova插件中获取的当前位置之间的距离。

这是我的代码:

document.addEventListener('deviceready', onDeviceReady, false);

function onDeviceReady() {
    navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

var onSuccess = function(position) {
    document.getElementById("content").innerHTML = 'Success, attempting calculation...';
    var lla = position.coords.latitude;
    var llo = position.coords.longitude;

    document.getElementById("content").innerHTML =
'GPS Position: ' + calcTheDistance(lla, llo).d + 'Metres';


};

var onError = function(error) {
    document.getElementById("content").innerHTML =
    'code: ' + error.code + '\n' +
    'message: ' + error.message + '\n';
};

function refrGps() {
    document.getElementById("content").innerHTML = 'Loading...';
    navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

function calcTheDistance(lati1, long1) {
    var r = 6371000; //Meters
    var joschLat = 50.1109221;
    var joschLon = 8.6821267;
    var la1 = lati1;
    var la2 = joschLat;
    var lat1 = lati1.toRadians();
    var lat2 = joschLat.toRadians();
    var lo1 = long1;
    var lo2 = joschLon;
    var la2minla1 = (la2-la1).toRadians();
    var lo2minlo1 = (lo2-lo1).toRadians();

    var cal = Math.sin(la2minla1 / 2) * Math.sin(la2minla1 / 2) +
            Math.cos(lat1) * Math.cos(lat2) *
            Math.sin(lo2minlo1/2) * Math.sin(lo2minlo1/2);
    var c = 2* Math.atan2(Math.sqrt(cal), Math.sqrt(1-cal));

    d = r * c;
};

我试图重复几次而没有运气。

对于我提到的计算:http://www.movable-type.co.uk/scripts/latlong.html

2 个答案:

答案 0 :(得分:0)

您引用的页面包含library of functions already implemented in Javascript。如果您在应用中包含这些内容,则计算变得微不足道:

document.addEventListener('deviceready', onDeviceReady, false);

function onDeviceReady() {
    navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

var onSuccess = function(position) {
    document.getElementById("content").innerHTML = 'Success, attempting calculation...';
    var sourceLl = new LatLon(position.coords.latitude, position.coords.longitude);

    document.getElementById("content").innerHTML =
'GPS Position: ' + calcTheDistance(sourceLl) + 'Metres';
};

var onError = function(error) {
    document.getElementById("content").innerHTML =
    'code: ' + error.code + '\n' +
    'message: ' + error.message + '\n';
};

function refrGps() {
    document.getElementById("content").innerHTML = 'Loading...';
    navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

function calcTheDistance(sourceLl) {
    var joschLat = 50.1109221;
    var joschLon = 8.6821267;
    var joschLl = new LatLon(joschLat, joschLon);
    return joschLl.distanceTo(sourceLl);
};

答案 1 :(得分:0)

所以我在阅读@DaveAlden的答案之后想出来了,谢谢顺便说一下!

toRadians();不是标准的Javascript函数,所以在我添加了这个并重写了我的代码之后,它运行正常。

这是工作代码     document.addEventListener(' deviceready',onDeviceReady,false);

function onDeviceReady() {


navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

var onSuccess = function(position) {
    document.getElementById("content").innerHTML = 'Success, attempting calculation...';
    var lla = position.coords.latitude;
    var llo = position.coords.longitude;
    var dst = 'Distance: ' + calcTheDistance(lla, llo) + ' Metres';
    document.getElementById("content").innerHTML = dst;


};

var onError = function(error) {
    document.getElementById("content").innerHTML =
    'code: ' + error.code + '\n' +
    'message: ' + error.message + '\n';
};

function refrGps() {
    document.getElementById("content").innerHTML = 'Loading...';
    navigator.geolocation.getCurrentPosition(onSuccess, onError);
};

    function toRadians(num) {
        return num * Math.PI / 180; 
};

function calcTheDistance(lati1, long1) {
    var r = 6371000; //metres
    var joschLat = 50.1109221;
    var joschLon = 8.6821267;
    var la1 = lati1;
    var la2 = joschLat;
    var lat1 = toRadians(lati1);
    var lat2 = toRadians(joschLat);
    var lo1 = long1;
    var lo2 = joschLon;
    var la2minla1 = toRadians(la2-la1);
    var lo2minlo1 = toRadians(lo2-lo1);

    var cal = Math.sin(la2minla1 / 2) * Math.sin(la2minla1 / 2) +
            Math.cos(lat1) * Math.cos(lat2) *
            Math.sin(lo2minlo1/2) * Math.sin(lo2minlo1/2);
    var c = 2* Math.atan2(Math.sqrt(cal), Math.sqrt(1-cal));

    var d = r * c;
    return Math.round(d);
};