Click here to Skip to main content
15,991,108 members
Articles / Desktop Programming / Universal Windows Platform
Tip/Trick

Using Google Maps API in UWP C#

Rate me:
Please Sign up or sign in to vote.
4.78/5 (6 votes)
6 Mar 2018Ms-RL2 min read 28K   816   11   13
In this article, I will show you how easy it is to use Google maps in Universal Windows platform

Image 1

Introduction

In this article, I will show you how easy it is to use Google maps in universal windows platform.

Using the Code

For getting ready, first install GMapsUWPSDK NuGet package version 1.5.0 or higher. After you installed GMapsUWPSDK successfully, we have to Initialize the library before using it. Better to initialize this library on App.Xaml.Cs or on ExtendedSplashScreen. Initialize this library in this way:

C#
GMapsUWP.Initializer.Initialize("Your_API_KEY_HERE", "en-US");

Also, we need a MapControl in our page so add it in your XAML:

XML
xmlns:maps="using:Windows.UI.Xaml.Controls.Maps"
......
< maps:MapControl x:Name="Map"
      MapServiceToken="Bing_Maps_API_Token_To_Remove_MapControl_Error" />

Now for using Google Maps Tiles instead of Bing, use this code in cs file of the page:

C#
Map.Style = MapStyle.None;
Map.TileSources.Clear();
string mapuri = "http://mt1.google.com/vt/lyrs=r&hl=x-local&z={zoomlevel}&x={x}&y={y}";
Map.TileSources.Add(new MapTileSource(new HttpMapTileDataSource(mapuri)));

If you are using GMapsUWPSDK v1.9.0 or higher, you can simply use this code: 

C#
GMapsUWP.Map.MapControlHelper.UseGoogleMaps(Map);

For now, we have this result and we can see the Google Maps in our app.

Image 2

Finding Address for a POI on Map

For finding a POI address, you have to pass POI GeoPoint to the SDK. For getting a place, GeoPoint used MapTapped event, MapTapped returns the clicked point GeoPoint using args.Location.

C#
var GeoCodeResult = await GMapsUWP.GeoCoding.GeocodeHelper.GetAddress(args.Location);
await new MessageDialog(GeoCodeResult).ShowAsync();

Example:

Image 3

NOTE: If you have a wrong API Key or your API Key doesn't have the Geocoding feature enabled or on connection error, SDK will return you Earth. :D

Get Directions Between Two Points

For getting directions between two points, you have to pass points BasicGeoposition to the SDK.

C#
var DirectionsResult1 = await GMapsUWP.Directions.DirectionsHelper.GetDirections
                        (origin.Position, Destination.Position);
var DirectionsResult1Polyline = GMapsUWP.Directions.DirectionsHelper.GetDirectionAsRoute
                                (DirectionsResult1, Colors.SkyBlue);
Map.MapElements.Add(DirectionsResult1Polyline);

Image 4

In this SDK, default directions mode is driving. Also, you can pass waypoints too. If you define any waypoint, SDK will return you directions from origin to destination passing from waypoints.

Downloading Offline Maps

Note: This feature is added in SDK V1.7.0. This tool will help you to download offline maps for a specified region. This function gets 2 points at Top Left and Bottom Right to download tiles in that region. For using offline downloader, first create an instance of this class and subscribe needed events for it.

C#
var OfflineDL = GMapsUWP.OfflineMapsDownloader.OfflineMapDownloader.GetInstance();
OfflineDL.DownloadCompleted += OfflineDL_DownloadCompleted;
OfflineDL.DownloadMap(TopLeftGeoPoint.Position.Latitude, TopLeftGeoPoint.Position.Longitude, 
BottomRightGeoPoint.Position.Latitude, BottomRightGeoPoint.Position.Longitude, 2);

......
private async void OfflineDL_DownloadCompleted(object sender, bool e)
{
	var f = OfflineDL.GetMapDownloadFolder();
	await Launcher.LaunchFolderAsync(f);
}

In this code, after downloading maps, the complete app will launch the download folder to see downloaded files. Note: In the code here, I mentioned to use Maximum ZoomLevel 2. For a real app with offline maps support, I prefer to keep ZoomLevel blank. It will use 17 for it by default.

Related Links and Sources

There are lots of other features you can see in this SDK that aren't mentioned here to not make the article much longer, but you can check the links below:

You can share SDK issues and see a sample that I update it as fast as I can. Also, you can share suggestions and see My Wiki about the SDK.

This is the first UWP Google MAps client that I made and is fully functional and open source.

License

This article, along with any associated source code and files, is licensed under Microsoft Reciprocal License


Written By
Software Developer
Iran (Islamic Republic of) Iran (Islamic Republic of)
Universal Windows Platform (UWP) software developer from Iran.

Comments and Discussions

 
QuestionMainPage.xaml.cs Error Line 98 in your example Pin
Member 115103328-Dec-20 6:24
Member 115103328-Dec-20 6:24 
Hi Ali,

thank you for sharing via your article. It looks like I will be giving a maximum score once I get your sample working.

In the meantime, I wonder if you could help me sort something out?

MainPage.xaml.cs has an Error at Line 98 in your example. It complains that ReverseGeocoding2.Position method doesnt exist. Is it easy for you to fix please?

await new MessageDialog($"Latitude : {ReverseGeocoding2.Position.Latitude}\nLongitude : {ReverseGeocoding2.Position.Longitude}").ShowAsync();

Many thanks
Stew
AnswerRe: MainPage.xaml.cs Error Line 98 in your example Pin
Member 115103328-Dec-20 6:37
Member 115103328-Dec-20 6:37 
GeneralRe: MainPage.xaml.cs Error Line 98 in your example Pin
Member 115103328-Dec-20 6:43
Member 115103328-Dec-20 6:43 
QuestionAPI key Pin
Member 1412706724-Jan-19 19:57
Member 1412706724-Jan-19 19:57 
Questionhttp://mt1.google.com/vt/lyrs=r&hl=x-local&z={zoomlevel}&x={x}&y={y} it is not working for uwp Pin
Member 1350769722-Apr-18 19:01
Member 1350769722-Apr-18 19:01 
AnswerRe: http://mt1.google.com/vt/lyrs=r&hl=x-local&z={zoomlevel}&x={x}&y={y} it is not working for uwp Pin
Ali NGame14-Jun-18 20:53
Ali NGame14-Jun-18 20:53 
Questioncould this work on wpf? Pin
John Torjo14-Mar-18 5:42
professionalJohn Torjo14-Mar-18 5:42 
AnswerRe: could this work on wpf? Pin
Ali NGame17-Mar-18 1:26
Ali NGame17-Mar-18 1:26 
GeneralRe: could this work on wpf? Pin
John Torjo22-Mar-18 7:54
professionalJohn Torjo22-Mar-18 7:54 
GeneralRe: could this work on wpf? Pin
Ali NGame23-Mar-18 10:29
Ali NGame23-Mar-18 10:29 
GeneralRe: could this work on wpf? Pin
John Torjo26-Mar-18 20:27
professionalJohn Torjo26-Mar-18 20:27 
Questiontop article Pin
Conseils-chien6-Mar-18 8:51
professionalConseils-chien6-Mar-18 8:51 
AnswerRe: top article Pin
Ali NGame6-Mar-18 9:02
Ali NGame6-Mar-18 9:02 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.