手机屏幕中的地理位置无法在模拟器上运行

时间:2014-10-08 10:45:04

标签: javascript html5 cordova geolocation

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

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

<!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>

提前致谢。

1 个答案:

答案 0 :(得分:0)

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

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

Eclipse - &gt;开放视角 - &gt; DDMS - &gt;模拟器控制 - &gt;位置控制

指定位置的坐标,然后按&#34;发送&#34;

引自[Here] PhoneGap. Failed to start Geolocation service