@ionic-native/google-maps plugin is a wrapper plugin of Cordova GoogleMaps plugin. You can write your code with TypeScript instead of pure JavaScript.
Since the @ionic-native/google-maps plugin was first written by the ionic-team, there might exist some mistakes in the wrapper plugin, such as missing some properties, or wrong method definition. The author of Cordova GoogleMaps plugin, Masashi, has been working to fix the plugin, but the plugin has lots of featues. It's hard to figure out all the mistakes alone. So if you find any problems with the @ionic-native/google-maps plugin, please report the issue to the issue list with test project.
The official page document is here https://github.com/ionic-team/ionic-native-google-maps/blob/master/documents/README.md
$ ionic cordova plugin add https://github.com/mapsplugin/cordova-plugin-googlemaps --variable API_KEY_FOR_ANDROID="YOUR_ANDROID_API_KEY_IS_HERE" --variable API_KEY_FOR_IOS="YOUR_IOS_API_KEY_IS_HERE"
$ npm install --save @ionic-native/core@latest @ionic-native/google-maps@latest
- Android
- iOS
Full source code: https://github.com/mapsplugin/ionic-googlemaps-quickdemo
export class MyApp {
@ViewChild(Nav) nav: Nav;
rootPage: any; // <<< Do not set the root page until the platform.ready()
// This avoids to face the plugin loading error.
pages: Array<{title: string, component: any}>;
constructor(public platform: Platform, public statusBar: StatusBar, public splashScreen: SplashScreen) {
this.initializeApp();
}
initializeApp() {
this.platform.ready().then(() => {
this.rootPage = HomePage; // <<< Set the first page after native side is ready. So, you don't need to write platform.ready() in anypage anymore.
this.statusBar.styleDefault();
this.splashScreen.hide();
});
}
openPage(page) {
this.nav.setRoot(page.component);
}
}
import { Component } from "@angular/core/";
import {
GoogleMaps,
GoogleMap,
GoogleMapsEvent,
Marker,
GoogleMapsAnimation,
MyLocation
} from '@ionic-native/google-maps';
@Component({
selector: 'page-home',
templateUrl: 'home.html'
})
export class HomePage {
mapReady: boolean = false;
map: GoogleMap;
constructor() {
}
ionViewDidLoad() {
this.loadMap();
}
loadMap() {
// Create a map after the view is loaded.
// (platform is already ready in app.component.ts)
this.map = GoogleMaps.create('map_canvas', {
camera: {
target: {
lat: 43.0741704,
lng: -89.3809802
},
zoom: 18,
tilt: 30
}
});
// Wait the maps plugin is ready until the MAP_READY event
this.map.one(GoogleMapsEvent.MAP_READY).then(() => {
this.mapReady = true;
});
}
onButtonClick() {
if (!this.mapReady) {
this.showToast('map is not ready yet. Please try again.');
return;
}
this.map.clear();
// Get the location of you
this.map.getMyLocation()
.then((location: MyLocation) => {
console.log(JSON.stringify(location, null ,2));
// Move the map camera to the location with animation
return this.map.animateCamera({
target: location.latLng,
zoom: 17,
tilt: 30
}).then(() => {
// add a marker
return this.map.addMarker({
title: '@ionic-native/google-maps plugin!',
snippet: 'This plugin is awesome!',
position: location.latLng,
animation: GoogleMapsAnimation.BOUNCE
});
})
}).then((marker: Marker) => {
// show the infoWindow
marker.showInfoWindow();
// If clicked it, display the alert
marker.on(GoogleMapsEvent.MARKER_CLICK).subscribe(() => {
this.showToast('clicked!');
});
});
}
showToast(message: string) {
let toast = this.toastCtrl.create({
message: message,
duration: 2000,
position: 'middle'
});
toast.present(toast);
}
}
<ion-header>
<ion-navbar>
<button ion-button menuToggle>
<ion-icon name="menu"></ion-icon>
</button>
<ion-title>Home</ion-title>
</ion-navbar>
</ion-header>
<ion-content padding>
<h3>Ionic GoogleMaps Demo</h3>
<p>
This is a demo application of <b>@ionic-native/google-maps</b> plugin.
</p>
<div id="map_canvas">
<button ion-button (click)="onButtonClick($event)">Demo</button>
</div>
</ion-content>
page-home {
#map_canvas {
height: 90%;
}
}