使用 Google 地图进行地理定位无法使用 PhoneGap

Posted

技术标签:

【中文标题】使用 Google 地图进行地理定位无法使用 PhoneGap【英文标题】:Geolocation with Google Maps not working using PhoneGap 【发布时间】:2012-07-27 16:47:04 【问题描述】:

我正在使用 Phonegap (cordova-2.0.0),并且我已将 cordova-2.0.0.js 与我的其他文件一起放在 assets/www 目录中,我已将 cordova-2.0.0.jar 放在引用的库中.我在 android 清单和 config.xml 中添加了所需的代码。我制作了一个名为“storelocation.html”的 html 文件,我希望该文件获取用户的当前坐标并将其传递到 Google 地图中,这将使这些坐标位于地图的中心。我不确定这个文件中的代码有什么问题,有人可以检查一下我是否只是愚蠢吗?

<!DOCTYPE html "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>

<title>Device Properties Example</title>

<script type="text/javascript" charset="utf-8" src="cordova-2.0.0.js"></script>
<script src="http://maps.google.com/maps?file=api&amp;v=2&amp;key=AIzaSyBlNOgoh-8Xg9_OYqUUxReMJZk4syLFayM&sensor=true"type="text/javascript"></script>
<script type="text/javascript">

// Wait for Cordova to load

document.addEventListener("deviceready", onDeviceReady, false);

// Cordova is ready
//
function onDeviceReady() 
navigator.geolocation.getCurrentPosition(onSuccess, onError,         enableHighAccuracy:true );


// onSuccess Geolocation
//
/* function onSuccess(position) 
    var element = document.getElementById('geolocation');
    element.innerHTML = 'Latitude: '           + position.coords.latitude              +   '<br />' +
                        'Longitude: '          + position.coords.longitude             + '<br />' +
                        'Altitude: '           + position.coords.altitude              + '<br />' +
                        'Accuracy: '           + position.coords.accuracy              + '<br />' +
                        'Altitude Accuracy: '  + position.coords.altitudeAccuracy      + '<br />' +
                        'Heading: '            + position.coords.heading               + '<br />' +
                        'Speed: '              + position.coords.speed                 + '<br />' +
                        'Timestamp: '          +                                   position.timestamp          + '<br />';
 

// onError Callback receives a PositionError object
//
function onError(error) 
    alert('code: '    + error.code    + '\n' +
          'message: ' + error.message + '\n');
 */
            var element = document.getElementById('geolocation');


function initialize() 
if (GBrowserIsCompatible()) 
var map = new GMap2(document.getElementById("map_canvas"));
map.setCenter(new GLatLng(position.coords.latitude, position.coords.longitude), 13);
map.setUIToDefault();






</script>
</head>
<body onload="initialize()" onunload="GUnload()">
<div id="map_canvas" style="width: 500px; height: 300px"></div>
</body>
</html>

非常感谢,如果你们中的一个天才可以帮助我,我真的很感激,我已经尝试了 2 天来看看出了什么问题。顺便说一句,找不到用户的坐标,找到它们的唯一方法(我发现)是使用 telnet 使用 geo fix,但我希望手机找到坐标而不是我。

【问题讨论】:

【参考方案1】:

你好,我基本上和你在尝试同样的事情。谷歌地图上的地理位置与phonegap。

您能否澄清一下: “顺便说一句,找不到用户的坐标,找到它们的唯一方法(我发现)是使用 telnet 使用地理修复,但我希望手机找到坐标而不是我。”

一台电脑显然没有 GPS,因此要在您的模拟器上工作,您需要模拟(假)GPS 坐标。

您是否已将谷歌地图添加到白名单权限?

链接到我的帖子Phone gap geolocation with google maps 虽然我正在使用其他代码,但我正在尝试完成相同的操作。

【讨论】:

【参考方案2】:

请注意您使用的是 Google Api SDK 而不是 Android SDK。 检查 eclipse 你的构建路径 => 配置构建路径 => 点击 Android 并选择例如 Google Api 2.3.3 / 10。

【讨论】:

以上是关于使用 Google 地图进行地理定位无法使用 PhoneGap的主要内容,如果未能解决你的问题,请参考以下文章

谷歌地图是不是只使用我的 IP 进行地理定位?

使用 Google maps API 和 Google text Search 进行地理定位

如何使用已加载 KML 图层的动态 Google 地图上的按钮激活地理定位?

使用谷歌地图地理定位 api 进行准确的地理定位

使用 Ionic 进行谷歌地图和地理定位:对象不是函数

地理定位后 google maps addlistener 点击 stop working