Я пытаюсь собрать приложение IONIC, используя Angular.Мое приложение - контент на карте Google, в том числе данные json api для аэропортовых координат, которые отображаются на карте.Я хочу изменить цвет иконки аэропортов в зависимости от индекса задержки.Для этого я использовал параметры буксировки одним методом, а этот метод отвечает за иконки аэропорта и координаты аэропортов.
имя метода addMarker()
Мой код:
export class HomePage implements OnInit {
points: Array<any> = [];
Data: any;
map: GoogleMap;
mags_icons: string;
DelayAvg: any
constructor(private http: HTTP) { }
ngOnInit() {
this.loadMap();
this.getData();
}
loadMap() {
this.map = GoogleMaps.create('map_canvas');
}
getData() {
this.http.get("xxxxxxxxxxxxx", {}, {}).then(data => {
// coordinates
this.Data = JSON.parse(data.data);
this.points = Object.keys(this.Data)
.map(key => this.Data[key].airport.position)
.map((position) => ({
lat: position.latitude,
lng: position.longitude
}))
console.log(this.points)
this.points.forEach((point) => {
this.addMarker(point);
});
// icons
this.DelayAvg = Object.keys(this.Data)
.map(key => this.Data[key].stats.arrivals)
.map((arrivals) => (
arrivals.delayIndex
))
console.log(this.DelayAvg)
this.DelayAvg.forEach((icons: any) => {
this.addMarker(icons)
let mag = icons;
switch (mag) {
case 0:
case 1.9:
return this.mags_icons = './assets/icon/green.png';
case 2:
case 3.5:
return this.mags_icons = './assets/icon/yellow.png';
case 3.6:
case 5:
return this.mags_icons = './assets/icon/red.png';
default:
return "blue";
}
});
console.log(this.mags_icons)
})
}
addMarker(point,icons) {
return this.map.addMarkerSync({
title: 'Ionic',
icon: icons,
animation: 'DROP',
position: point
});
}
}
, но проблема в том, что я получил ошибку в this.addMarker(icons)
и this.addMarker(point);
ошибка Expected 2 arguments, but got 1.
есть идеи, пожалуйста?