3

我有一个地图和搜索框实例化并在搜索完成后删除一个标记。这工作正常,但是,我想查询位置服务以获取附近放置我的标记的位置,并且在运行时出现错误:google.maps.places.PlacesService(map) Uncaught TypeError: undefined is not a功能...

以下是我的 Angular.module.config 中的一些相关代码:

uiGmapGoogleMapApiProvider.configure({
  v: '3.17',
  libraries: 'places'
});

在我的地图控制器中:

1) 加载时回调

uiGmapGoogleMapApi.then(function(maps) {
  $scope.googleMapsObject = maps;
});

2)设置事件处理程序以创建标记

$scope.searchbox = {
  events: {
      places_changed: placesChangedHandler
  }
}

3) 处理地点改变时,设置标记为 lat,(LAST LINE IS THE PROBLEM) 查询地点名称。

function placesChangedHandler(searchBox) {
  var lat = searchBox.getPlaces()[0].geometry.location.k;
  var lgn = searchBox.getPlaces()[0].geometry.location.C;
  var center = { latitude: lat , longitude: lgn };
  $scope.address = searchBox.getPlaces()[0].adr_address;
  $scope.map = {
    center: center, zoom: 15
  };
  setMarker(center);
  var service = new google.maps.places.PlacesService($scope.googleMapsObject); 
 // service.nearbySearch(request, callback);
}

错误在倒数第二行。(另外,有没有更简洁的方法来获取这些变量?)

在此先感谢您的帮助!

4

3 回答 3

0

我最近遇到了同样的问题,因为我是 Angular 的新手(老实说我是 Java Script 的新手;),所以我花了一些时间来理解出了什么问题。)

在您的控制器中,您需要添加$window依赖项来访问全局对象google。这是它的样子:

.controller('mapCtrl', ['$scope', '$window', 'uiGmapGoogleMapApi'
    , function($scope, $window, GoogleMapApi) {
  GoogleMapApi.then(function(map) {
    $scope.googleVersion = map.version;
    $scope.map = { center: { latitude: 59.9500, longitude: 10.7500 }, zoom: 11 };
    $scope.googleMapsObject = map

    var service = new $window.google.maps.places.PlacesService($scope.googleMapsObject);
  });
}])
于 2015-01-25T22:24:32.630 回答
0

我认为问题是您试图在“地图”返回值(即 google.maps 对象)上加载位置服务。

所以:

$scope.googleMapsObject == google.maps

您需要的是使用标记指令(我还没有尝试过)或继续您的地图的实际地图对象,您可以从 tilesLoaded 事件中获得。

$scope.map = {
   events: {
     tilesloaded: function (map) {
        $scope.$apply(function () {
            $scope.actualMapObj = map;
            $log.info('this is the map instance', map);
        });
     }
   }
}

瓦片从常见问题解答: http ://angular-ui.github.io/angular-google-maps/#!/faq

于 2015-04-22T06:29:32.597 回答
0

使用“places”作为库对其进行初始化后,您应该在 api 参数中拥有 places 属性

uiGmapGoogleMapApi.then(function(maps) {
  maps.places.PlacesService() // -> here you can search for something
});

于 2015-08-16T21:03:30.467 回答