This tutorial demonstrates how to use the Google Map component in an Ionic 4 app. As part of the app design, the Geolocation service is added to show current coordinates on the map.
Appery.io provides the Ionic 4 component. You can simply drag it to the page, configure it via the PROPERTIES panel like any other UI component, and then use it with the Google Maps API via JavaScript.
Before You Start
Before you begin, don't forget to set up a Google Maps API key for yourself if you haven't already. It's required for the Google Maps component to work correctly in your app. Learn how to get your API key from this guide. And, be careful with API restrictions. (You can read about these here.)
You can also check our instructional video that shows how to use the Google Maps component in Ionic 4 apps here:
Creating New App
- From the Apps tab, click Create new app.
- Select Ionic 4 as the application type, enter an app name, and click Create:
data:image/s3,"s3://crabby-images/72438/72438e0ae76c44c048310a6cd4df724b834e85e9" alt="Screenshot_3.jpg 1554"
New Ionic 4 app
- You will see a Start page. On the left side, expand the Project folder and go to App Settings > Components. Set your own Google API Key to the Browser API key field:
data:image/s3,"s3://crabby-images/105ad/105ad46f441d0e014d58afae3990f2c2ca5300b3" alt="api_key.png 1177"
Google API Key
- Then navigate to App Settings > Cordova plugins and enable the Geolocation plugin:
data:image/s3,"s3://crabby-images/17a10/17a1054175629f0d73e27740673799658946ae8a" alt="geolocation_plugin.png 1253"
Geolocation plugin
Building UI
Next, we set up the UI, consisting of a Google Map component and a Button component.
- Open Screen1 and go to its DESIGN tab. Click on the Toolbar title in the app screen and change it to Google Maps App by changing the Text property on the right menu.
- Drag & drop the Button component to the screen and set its Text property to Get Current Position.
- Then, drag & drop the Google Map component to Screen1.
The resulting app:
data:image/s3,"s3://crabby-images/bd818/bd8183b5c6a26cafa9fb83e11a4d80382108eee8" alt="app_ui.png 519"
Resulting app view
Defining Application Logic
Next, we "wire" things together in the app.
- Open the CODE tab. Add lat and lng as Number variables:
data:image/s3,"s3://crabby-images/75762/75762cff8879c375fc98f777f410b93812589b5c" alt="lat_lng.png 817"
Add lat and lng variables
- Go back to the DESIGN tab. Select the Google Map component (for your convenience, you can use the OUTLINE tab or do it by selecting the needed component in the breadcrumbs menu) and set its View point properties to: Latitude = lat, Longitude = lng:
data:image/s3,"s3://crabby-images/1af39/1af39fed5d3298a45576b1abe9d8851f3a4fe077" alt="map_props.png 1118"
Define lat and lng variables
- Then, select Google Map > Marker1 and set its Coords properties to: Latitude = lat, Longitude = lng:
data:image/s3,"s3://crabby-images/21931/2193109d0ca7a643b72a0c5c3a5ae7c543d24d39" alt="marker.png 344"
Define Marker coordinates
- Click the Get Current Position button (Button1) and expand the EVENTS panel from the bottom. There, for the Button1 component, select the Click event, and, for action, set Run TypeScript inserting the following code:
let _this = this;
let onSuccess = (position) => {
_this.lat = position.coords.latitude;
_this.lng = position.coords.longitude;
};
function onError(error) {
console.log('code: ' + error.code + '\n' + 'message: ' + error.message + '\n');
}
navigator.geolocation.getCurrentPosition(onSuccess, onError);
data:image/s3,"s3://crabby-images/d4b34/d4b34ba6d99f2e89fe69513d6d8ad934fae2932e" alt="click_event.png 1651"
Set Click event
- Click the Save button to save all the changes.
App Testing
Now, you are ready to test your app. Click the TEST button in the App Builder to launch the app in the browser.
That's it.
Troubleshooting
data:image/s3,"s3://crabby-images/d2fe7/d2fe78eaf518deea41ff7c0e99b2b6a1c56a3528" alt="billing_err.png 1127"
"This page didn’t load Google Maps correctly" error
If you encounter this issue, make sure that Google Maps Platform billing is enabled. To use the Maps JavaScript API, add the API key to all API requests and enable billing for each of your projects. You can read more about it here.
You might also like our Appery.io Community video that shows how to use the Google Maps component to get current geolocation with Appery.io Geo Service plug-in: