javascript - phonegap 中的地理位置在模拟器上不起作用

标签 javascript html cordova geolocation

我是phonegap开发的新手。请帮助我摆脱以下问题。 我正在开发一个phonegap应用程序,我必须读取当前的地理位置坐标,并根据该坐标在 map 上显示地理位置。当我在浏览器中运行代码时,它工作正常,但是当我在模拟器或移动设备上运行应用程序时, map 上没有显示任何内容,白色屏幕代替 map 可见。

这是我的代码。请帮助我,

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">

        html { height: 100% }
        body { height: 100%; margin: 0; padding: 0 }
        #map_canvas { height: 100% width: 100%}

    </style>

    <script type="text/javascript"
            src="http://maps.googleapis.com/maps/api/js?key=AIzaSyA6YvhWQgns2SVExEys8V-WeVfxdQAIqVQ">
    </script>

    <script type="text/javascript">
  var lat  = 0;
  var long = 0;

  infowindow.open(map,marker);

function initGeolocation(){
  if( navigator.geolocation){
  // Call getCurrentPosition with success and failure callbacks
  //navigator.geolocation.getCurrentPosition( success, fail );
  navigator.geolocation.getCurrentPosition(success,fail,{enableHighAccuracy:true},{timeout:9000});

  }
  else{var long = position.coords.longitude;
  var lat = position.coords.latitude;
  alert("Sorry, your browser does not support geolocation services.");
  }
  }

function success(position)
  {

  var long = position.coords.longitude;
  var lat = position.coords.latitude;
  console.log('Coordinates: ' +position.coords);
  console.log('TimeStamp' + position.timestamp);

    var myOptions =
    {

  center: new google.maps.LatLng(lat,long),
  zoom: 12,
  mapTypeId: google.maps.MapTypeId.ROADMAP
    };

  var map = new google.maps.Map(document.getElementById("map_canvas"),myOptions);
  marker = new google.maps.Marker({
  position: new google.maps.LatLng(lat, long),
  map: map
  });
  }

  function fail()
  {
  console.log('error' +error.message);
  console.log('code' + error.code);
  alert("error");
  }

 </script>
    <div class="divImageHolder">
        <a href="menu.html" title="Mouseover Description"><img style="width: 20px; height: 20px; border: 0;" src="http://etc-mysitemyway.s3.amazonaws.com/icons/legacy-previews/icons/green-jelly-icons-media/003210-green-jelly-icon-media-a-media31-back.png" alt="Text Description"></a></div>
    </div>
</head>

<body onload="initGeolocation()">
<div id="map_canvas" style="width:100%; height:100%">

</div>
</body>
</html>

提前致谢。

最佳答案

您在模拟器中设置了地理位置吗?

指定模拟器中位置的坐标。

Eclipse -> 开放视角 -> DDMS -> 模拟器控制 -> 位置控制

指定位置坐标,然后按“发送”

引自[此处]PhoneGap. Failed to start Geolocation service

关于javascript - phonegap 中的地理位置在模拟器上不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26255002/

相关文章:

html - 防止 css border-image 属性拉伸(stretch)

cordova - 在 android WebView 中禁用电子邮件、号码检测

ios - PhoneGap Media API 无法覆盖 iPhone 设备上录制的音频

javascript - 具有 selectAll 焦点的 Contenteditable div 不能完全工作

javascript - 在 AngularJS 中顺序运行 $http 请求

javascript - Ajax表单提交两次

html - Angular Material ,如何在标签中添加粘性副标题

html - 如何将页脚推到页面底部但避免滚动条?

android - 需要获取捕获图像的当前方向

javascript - JqG​​rid 检查行是否被选中