【发布时间】:2018-01-03 09:47:33
【问题描述】:
我试图在一个简单的谷歌地图上获得几个标记。我正在使用使用 Angular 4 的 Ionic 3。
我正在像这样加载地图:
import { Component, ViewChild, ElementRef } from '@angular/core';
import { GoogleMaps } from '@ionic-native/google-maps';
declare var google;
export class SearchResultsPage extends BasePage {
@ViewChild('map') mapElement: ElementRef;
private map: any;
constructor(public navCtrl: NavController,
public navParams: NavParams,
private translateService: TranslateService,
private googleMaps: GoogleMaps) {}
ionViewDidLoad() {
setTimeout(()=>{
this.loadMap();
}, 1000)
}
loadMap() {
let latLng = new google.maps.LatLng(48.8509695, 2.3861870000000636);
let latLng2 = new google.maps.LatLng(48.8504541, 2.3865487000000485);
let mapOptions = {
center: latLng,
zoom: 15,
mapTypeId: google.maps.MapTypeId.ROADMAP
}
this.map = new google.maps.Map(this.mapElement.nativeElement, mapOptions);
var marker = new google.maps.Marker({
position: latLng,
map: this.map,
title: 'Hello World!'
},{
position: latLng2,
map: this.map,
title: 'Check the World!'
});
}
我找到了这个(但不起作用)
addMarkers(data, callback) {
var markers = [{
'position': {
lat: 48.8513735,
lng: 2.3861292
},
'icon': '#ff0000'
}];
function onMarkerAdded(marker) {
console.log(marker);
markers.push(marker);
if (markers.length === data.length) {
callback(markers);
} else {
console.log('in the else');
}
}
data.forEach(function(markerOptions) {
console.log('in foreach');
this.map.addMarker(markerOptions, onMarkerAdded);
});
}
地图正在显示,但我没有成功添加标记。
我尝试遵循官方文档(v1 和 v2),但它不起作用。如果有人有想法,请提前致谢。我看到很多人都在尝试做同样的事情,但每个代码都不一样..
【问题讨论】:
-
有什么问题?地图不显示或您无法添加标记?如果地图未显示,您是否为包含地图的 div 设置了正确的样式?
-
抱歉,我编辑了我的问题。地图正在显示,但我无法成功显示标记
-
您附加的代码中没有任何可以加载标记的内容。你能不能把它也加进去,让我们看看发生了什么。
-
是的,因为我尝试的方法不起作用。我会在 2 分钟内修改问题。
-
您是否可以添加我在答案中提到的单个标记?
标签: angular google-maps ionic-framework ionic3