基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能前言 由于项目需求需要在项目中实现手机端 基于网页 考勤打卡功能 最初考虑使用 H5 自身定位功能 但尝试过后 效果很不稳定 然后尝试使用百度地图 JsAPI 百度家的稳定倒是很稳定 没想到的是定位位置和实际位置居然相差几十公里 一开始是以为自己配置有问题 浪费了我大半天时间去找原因 最后发现他本身提供的 API 就是偏差很大距离的 他自己家的倒是定位很准 对外开放的 API 简直惨不忍睹 百度 API 浏

前言:

由于项目需求需要在项目中实现手机端(基于网页)考勤打卡功能,最初考虑使用H5自身定位功能,但尝试过后,效果很不稳定。然后尝试使用百度地图JsAPI,百度家的稳定倒是很稳定,没想到的是定位位置和实际位置居然相差几十公里,一开始是以为自己配置有问题,浪费了我大半天时间去找原因,最后发现他本身提供的API就是偏差很大距离的,他自己家的倒是定位很准,对外开放的API简直惨不忍睹。

百度API浏览器定位

高德API浏览器定位

然后换用高德去测试,高德开放的API精确度和百度地图是一样的,小伙伴可以亲自去体验下,难怪百度如今沦落到这样。。。

所以就决定使用高德API来进行定位了;

主要思路:利用高德API获取当前位置经纬度、设置考勤点经纬度、计算两点距离判断是否在考勤范围内。

高德JS API提供的浏览器定位接口,融合了HTML5 Geolocation定位接口、精确IP定位服务,以及安卓定位sdk定位。所以在定位上大大提高了精准度以及成功率。

效果如下:

基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

正文:

首先注册账号并申请Key

1. 首先,注册开发者账号,成为高德开放平台开发者

2. 登陆之后,在进入「应用管理」 页面「创建新应用」

3. 为应用添加 Key,「服务平台」一项请选择「 Web 端 ( JSAPI ) 

准备页面

1. 在页面添加 JS API 的入口脚本标签,并将其中「您申请的key值」替换为您刚刚申请的 key;

HTML

 

2. 添加div标签作为地图容器,同时为该div指定id属性;

HTML

 
  

3. 为地图容器指定高度、宽度;

CSS

#container {width:300px; height: 180px; } 

4. 进行移动端开发时,请在head内添加viewport设置,以达到最佳的绘制性能;

HTML

 
   
  

5. 在完成如上准备工作之后便可以开始进行开发工作了。

显示定位地图以及获取当前经纬度地址

 
   
    
     
     浏览器精确定位 
      
       
      


由于众多浏览器已不再支持非安全域的定位请求,为保位成功率和精度,请升级您的站点到HTTPS。

计算当前位置与考勤点距离

var signzone = [121.52625, 31.66925];//设置的签到点 console.log(signzone); //计算当前位置与考勤点距离 var distance = AMap.GeometryUtil.distance(getposition,signzone).toFixed(2); //document.getElementById('distance').innerHTML = distancestr; console.log(distance); if (distance <= 1000) { //在范围内 //数据操作 } else { //不在范围内 //数据操作 } 

绘制签到点范围 

//绘制签到范围 var circle = new AMap.Circle({ center: signzone, radius: 100, //签到范围半径 borderWeight: 1, strokeOpacity: 1, strokeOpacity: 0.2, fillOpacity: 0.4, }) circle.setMap(map) // 缩放地图到合适的视野级别 map.setFitView([ circle ]) var circleEditor = new AMap.CircleEditor(map, circle) 

基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

到这里定位打卡的基本功能就完成了,然后再加上一些判断,比如用户是否进入考勤范围这些等等,配合上后端数据操作就可以实现该需求了。

基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

最终页面效果如下:

基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

效果演示地址:https://www.eiun.net/tools/map/index.html

一些注意事项

定位一般分为两种场景:移动端和PC,下面分别讲下这两个场景在使用定位过程中的一些注意事项。

移动端

移动端包括手机,pad和其它带有GPS定位芯片的智能设备(如手表、音箱等),移动端的系统包括iOS和Android。成功完成定位需要达成以下前提条件:

  1. 系统GPS打开
  2. 所使用的App或浏览器已获取定位权限
  3. 对打开的页面允许使用定位
  4. 对于iOS10以上系统和Android的一些版本已禁止在非HTTPS协议的域名下定位,请尽快将站点升级到HTTPS

注意,以上只是定位成功的前提条件,满足这些并不一定等于可以成功定位,定位还与当前位置(室内会影响GPS信息)、手机信号和定位权限等因素影响。如果您在使用过程中定位失败,可以参考FAQ:Geolocation的定位流程以及定位失败的原因 ,将失败信息通过工单发送给我们,高德的工程师将协助您解决问题。

PC

因为pc设备上大都缺少GPS芯片,所以在PC上的定位主要通过IP精准定位服务,该服务的失败率在5%左右。

定位失败

如果定位失败或者遇到其它问题,请参考FAQ:Geolocation的定位流程以及定位失败的原因 

附上源代码:

Github地址:GitHub - iGaoWei/Amap-location: 基于高德地图JsAPI进行浏览器精确定位,实现手机端考勤打卡功能

第一次写GitHub,喜欢的小伙伴点个Star哦,本资料仅供参考,水平有限,难免存在纰漏错误之处,欢迎评论指正。

基于腾讯地图实现精准定位,实现微信小程序考勤打卡功能_DreamCoders的博客-CSDN博客

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/199280.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午1:27
下一篇 2026年3月26日 下午1:28


相关推荐

  • Python的random函数用法详解[通俗易懂]

    Python的random函数用法详解[通俗易懂]在random模块下提供了如下常用函数:random.seed(a=None,version=2):指定种子来初始化伪随机数生成器。random.randrange(start,stop[,stop]):返回从start开始到stop结束、步长为step的随机数。其实就相当于choice(range(start,stop,step))的效果,只不过实际底层并不生成区间对象。random.randint(a,b):生成一个范围为a≤N≤b的随机数。其等同于ra

    2022年4月30日
    120
  • 2021年最新idea激活注册码破解方法

    2021年最新idea激活注册码破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    75
  • 驼峰命名法总结

    驼峰命名法总结Java 语言讲究规范 好的编程习惯受益一生哦 nbsp nbsp nbsp nbsp 以下是我总结的关于驼峰命名法的一些内容 有些资料是网上查到整理的 nbsp nbsp nbsp 转自好搜百科 骆驼式命名法 Camel Case 又称驼峰命名法 是电脑程式编写时的一套命名规则 惯例 正如它的名称 CamelCase 所表示的那样 是指混合使用大小写字母来构成变量和函数的名字 程序员们为了自己的代码能更容易的在同行之

    2026年3月16日
    3
  • 史上最小白之RNN详解

    史上最小白之RNN详解1 前言网上目前已经有诸多优秀的 RNN 相关博客 但是我写博客的出发点主要是为了加深和巩固自己的理解 所以还是决定自己再进行一下总结和描述 如有不正确的地方欢迎指正 2 区分 RNN 循环神经网络 RecurrentNeu 递归神经网络 RecursiveNeu 你有没有发现他们的缩写都是 RNN 那他们两个是同一回事儿吗 网上有一些博客把这两就当

    2026年3月26日
    3
  • WPF 使用TextBox做密码输入框

    WPF 使用TextBox做密码输入框密码输入框需要输入的密码不能显示明文,用其他的特殊字符代替显示。显示效果如下:Xaml部分代码如下:

    2022年7月25日
    117
  • sin傅里叶变换公式_傅里叶变换公式(傅里叶变换常用公式)

    sin傅里叶变换公式_傅里叶变换公式(傅里叶变换常用公式)一般傅里叶变换与反变换的公式是成对儿给出的。1、如果正变换前有系数1/2*π,则反变换前无系数2、如果正变换前无系数,则反变换前有系数1/2*π3、正、反变换前.1.傅里叶正变换2.傅里叶逆变换常用的就可以了问题是我找不到教材书了啊大概最常用的输10个左右就ok了连续傅里叶变换一般情况下,若“傅立叶变换”一词的前面未加任何限定语,则指的是“连续傅里叶变换”。“连续傅里叶变换”将平方…

    2022年7月17日
    15

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号