地理定位使用

HTML5的GeolocationAPI用于获取用户的位置信息。通过调用getCurrentPosition()方法,可以获取到包含经度和纬度的坐标。如果浏览器不支持,会显示相应消息。成功获取位置后,可以结合地图服务(如谷歌地图)展示位置。同时,应注意处理可能的错误,如用户拒绝权限、位置不可用、超时等。
摘要由CSDN通过智能技术生成

使用地理定位

HTML5 Geolocation(地理定位)用于定位用户的位置。

使用 getCurrentPosition() 方法来获得用户的位置。

下例是一个简单的地理定位实例,可返回用户位置的经度和纬度:

var x=document.getElementById("demo"); 
function getLocation() {    
    if(navigator.geolocation){
        navigator.geolocation.getCurrentPosition(showPosition);
    }
    else{
        x.innerHTML="该浏览器不支持获取地理位置。";
    } 
}  
function showPosition(position) {    
    x.innerHTML="纬度: "+ position.coords.latitude + "<br>经度: " + position.coords.longitude;     
}

实例解析:

  • 检测是否支持地理定位

  • 如果支持,则运行 getCurrentPosition() 方法。如果不支持,则向用户显示一段消息。

  • 如果 getCurrentPosition() 运行成功,则向参数showPosition中规定的函数返回一个 coordinates 对象

  • showPosition() 函数获得并显示经度和纬度

上面的例子是一个非常基础的地理定位脚本,不含错误处理。

处理错误和拒绝

getCurrentPosition() 方法的第二个参数用于处理错误。它规定当获取用户位置失败时运行的函数:

function showError(error) {    
    switch(error.code){        
        case error.PERMISSION_DENIED: x.innerHTML="用户拒绝对获取地理位置的请求。" 
            break;
        case error.POSITION_UNAVAILABLE: x.innerHTML="位置信息是不可用的。"
            break;        
        case error.TIMEOUT: x.innerHTML="请求用户地理位置超时。"
            break;        
        case error.UNKNOWN_ERROR: x.innerHTML="未知错误。"            
            break;    
    } 
}

错误代码:

  • Permission denied - 用户不允许地理定位

  • Position unavailable - 无法获取当前位置

  • Timeout - 操作超时


在地图中显示结果

如需在地图中显示结果,您需要访问可使用经纬度的地图服务,比如谷歌地图或百度地图:

function showPosition(position) {    
    var latlon=position.coords.latitude+","+position.coords.longitude;     
    var img_url="http://maps.googleapis.com/maps/api/staticmap?center=" + latlon + "&zoom=14&size=400x300&sensor=false";    
    document.getElementById("mapholder").innerHTML="<img src='"+img_url+"'>"; 
}

在上例中,我们使用返回的经纬度数据在谷歌地图中显示位置(使用静态图像)


返回数据

若成功,则 getCurrentPosition() 方法返回对象。始终会返回 latitude、longitude 以及 accuracy 属性。如果可用,则会返回其他下面的属性。

属性

描述

coords.latitude

十进制数的纬度

coords.longitude

十进制数的经度

coords.accuracy

位置精度

coords.altitude

海拔,海平面以上以米计

coords.altitudeAccuracy

位置的海拔精度

coords.heading

方向,从正北开始以度计

coords.speed

速度,以米/每秒计

timestamp

响应的日期/时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值