获取地理位置及计算距离

获取地理位置及计算距离


function loadSupport(){         //支持检测
    if(navigator.geolocation){
        navigator.geolocation.getCurrentPosition(updataPosition,showError);
    }else{
        alert("对不起,浏览器不支持");
        document.innerHTML = "对不起,浏览器不支持"
    }
}

function updataPosition(position){
    var latitudeP = position.coords.latitude,
        longitudeP = position.coords.longitude,
        accuracyP = position.coords.accuracy,
        altitudeP = position.coords.altitude,
        altitudeAccuracyP = position.coords.altitudeAccuracy,
        speedP = position.coords.speed;
    var distanceP = getDistance(latitudeP,longitudeP,31.22, 121.48);
}

function showError(error){
    switch(error){
        case error.PERMISSION_DENIED:
            document.innerHTML = "用户拒绝方位地理位置"
            break;
        case error.POSITION_UNAVAILABLE:
            document.innerHTML = "地理位置信息无法获取"
            break;
        case error.TIMEOUT:
            document.innerHTML = "获取位置时间超时"
            break;
        case error.UNKNOWN_ERROR:
            document.innerHTML = "未知错误"
            break;
    }
}

function rad(d){
    return d * Math.PI / 180;
}

function getDistance(lat1,lng1,lat2,lng2){
    var earth_radius = 6378.137             //单位为公里
    var radlat1 = rad(lat1);
    var radlng1 = rad(lng1);
    var radlat2 = rad(lat2);
    var radlng2 = rad(lng2);

    var a = radlat1 - radlat2;
    var b = radlng1 - radlng2;

    var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) + Math.cos(radlat1)*Math.cos(radlat2)*Math.pow(Math.sin(b/2),2)));
    s = s * earth_radius;
    s = Math.round(s);
    return s;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值