GoogleMapsApi 1.8.0
See the version list below for details.
dotnet add package GoogleMapsApi --version 1.8.0
NuGet\Install-Package GoogleMapsApi -Version 1.8.0
<PackageReference Include="GoogleMapsApi" Version="1.8.0" />
<PackageVersion Include="GoogleMapsApi" Version="1.8.0" />
<PackageReference Include="GoogleMapsApi" />
paket add GoogleMapsApi --version 1.8.0
#r "nuget: GoogleMapsApi, 1.8.0"
#:package GoogleMapsApi@1.8.0
#addin nuget:?package=GoogleMapsApi&version=1.8.0
#tool nuget:?package=GoogleMapsApi&version=1.8.0
Release history: see CHANGELOG.md.
GoogleMapsApi
A friendly, strongly-typed .NET wrapper for the Google Maps Web Services APIs — Geocoding, Routes, Directions, Distance Matrix, Elevation, Time Zone, Places, Address Validation, and Static Maps. Multi-framework (net10.0, net8.0, netstandard2.0, net481, net462), async-first, and battle-tested with 2M+ downloads on NuGet.
Supported APIs
| API | Description |
|---|---|
| Geocoding | Convert between addresses and geographic coordinates |
| Routes | Modern route planning — real-time traffic, eco-routing, toll calc, two-wheeled vehicles (replaces Directions) |
| Directions | Legacy route planning between two points with multiple travel modes |
| Distance Matrix | Travel time and distance between multiple origins/destinations |
| Elevation | Elevation data for individual locations or paths |
| Time Zone | Time zone information for any coordinate |
| Places (New) | Modern Places API — Text Search, Nearby Search, Place Details, Autocomplete, Place Photos (replaces legacy Places) |
| Places | Deprecated (frozen by Google) — legacy Find / Nearby / Text search, Place Details, Autocomplete. Use Places (New) instead |
| Address Validation | Validate a postal address with component-level confirmation; USPS CASS for US/PR |
| Static Maps | Generate URLs for static map images with markers, paths, and styles |
Why this vs Google's official SDKs
Google's official .NET packages (e.g. Google.Maps.Routing.V2, Google.Maps.Places.V1) are auto-generated from gRPC service definitions — they're verbose, split across many packages, and feel like protobuf instead of .NET. GoogleMapsApi is a single, idiomatic NuGet package: one install, async-first, multi-target (modern .NET through legacy .NET Framework), with hand-crafted request/response types that read like normal C#.
Installation
Install via NuGet Package Manager:
Install-Package GoogleMapsApi
Or via .NET CLI:
dotnet add package GoogleMapsApi
Looking for runnable examples? See samples/ — console, ASP.NET Core minimal API, and Blazor Server.
Quickstart
API Key Configuration
You can configure your Google Maps API key in several ways:
// Option 1: Set API key per request
DirectionsRequest directionsRequest = new DirectionsRequest()
{
Origin = "NYC, 5th and 39",
Destination = "Philadelphia, Chestnut and Walnut",
ApiKey = "your-google-maps-api-key"
};
// Option 2: Set globally via app.config/appsettings.json (see wiki for details)
For more configuration options and detailed guides, see the wiki. Full API reference is published at maximn.github.io/google-maps.
Code Examples
The static GoogleMaps facade shown in Basic Usage below is deprecated and will be removed in 2.0.0. For new code prefer the instance-based IGoogleMapsClient / GoogleMapsClient — see Instance-based client below.
Basic Usage (async-first)
using GoogleMapsApi;
using GoogleMapsApi.Entities.Common;
using GoogleMapsApi.Entities.Directions.Request;
using GoogleMapsApi.Entities.Directions.Response;
using GoogleMapsApi.Entities.Geocoding.Request;
using GoogleMapsApi.Entities.Geocoding.Response;
using GoogleMapsApi.StaticMaps;
using GoogleMapsApi.StaticMaps.Entities;
//Static class use (Directions) (Can be made from static/instance class)
DirectionsRequest directionsRequest = new DirectionsRequest()
{
Origin = "NYC, 5th and 39",
Destination = "Philadelphia, Chestnut and Walnut",
};
// Async call (recommended)
DirectionsResponse directions = await GoogleMaps.Directions.QueryAsync(directionsRequest);
Console.WriteLine(directions);
//Instance class use (Geocode) (Can be made from static/instance class)
GeocodingRequest geocodeRequest = new GeocodingRequest()
{
Address = "new york city",
};
var geocodingEngine = GoogleMaps.Geocode;
GeocodingResponse geocode = await geocodingEngine.QueryAsync(geocodeRequest);
Console.WriteLine(geocode);
// Static maps API - get static map of with the path of the directions request
StaticMapsEngine staticMapGenerator = new StaticMapsEngine();
//Path from previos directions request
IEnumerable<Step> steps = directions.Routes.First().Legs.First().Steps;
// All start locations
IList<ILocationString> path = steps.Select(step => step.StartLocation).ToList<ILocationString>();
// also the end location of the last step
path.Add(steps.Last().EndLocation);
string url = staticMapGenerator.GenerateStaticMapURL(new StaticMapRequest(new Location(40.38742, -74.55366), 9, new ImageSize(800, 400))
{
Pathes = new List<GoogleMapsApi.StaticMaps.Entities.Path>(){ new GoogleMapsApi.StaticMaps.Entities.Path()
{
Style = new PathStyle()
{
Color = "red"
},
Locations = path
}}
});
Console.WriteLine("Map with path: " + url);
Routes API (modern replacement for Directions)
The Routes API is Google's modern replacement for the Directions API — it supports real-time traffic, eco-routing, toll calculation, two-wheeled vehicles, and route alternatives. Unlike Directions, it requires a field mask to constrain the response. A sensible default is pre-populated; tighten it to reduce response size and cost.
using GoogleMapsApi;
using GoogleMapsApi.Entities.Routes.Request;
var request = new RoutesRequest
{
ApiKey = "your-google-maps-api-key",
Origin = Waypoint.FromAddress("San Francisco, CA"),
Destination = Waypoint.FromAddress("Mountain View, CA"),
TravelMode = RoutesTravelMode.Drive,
RoutingPreference = RoutingPreference.TrafficAware,
// FieldMask defaults to a Directions-equivalent shape; override to slim the response.
};
var response = await GoogleMaps.Routes.QueryAsync(request);
var route = response.Routes![0];
Console.WriteLine($"{route.DistanceMeters} m, {route.DurationSeconds} s");
Instance-based client (IHttpClientFactory-friendly)
In addition to the static GoogleMaps facade, you can use the instance-based GoogleMapsClient that accepts an injected HttpClient. This is the recommended pattern for ASP.NET Core, minimal APIs, and worker services — it plays nicely with IHttpClientFactory, per-instance event handlers, and an ambient API key that is auto-filled into requests when not set explicitly.
// Register once at startup
services.AddHttpClient<IGoogleMapsClient, GoogleMapsClient>();
services.AddSingleton(new GoogleMapsClientOptions { ApiKey = "your-google-maps-api-key" });
// Inject and use
public class GeocodingService(IGoogleMapsClient maps)
{
public Task<GeocodingResponse> LookupAsync(string address)
=> maps.Geocode.QueryAsync(new GeocodingRequest { Address = address });
}
Without DI:
using var http = new HttpClient();
var maps = new GoogleMapsClient(http, new GoogleMapsClientOptions { ApiKey = "your-key" });
var result = await maps.Directions.QueryAsync(new DirectionsRequest { Origin = "NYC", Destination = "DC" });
Per-instance events (no global state):
maps.Geocode.OnUriCreated += uri => uri; // inspect/rewrite outgoing URI
maps.Geocode.OnRawResponseReceived += bytes => { }; // tap raw JSON
Synchronous Usage
Synchronous calls are also supported via Query (use QueryAsync whenever possible):
DirectionsResponse directions = GoogleMaps.Directions.Query(directionsRequest);
Console.WriteLine(directions);
If this library saved you time, please ⭐ the repo — it helps others find it.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 is compatible. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.6.2
- System.Net.Http (>= 4.3.4)
- System.Text.Encodings.Web (>= 10.0.8)
- System.Text.Json (>= 10.0.8)
-
.NETFramework 4.8.1
- System.Net.Http (>= 4.3.4)
- System.Text.Encodings.Web (>= 10.0.8)
- System.Text.Json (>= 10.0.8)
-
.NETStandard 2.0
- System.Text.Encodings.Web (>= 10.0.8)
- System.Text.Json (>= 10.0.8)
-
net10.0
- No dependencies.
-
net6.0
- System.Text.Json (>= 10.0.8)
-
net8.0
- System.Text.Json (>= 10.0.8)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on GoogleMapsApi:
| Package | Downloads |
|---|---|
|
GoogleMapsApi.Extensions.DependencyInjection
Dependency injection extensions for GoogleMapsApi — registers IGoogleMapsClient with IHttpClientFactory and binds options via AddGoogleMaps(). |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.5.0 | 265 | 6/23/2026 |
| 2.4.0 | 899 | 6/15/2026 |
| 2.3.0 | 243 | 6/13/2026 |
| 2.2.0 | 164 | 6/12/2026 |
| 2.1.0 | 1,546 | 5/31/2026 |
| 2.0.0 | 130 | 5/31/2026 |
| 1.8.0 | 303 | 5/31/2026 |
| 1.7.0 | 144 | 5/30/2026 |
| 1.6.0 | 139 | 5/30/2026 |
| 1.5.0 | 518 | 5/25/2026 |
| 1.4.8 | 1,269 | 5/24/2026 |
| 1.4.7 | 172 | 5/23/2026 |
| 1.4.6 | 159 | 5/23/2026 |
| 1.4.5 | 83,629 | 9/23/2025 |
| 1.4.4 | 2,466 | 9/19/2025 |
| 1.4.0 | 3,761 | 9/5/2025 |
| 1.3.9 | 1,106 | 9/3/2025 |
| 1.3.8 | 777 | 9/3/2025 |