cordova+vue+webapp使用html5获取地理位置的方法


Posted in Javascript onJuly 06, 2019

1.在HTML5中使用Geolocation.getCurrentPosition()方法来获取地理位置。

语法:

navigator.geolocation.getCurrentPosition(success, error, options)

参数:

  •  success: 成功得到位置信息时的回调函数,使用Position 对象作为唯一的参数。
  • error: 获取位置信息失败时的回调函数,使用 PositionError 对象作为唯一的参数,这是一个可选项。
  • options:一个可选的PositionOptions 对象,包含以下3个参数。
    • enableHighAccuracy 是一个Boolean值,用来表明应用是否使用其最高精度来表示结果,默认为false。
    • timeout 是一个正的long值,表明的是设备必须在多长时间(单位毫秒)内返回一个位置,默认是Infinity。
    • maximumAge 是一个正的long值,表明可以返回多长时间(即最长年龄,单位毫秒)内的可获取的缓存位置。如果设置为 0,说明设备不能使用一个缓存位置,而且必须去获取一个真实的当前位置。如果设置为 Infinity ,那么不管设置的最长年龄是多少,设备都必须返回一个缓存位置。默认值:0

2.success - 成功得到位置信息时的回调函数

navigator.geolocation.getCurrentPosition(function(position)) {
  // 获取成功时的的处理
  //参数position是地理位置对象
}

position中返回的信息如下图:

cordova+vue+webapp使用html5获取地理位置的方法

  • accuracy 获取到的纬度或者经度的精度(以米为单位)
  • altitude 当前地理位置的海拨高度(不能获取为null)
  • altitudeAccurancy 获取到的海拨高度的经度(以米为单位)
  • heading 设备移动的方向(以度为单位)
  • latitude 当前地理位置的纬度
  • longitude 当前地理位置的经度
  • speed 设备的前进速度(以米/秒为单位,不能获取时为null)
  • timestamp 获取地理位置信息时的时间

3.error - 获取位置信息失败时的回调函数

navigator.geolocation.getCurrentPosition(function(position){
   // 获取成功时的的处理;
  //参数position是地理位置对象
},function(error)) {
  // 获取失败时的的处理;
}

error中返回的信息如下图

cordova+vue+webapp使用html5获取地理位置的方法

code属性有以下值:

- 1 地理位置信息的获取失败,因为该页面没有获取地理位置信息的权限。
- 2 地理位置获取失败,因为至少有一个内部位置源返回一个内部错误。
- 3 获取地理位置超时,通过定义PositionOptions.timeout 来设置获取地理位置的超时时长。

message 返回一个开发者可以理解的 DOMString 来描述错误的详细信息。

4.使用Geolocation.getCurrentPosition()注意事项:

  1. 本地项目中在Chrome浏览器中运行时,无法获取到经纬度信息,原因是Chrome已不再支持非安全域的
  2. 浏览器定位请求,只有在https下才可使用定位。在IE、Eage、Firefox下亲测可以获取的经纬度信息。获取到的GPS经纬度信息在百度地图展示位置会与实际位置不同,是因为百度对外接口的坐标系为BD09
  3. 坐标系,并不是GPS采集的真实经纬度,在使用百度地图JavaScript API服务前,需先将非百度坐标通过坐标转换接口转换成百度坐标。(转换方法详见下文)

5.使用Geolocation.getCurrentPosition()获取经纬度信息,并转换为百度坐标并进行逆地址解析:

以Vue项目为例,首先根目录index.html中引入百度API文件,如下图:

cordova+vue+webapp使用html5获取地理位置的方法

获取位置,标记marker并进行逆地址解析代码如下:

// 1 查询当前位置信息
    getPosition() {
      navigator.geolocation.getCurrentPosition(this.getPositionSuccess, this.getPositionError, {"enableHighAccuracy": true, "timeout": 5000, "maximumAge": 5000})
    },
    // 1-1 查询当前位置信息成功
    getPositionSuccess(position) {
      this.latitude = String(position.coords.latitude)
      this.longitude = String(position.coords.longitude)
      let ggPoint = new BMap.Point(this.longitude, this.latitude)
      let pointArr = []
      pointArr.push(ggPoint)
      let convertor = new BMap.Convertor()
      // 坐标转换
      convertor.translate(pointArr, 1, 5, this.translateCallback)
    },
    // 1-2 查询当前位置信息失败
    getPositionError(error) {
      this.$toast({
        message: `获取地理位置失败请重试~`,
        duration: 1000
      })
    },
     // 坐标转换回调
    translateCallback(data) {
      if (data.status === 0) {
        // 在地图上标注marker
        let marker = new BMap.Marker(data.points[0])
        map.addOverlay(marker)
        map.panTo(data.points[0])
        // 逆地址解析
        let myGeo = new BMap.Geocoder()
        let that = this
        myGeo.getLocation(data.points[0], function(result){   
          if (result){
            // 获取逆地址解析结果
            that.clockSite = result.address
          }   
        })
      }
    },

坐标转换convertor.translate()方法说明:

语法:

convertor.translate(coords, from, to, fn)

参数:

  • coords:需转换的源坐标
  • from: 源坐标类型 详见:[类型详情][4]
  • to: 目标坐标类型 详见:[类型详情][5]
  • fn: 转换结果回调

6.使用cordova+vue开发webapp中定位解决方法:

在cordova中安装Geolocation插件后,方可在生成的app中获取到地理位置信息,运行如下命令即可:

cordova plugin add cordova-plugin-geolocation

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
经常用到的JavasScript事件的翻译
Apr 09 Javascript
javaScript面向对象继承方法经典实现
Aug 20 Javascript
jquery div拖动效果示例代码
Dec 08 Javascript
js中reverse函数的用法详解
Dec 26 Javascript
jQuery 删除/替换DOM元素的几种方式
May 20 Javascript
jquery插件jSignature实现手动签名
May 04 Javascript
javascript匀速运动实现方法分析
Jan 08 Javascript
HTML5游戏引擎LTweenLite实现的超帅动画效果(附demo源码下载)
Jan 26 Javascript
Node.js中文件操作模块File System的详细介绍
Jan 05 Javascript
jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一
May 26 jQuery
将Vue组件库更换为按需加载的方法步骤
May 06 Javascript
Vue+scss白天和夜间模式切换功能的实现方法
Jan 05 Vue.js
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
Jul 06 #Javascript
vue router总结 $router和$route及router与 router与route区别
Jul 05 #Javascript
基于vue实现圆形菜单栏组件
Jul 05 #Javascript
vue 使用axios 数据请求第三方插件的使用教程详解
Jul 05 #Javascript
vue中实现Monaco Editor自定义提示功能
Jul 05 #Javascript
VueCli3.0中集成MockApi的方法示例
Jul 05 #Javascript
Electron vue的使用教程图文详解
Jul 05 #Javascript
You might like
php 处理上百万条的数据库如何提高处理查询速度
2010/02/08 PHP
PH P5.2至5.5、5.6的新增功能详解
2014/07/14 PHP
php相对当前文件include其它文件的方法
2015/03/13 PHP
PHP实现递归无限级分类
2015/10/22 PHP
Zend Framework基本页面布局分析
2016/03/19 PHP
PHP之十六个魔术方法详细介绍
2016/11/01 PHP
对象的类型:本地对象(1)
2006/12/29 Javascript
JavaScript之Getters和Setters 平台支持等详细介绍
2012/12/07 Javascript
js动态创建上传表单通过iframe模拟Ajax实现无刷新
2014/02/20 Javascript
DOM节点的替换或修改函数replaceChild()用法实例
2015/01/12 Javascript
angularJS中router的使用指南
2015/02/09 Javascript
深入学习JavaScript中的Rest参数和参数默认值
2015/07/28 Javascript
深入浅析JavaScript面向对象和原型函数
2016/02/06 Javascript
[原创]JQuery 在表单提交之前修改 提交的值
2016/04/14 Javascript
JavaScript的MVVM库Vue.js入门学习笔记
2016/05/03 Javascript
Bootstrap Table使用心得总结
2016/11/29 Javascript
详解微信小程序 wx.uploadFile 的编码坑
2017/01/23 Javascript
微信小程序 页面跳转传值实现代码
2017/07/27 Javascript
vue-lazyload使用总结(推荐)
2018/11/01 Javascript
Vue指令指令大全
2019/02/09 Javascript
JS实现瀑布流效果
2020/03/07 Javascript
安装Python的web.py框架并从hello world开始编程
2015/04/25 Python
Python常用字符串替换函数strip、replace及sub用法示例
2018/05/21 Python
django 解决manage.py migrate无效的问题
2018/05/27 Python
Python爬虫之正则表达式基本用法实例分析
2018/08/08 Python
python爬虫爬取幽默笑话网站
2019/10/24 Python
Python对Tornado请求与响应的数据处理
2020/02/12 Python
Pandas中DataFrame交换列顺序的方法实现
2020/12/14 Python
CSS教程:CSS3圆角属性
2009/04/02 HTML / CSS
匡威西班牙官网:Converse西班牙
2019/10/01 全球购物
运动鞋、街头服装、手表和手袋的实时市场:StockX
2020/11/25 全球购物
个人现实表现材料
2014/02/04 职场文书
电话客服专员岗位职责
2014/06/28 职场文书
学校运动会报道稿
2014/09/23 职场文书
党员电教片《信仰》心得体会
2016/01/15 职场文书
Python写情书? 10行代码展示如何把情书写在她的照片里
2022/04/21 Python