首页 web前端 H5教程 html5中地理位置定位api接口开发应用小结_html5教程技巧

html5中地理位置定位api接口开发应用小结_html5教程技巧

May 16, 2016 pm 03:50 PM
api 地理位置

地理位置定位的几种方式:IP地址,GPS,Wifi,GSM/CDMA

地理位置获取流程
1、用户打开需要获取地理位置的web应用。
2、应用向浏览器请求地理位置,浏览器弹出询问,询问用户是否共享地理位置。
3、假设用户允许,浏览器从设别查询相关信息。
4、浏览器将相关信息发送到一个信任的位置服务器,服务器返回具体的地理位置。

HTML5地理地位的实现
1. 实现基于浏览器(无需后端支持)获取用户的地理位置技术
2. 精确定位用户的地理位置( 精度最高达10m之内,依赖设备 )
3. 持续追踪用户的地理位置
4. 与 Google Map、或者 Baidu Map 交互呈现位置信息

Geolocation API 用于将用户当前地理位置信息共享给信任的站点,这涉及用户的隐私安全问题,所以当一个站点需要获取用户的当前地理位置,浏览器会提示用户是“允许” or “拒绝”。
先看看哪些浏览器支持Geolocation API:
IE9.0+、FF3.5+、Safari5.0+、Chrome5.0+、Opera10.6+、IPhone3.0+、Android2.0+
Geolocation API存在于navigator对象中,只包含3个方法:

复制代码
代码如下:

1、getCurrentPosition //当前位置
2、watchPosition //监视位置
3、clearWatch //清除监视
navigator.geolocation.getCurrentPosition( … , function(error){
switch(error.code){
case error.TIMEOUT :
alert( " 连接超时,请重试 " );
break;
case error.PERMISSION_DENIED :
alert( " 您拒绝了使用位置共享服务,查询已取消 " );
break;
case error.POSITION_UNAVAILABLE :
alert( " ,抱歉,暂时无法为您所在的星球提供位置服务 " );
break;
}
});

watchPosition像一个追踪器与clearWatch成对。
watchPosition与clearWatch有点像setInterval和clearInterval的工作方式。
var watchPositionId = navigator.geolocation.watchPosition(success_callback, error_callback, options);
navigator.geolocation.clearWatch(watchPositionId );

HTML 5提供了地理位置等一系列API可以给用户使用,方便用户制作LBS的地理应用,首先在支持HTML 5的浏览器中,当开启API时,会询问是否用户同意使用api,否则不会开启的,保证安全。
1、开启,判断是否浏览器支持LBS api

复制代码
代码如下:

function isGeolocationAPIAvailable()
{
var location = "No, Geolocation is not supported by this browser.";
if (window.navigator.geolocation) {
location = "Yes, Geolocation is supported by this browser.";
}
alert(location);
}

上面的例子中,还在displayError方法中,捕捉了异常;
2、获得用户的地理位置
这个使用getCurrentPosition就可以了;

复制代码
代码如下:

function requestPosition() {
if (nav == null) {
nav = window.navigator;
}
if (nav != null) {
var geoloc = nav.geolocation;
if (geoloc != null) {
geoloc.getCurrentPosition(successCallback);
}
else {
alert("Geolocation API is not supported in your browser");
}
}
else {
alert("Navigator is not found");
}
}

当获得地理位置成功后,会产生一个回调方法了,处理返回的结果,

复制代码
代码如下:

function setLocation(val, e) {
document.getElementById(e).value = val;
}
function successCallback(position)
{
setLocation(position.coords.latitude, "latitude"); setLocation(position.coords.longitude, "longitude");
}

3、一个很常见的问题,是如何跟踪用户不断变化的地理位置,这里小结下其中用到的两个api
1 watchPosition
例子如下:

复制代码
代码如下:

function listenForPositionUpdates() {
if (nav == null) {
nav = window.navigator;
}
if (nav != null) {
var geoloc = nav.geolocation;
if (geoloc != null) {
watchID = geoloc.watchPosition(successCallback);
} else {
alert("Geolocation API is not supported in your browser");
}
} else {
alert("Navigator is not found");
}
}

然后在successCallback中,就可以设置显示最新的地理位置:

复制代码
代码如下:

function successCallback(position){
setText(position.coords.latitude, "latitude"); setText(position.coords.longitude, "longitude");
}

如果不希望实时跟踪,则可以取消之:
function clearWatch(watchID) {
window.navigator.geolocation.clearWatch(watchID);
}
4、如何处理异常
当遇到异常时,可以捕捉之:

复制代码
代码如下:

if (geoloc != null) {
geoloc.getCurrentPosition(successCallback, errorCallback);
}
function errorCallback(error) {
var message = "";
switch (error.code) {
case error.PERMISSION_DENIED:
message = "This website does not have permission to use "
+ "the Geolocation API";
break;
case error.POSITION_UNAVAILABLE:
message = "The current position could not be determined.";
break;
case error.PERMISSION_DENIED_TIMEOUT:
message = "The current position could not be determined "
+ "within the specified timeout period.";
break;
}
if (message == "") {
var strErrorCode = error.code.toString();
message = "The position could not be determined due to "
+ "an unknown error (Code: " + strErrorCode + ").";
}
alert(message);
}

5、 在google 地图上显示位置(前提是有google map api等设置好)

复制代码
代码如下:

function getCurrentLocation()
{
if (navigator.geolocation)
{
navigator.geolocation.getCurrentPosition(showMyPosition,showError);
}
else
{
alert("No, Geolocation API is not supported by this browser.");
}
}
function showMyPosition(position)
{
var coordinates=position.coords.latitude+","+position.coords.longitude;
var map_url="http://maps.googleapis.com/maps/api/staticmap?center="
+coordinates+"&zoom=14&size=300x300&sensor=false";
document.getElementById("googlemap").innerHTML="html5中地理位置定位api接口开发应用小结_html5教程技巧";
}
function showError(error)
{
switch(error.code)
{
case error.PERMISSION_DENIED:
alert("This website does not have permission to use the Geolocation API")
break;
case error.POSITION_UNAVAILABLE:
alert("The current position could not be determined.")
break;
case error.TIMEOUT:
alert("The current position could not be determined within the specified time out period.")
break;
case error.UNKNOWN_ERROR:
alert("The position could not be determined due to an unknown error.")
break;
}
}
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1665
14
CakePHP 教程
1424
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
如何修改抖音IP属地 如何修改抖音IP属地 May 04, 2024 pm 04:36 PM

是的,您可以修改抖音 IP 属地,方法如下:打开抖音,编辑个人资料。修改城市信息,选择您要显示的城市或地区。注销并重新登录,使修改生效。

高德地图是不是要手机注册 高德地图是不是要手机注册 May 05, 2024 pm 05:12 PM

是的,为了安全保障、个性化服务和账号管理,高德地图需要使用手机号码注册。注册步骤包括:打开高德地图应用,点击“我的”和“登录/注册”,选择手机号码注册,输入手机号码获取验证码,设置密码即可完成注册。

微博怎么发图片和视频一起 微博怎么发图片和视频一起 May 03, 2024 am 01:15 AM

微博同时发布图片和视频的操作步骤如下:选择相关或互补的图片和视频。打开微博客户端并点击发布按钮。选择「图片和视频」选项卡。添加图片和视频(最多9张图片及1个视频)。输入文字内容并添加相关信息。发布即可。

抖音的IP地址是怎么显示的?IP地址显示的是实时位置吗? 抖音的IP地址是怎么显示的?IP地址显示的是实时位置吗? May 02, 2024 pm 01:34 PM

用户在抖音不仅可以观看各种有趣的短视频,还可以发布自己拍摄的作品,与全国乃至全球的网友互动。在这个过程中,抖音的IP地址显示功能引起了广泛关注。一、抖音的IP地址是怎么显示的?抖音的IP地址显示功能主要是通过地理位置定位服务实现的。当用户在抖音上发布或观看视频时,抖音会自动获取用户的地理位置信息。这一过程主要分为以下几个步骤:首先,用户启用抖音应用程序并允许应用程序访问其地理位置信息;其次,抖音使用定位服务获取用户的地理位置信息;最后,抖音将用户的地理位置信息与其发布或观看的视频数据相关联,并将

抖音推荐怎么重新设置?如何把推荐改为精选? 抖音推荐怎么重新设置?如何把推荐改为精选? May 08, 2024 pm 03:52 PM

抖音作为一个以短视频为主的社交平台,推荐算法是其核心功能之一。它能够根据用户的兴趣和行为,推荐相关的视频内容。有时用户可能想要重新设置推荐算法,以获得更符合自己喜好的内容。那么,抖音推荐怎么重新设置?抖音如何把推荐改为精选?本文将为您解答这两个问题。一、抖音推荐怎么重新设置?1.打开抖音APP,进入个人主页。2.点击右上角的“设置”图标,进入设置页面。3.在设置页面,找到“推荐管理”选项,点击进入。4.在推荐管理页面,你可以看到自己的兴趣标签和兴趣偏好。你可以根据自己的喜好,选择或取消选择不同的

抖音如何修改位置权限 抖音如何修改位置权限 May 03, 2024 pm 11:24 PM

修改抖音位置权限的步骤:1. 打开抖音应用,点击“我”。2. 点击右上角的“三横杠图标”。3. 选择“设置”。4. 找到“隐私设置”,并点击。5. 点击“定位服务”。6. 根据需要选择“允许使用定位”或“仅在使用时询问”。7. 修改后需重启抖音应用才能生效。

抖音如何更改推荐设置 抖音如何更改推荐设置 May 04, 2024 am 12:06 AM

可以通过更改“内容偏好”设置来更改抖音推荐,包括调整推荐视频类型、关注感兴趣的创作者、屏蔽不喜欢的内容、设置视频语言、地理位置限制、热门话题关注和清除搜索/浏览记录。

如何更改抖音时区设置 如何更改抖音时区设置 May 04, 2024 am 01:57 AM

无法更改抖音时区设置,时区将基于当前地理位置自动设置。

See all articles