注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

snoopyxdy的博客

https://github.com/DoubleSpout

 
 
 

日志

 
 

phonegap利用百度地图sdk定位  

2014-05-20 21:07:39|  分类: phone |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
近期的一个phonegap项目把我做的焦头烂额,最让人蛋疼的就是安卓4.1.x对html5的定位获取经纬度有个无比巨大的坑,一般我们利用如下代码进行html5的定位
navigator.geolocation.getCurrentPosition(function(pos){
            alert(JSON.stringify(pos))
        },function(err){
               alert(JSON.stringify(err))
          }, {
enableHighAccuracy: false,
timeout: 60*1000,
maximumAge: 1000*60*10
});

上述代码在ios上一切正常,在安卓4.3及以后的机器也可以正常访问,但是在安卓4.1上就会出现timeout,如果我们把 enableHighAccuracy 设置为 true,那么在室外,空气良好的地方,安卓4.1将能够通过卫星进行定位,但是速度巨慢,其实我们很多时候并不是想要非常精准的定位信息,完全可以通过基站或者wifi来定位,虽然html5提供给了我们这样的接口,但是安卓4.1上支持的不是很好。

另外一个巨坑也直接影响了我对这个问题的判断,如果我重启了安卓4.1的机器,那么上述代码将能够正常跑大约几小时,甚至半天,可是到了第二天又会出现同样的问题,无尽的timeout。总不能让客户每次使用定位功能都重启一次机器吧,涉及这个问题的机器有包括我的华为,三星note2,oppo等目前主流的安卓4.1系统的机子,在另外几台例如glasky3、红米等安卓4.3的机器上没有出现。

然后我直接将上述代码在浏览器中运行,发现安卓4.1也是无法跑起来,天真的我以为是安卓4.1对html5的接口支持问题,于是利用cordova加载geolocation插件,想利用cordova的native方法解决这个问题,但是问题依旧,其中意外的发现我的华为和note2能够跑起来了,其实只不过碰巧刚重启过而已。

这个是我在stackoverflow上发的问题,碰到这类问题的中外友人巨多。

如何填补这个坑呢?我搜遍了整个网络,发现国外可以使用google地图来解决,而国内只有使用百度的定位SDK来解决了,不过最新的安卓百度定位SDK4.1同样巨坑无比,直接下载官方的demo跑在真机上各种无法定位,一直报errorcode 602,于是逛了下百度SDK的论坛,发现很多人说4.1版本的SDK问题很多,不如用回4.0版本,于是我报着试试看的心情用回了SDK4.0版本,最终在安卓4.1的机器上定位成功,不存在需要重启的情况,然后我根据 andybuit 作者的代码,小幅改动,封装成支持新版 cordova 3.4.1 的插件放在github上,供碰到同样问题的朋友使用,希望能够帮助到他们。再次感谢 andybuit 提供的百度定位代码,谢谢!

新版本插件地址:

下面步入正题,通过一个简单的安卓 hello world 程序来运用百度定位插件
1、建立 hello world 项目:

cordova create hello com.example.hello HelloWorld

2、建立安卓支持,目前本插件只支持安卓,似乎也只要支持安卓,ios对html5的定位支持的非常好,无须百度定位SDK

cordova platform add android

3、安装 baidu 定位的插件:
可以通过git来下载远程的,需要安装git命令
 cordova plugin add https://github.com/DoubleSpout/phonegap_baidu_sdk_location.git
也可以将插件下载到 hello\plugins 目录下,文件夹重命名为 com.spout.phonegap.plugins.baidulocation,然后执行命令:

cordova plugin install com.spout.phonegap.plugins.baidulocation

4、插件安装完成之后,执行一次 build 命令,将插件的配置文件写入安卓平台目录:

cordova build android

5、打开eclipse,对hello项目进行配置:

5.1、新建工程
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.2、从已有代码库添加
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.3、找到安卓的项目路径
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.4、编辑项目属性
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.5、添加百度sdk的jar文件
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.6、选择locSDK
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.7、编辑source 附件
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.8、同样选择百度sdk的jar
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.9、保存路径
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.10、选择order and export 将前面全部打勾
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.11、将文本编辑编码改为utf-8
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
5.12、打开 hello\platforms\android\src\com\spout\phonegap\plugins\baidulocation\BaiduLocation.java 文件,修改自己的apkkey(其实不修改也能使用),大约在64行:
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客

key的生成和获取详见百度sdk的key获取页面,地址:

6、找到 hello\www\js\index.js 文件,修改并增加如下几行,通过百度SDK获取经纬度:

onDeviceReady: function() {
app.receivedEvent('deviceready');

//通过百度sdk来获取经纬度,并且alert出经纬度信息
var noop = function(){}
window.locationService.getCurrentPosition(function(pos){
alert(JSON.stringify(pos))
window.locationService.stop(noop,noop)
},function(e){
alert(JSON.stringify(e))
window.locationService.stop(noop,noop)
});
},



7、完成上述工作后,执行命令打包生产APK,注意百度定位的SDK在模拟器上是无法运行的,会曝出167错误码

cordova build android


8、将 hello\platforms\android\ant-build\HelloWorld-debug-unaligned.apk 文件拷贝到之前有问题的安卓4.1的机器上,显示如下图,通过wifi成功快速获取到经纬度信息,再也不用重启机子了:
phonegap利用百度地图sdk定位 - snoopyxdy - snoopyxdy的博客
 
至此百度SDK说明完毕,希望能够帮助到利用phonegap开发安卓应用,又碰到我这样问题的朋友~

  评论这张
 
阅读(17134)| 评论(49)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016