【问题标题】:Multiple markers on Google Map with ionic 3带有离子3的谷歌地图上的多个标记
【发布时间】: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


【解决方案1】:
loadMap() {
let latLng = new google.maps.LatLng(48.8513735, 2.3861292);

let mapOptions = {
  center: latLng,
  zoom: 15,
  mapTypeId: google.maps.MapTypeId.ROADMAP
}

this.map = new google.maps.Map(this.mapElement.nativeElement, mapOptions);    

var locations = [
  ['Bondi Beach', -33.890542, 151.274856, 4],
  ['Coogee Beach', -33.923036, 151.259052, 5],
  ['Cronulla Beach', -34.028249, 151.157507, 3],
  ['Manly Beach', -33.80010128657071, 151.28747820854187, 2],
  ['Maroubra Beach', -33.950198, 151.259302, 1]
];

var infowindow = new google.maps.InfoWindow();

var marker, i;

for (i = 0; i < locations.length; i++) {  
  marker = new google.maps.Marker({
    position: new google.maps.LatLng(locations[i][1], locations[i][2]),
    map: map
  });

  google.maps.event.addListener(marker, 'click', (function(marker, i) {
    return function() {
      infowindow.setContent(locations[i][0]);
      infowindow.open(map, marker);
    }
  })(marker, i));
}
}

【讨论】:

  • 感谢您的回答。它工作得很好,但是当我添加另一个标记时,它似乎不存在。这两个标记应该在同一条街道上。我将更新代码,向您展示我是如何做到的。
  • 您不能在一次调用中创建多个标记。查看此答案以获取创建多个标记的示例代码。如果对您有帮助,请将我的答案标记为答案。谢谢。 stackoverflow.com/questions/3059044/…
  • 我已经更新了答案,以便可以添加多个标记。
  • 但是为什么要否决这个问题呢?
  • 嗨@Pouloulou 和eNVy,我刚刚在stackoverflow 中问了一个问题。 stackoverflow.com/questions/57985967/...请在我出错的地方向我提出建议,谢谢
猜你喜欢
  • 1970-01-01
  • 2015-07-05
  • 2014-12-21
  • 1970-01-01
  • 2020-01-19
  • 2011-06-12
  • 1970-01-01
  • 2010-10-11
相关资源
最近更新 更多