Переместить google map center javascript api
В моем проекте я хочу переместить центр карты в новые координаты. Это код, который у меня есть для карты
function initialize() {
var mapOptions = {
center: new google.maps.LatLng(0, 0),
zoom: 4,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map_canvas"),
mapOptions);
}
function moveToLocation(lat, lng){
var center = new google.maps.LatLng(lat, lng);
var map = document.getElementById("map_canvas");
map.panTo(center);
}
Функция moveToLocation вызывается, но карта не центрируется. Любая идея, что мне не хватает?
Ответы
Ответ 1
Ваша проблема заключается в том, что в moveToLocation
вы используете document.getElementById
, чтобы попытаться получить объект Map
, но это приведет только к элементу HTMLDivElement
, а не к элементу google.maps.Map
, который вы ожидаете. Таким образом, ваша переменная Map
не имеет функции panTo
, поэтому она не работает. То, что вам нужно, - это белка Map
где-то где-то, и она должна работать так, как планировалось. Вы можете просто использовать глобальную переменную следующим образом:
var map; // global variable
function initialize() {
var mapOptions = {
center: new google.maps.LatLng(0, 0),
zoom: 4,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
// assigning to global variable:
map = new google.maps.Map(document.getElementById("map_canvas"),
mapOptions);
}
function moveToLocation(lat, lng){
var center = new google.maps.LatLng(lat, lng);
// using global variable:
map.panTo(center);
}
См. здесь рабочий jsFiddle: http://jsfiddle.net/fqt7L/1/
Ответ 2
Отобразить API Карт Google динамически, получить данные в базе данных, чтобы отобразить место, lat, long и показать маркер карты в центре с помощью AngularJS. Сделано Сурешаном...
![Снимок экрана с Google Maps]()
$(function() {
$http.get('school/transport/scroute/viewRoute?scRouteId=' + scRouteId).success(function(data) {
console.log(data);
for (var i = 0; i < data.viewRoute.length; i++) {
$scope.view = [];
$scope.view.push(data.viewRoute[i].stoppingName, data.viewRoute[i].latitude, data.viewRoute[i].longitude);
$scope.locData.push($scope.view);
}
var locations = $scope.locData;
var map = new google.maps.Map(document.getElementById('map'), {
mapTypeId : google.maps.MapTypeId.ROADMAP
});
var infowindow = new google.maps.InfoWindow();
var bounds = new google.maps.LatLngBounds();
var marker, j;
for (j = 0; j < locations.length; j++) {
marker = new google.maps.Marker({
position : new google.maps.LatLng(locations[j][1], locations[j][2]),
map : map
});
google.maps.event.addListener(marker, 'click', (function(marker, j) {
bounds.extend(marker.position);
return function() {
infowindow.setContent(locations[j][0]);
infowindow.open(map, marker);
map.setZoom(map.getZoom() + 1);
map.setCenter(marker.getPosition());
}
})(marker, j));
};
map.fitBounds(bounds);
});
});