我想制作一个应用程序,它需要我获取我的位置并将其显示在谷歌地图上。我使用了来自http://wiki.phonegap.com/w/page/16494764/PhoneGap%20Geolocation%20Sample%20Application的代码。我正在使用 phonegap 2.0.0 为 Android 2.2 开发。我正在使用模拟器 2.2。
我已经正确安装了 Phonegap 的所有内容,并且获得了地图的 google Api3 密钥。我把钥匙放在:http ://maps.google.com/maps/api/staticmap?center= (这里我放钥匙)。现在,当我启动应用程序时,我使用 CMD 发送坐标。Telnet 本地主机 5554、geo fix 等。当我启动应用程序时,它会给出一个错误:无法检索位置错误 [object PositionError]。
我不再收到错误消息(我添加了启用高精度)。但它也没有显示任何东西。所以我认为我在谷歌地图上做错了,或者我忘记了一些东西。
有人可以帮我吗?它在左上角显示一个问号。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta name="viewport" content="width=device-width; height=device-height; user-scalable=no" />
<meta http-equiv="Content-type" content="text/html; charset=utf-8">
<title>Beer Me</title>
<link rel="stylesheet" href="/master.css" type="text/css" media="screen" />
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=true"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script type="text/javascript" charset="utf-8" src="cordova-2.0.0.js"></script>
<script type="text/javascript">
function loader() {
var state = document.readyState;
if (state == 'loaded' || state == 'complete') {
run();
} else {
if (navigator.userAgent.indexOf('Browzr') > -1) {
setTimeout(run, 250);
} else {
document.addEventListener('deviceready',run,false);
}
}
}
function run() {
var imageUrl = "http://maps.google.com/maps/api/staticmap?sensor=false¢er=" + latitude + ',' + longitude +
"&zoom=14&size=300x400&markers=color:blue|label:S|" + latitude + ',' + longitude;
console.log("imageUrl-" + imageUrl);
$("#map").remove();
$(document.body).append(
$(document.createElement("img")).attr("src", imageUrl).attr('id', 'map')
);
var fail = function(e) {
alert('Can\'t retrieve position.\nError: ' + e);
};
navigator.geolocation.getCurrentPosition(imageUrl, fail,{ enableHighAccuracy: true });
}
</script>
</head>