BlazorGoogleMaps 4.15.1
dotnet add package BlazorGoogleMaps --version 4.15.1
NuGet\Install-Package BlazorGoogleMaps -Version 4.15.1
<PackageReference Include="BlazorGoogleMaps" Version="4.15.1" />
<PackageVersion Include="BlazorGoogleMaps" Version="4.15.1" />
<PackageReference Include="BlazorGoogleMaps" />
paket add BlazorGoogleMaps --version 4.15.1
#r "nuget: BlazorGoogleMaps, 4.15.1"
#:package BlazorGoogleMaps@4.15.1
#addin nuget:?package=BlazorGoogleMaps&version=4.15.1
#tool nuget:?package=BlazorGoogleMaps&version=4.15.1
BlazorGoogleMaps
🗺️ Blazor interop for Google Maps JavaScript API
A powerful and easy-to-use Blazor library for integrating Google Maps into your Blazor WebAssembly and Blazor Server applications.
📑 Table of Contents
- Features
- Prerequisites
- Installation
- Quick Start
- Configuration
- Usage Examples
- Live Demos
- Breaking Changes
- Contributing
✨ Features
- 🎯 Full Google Maps API Support - Markers, Polylines, Polygons, Circles, Info Windows, and more
- 🚀 Blazor WebAssembly & Server - Works seamlessly with both hosting models
- 🎨 Advanced Markers - Render Blazor components directly on the map
- 📍 Marker Clustering - Built-in support for marker clustering
- 🔥 Heat Maps - Visualize data density with heat map layers
- 🛣️ Directions & Routes - Full support for directions and route rendering
- 🎭 Map Styling - Customize map appearance with style options
- 📊 Data Layers - Support for GeoJSON and other data formats
- ⚡ Event Handling - Comprehensive event support for interactive maps
- 🎨 Drawing Tools - Built-in drawing manager for shapes and overlays
📋 Prerequisites
- .NET 8.0 or higher
- A valid Google Maps API key (Get one here)
📦 Installation
Install the package via NuGet Package Manager:
dotnet add package BlazorGoogleMaps
Or via NuGet Package Manager Console:
Install-Package BlazorGoogleMaps
🚀 Quick Start
Step 1: Configure Your API Key
Add BlazorGoogleMaps to your Program.cs:
Option 1: Simple Configuration (Recommended)
builder.Services.AddBlazorGoogleMaps("YOUR_GOOGLE_API_KEY");
Option 2: Advanced Configuration
builder.Services.AddBlazorGoogleMaps(new GoogleMapsComponents.Maps.MapApiLoadOptions("YOUR_GOOGLE_API_KEY")
{
Version = "beta",
Libraries = "places,visualization,drawing,marker"
});
Option 3: Custom Key Service
For more complex scenarios (e.g., loading keys asynchronously from a database):
builder.Services.AddScoped<IBlazorGoogleMapsKeyService, YourCustomKeyService>();
⚠️ Legacy Method (Not Recommended): Adding the script tag directly to your HTML is still supported but not recommended.
Step 2: Add JavaScript References
Add the required JavaScript files to your wwwroot/index.html (Blazor WASM) or _Host.cshtml/_HostLayout.cshtml (Blazor Server):
<script src="_content/BlazorGoogleMaps/js/objectManager.js"></script>
Optional: For marker clustering support, add:
<script src="https://unpkg.com/@googlemaps/markerclusterer/dist/index.min.js"></script>
💡 Usage Examples
Basic Map
Create a simple map component:
@page "/map"
@using GoogleMapsComponents
@using GoogleMapsComponents.Maps
<h1>Google Map</h1>
<div style="height: 500px;">
<GoogleMap @ref="@_map1"
Id="map1"
Options="@_mapOptions"
Height="100%"
OnAfterInit="@AfterMapRender">
</GoogleMap>
</div>
@code {
private GoogleMap? _map1;
private MapOptions _mapOptions = default!;
protected override void OnInitialized()
{
_mapOptions = new MapOptions()
{
Zoom = 13,
Center = new LatLngLiteral()
{
Lat = 13.505892,
Lng = 100.8162
},
MapTypeId = MapTypeId.Roadmap
};
}
private async Task AfterMapRender()
{
// Map is ready - you can perform additional initialization here
var bounds = await LatLngBounds.CreateAsync(_map1!.JsRuntime);
}
}
Advanced Map with Blazor Components
Render interactive Blazor components as markers (requires Google Maps v=beta and a MapId):
@page "/advanced-map"
@using GoogleMapsComponents
@using GoogleMapsComponents.Maps
<h1>Advanced Map with Blazor Markers</h1>
<AdvancedGoogleMap @ref="@_map1" Id="map1" Options="@_mapOptions">
@foreach (var marker in Markers)
{
<MarkerComponent
@key="marker.Id"
Lat="@marker.Lat"
Lng="@marker.Lng"
Clickable="@marker.Clickable"
Draggable="@marker.Draggable"
OnClick="@(() => marker.Active = !marker.Active)"
OnMove="@(pos => marker.UpdatePosition(pos))">
<div class="custom-marker">
<h4>@marker.Title</h4>
<p>Custom Blazor Content</p>
</div>
</MarkerComponent>
}
</AdvancedGoogleMap>
@code {
private AdvancedGoogleMap? _map1;
private List<MarkerData> Markers =
[
new MarkerData { Id = 1, Lat = 13.505892, Lng = 100.8162, Title = "Location 1" }
];
private MapOptions _mapOptions = new()
{
Zoom = 13,
Center = new LatLngLiteral()
{
Lat = 13.505892,
Lng = 100.8162
},
MapId = "DEMO_MAP_ID", // Required for advanced markers
MapTypeId = MapTypeId.Roadmap
};
public class MarkerData
{
public int Id { get; set; }
public string Title { get; set; } = string.Empty;
public double Lat { get; set; }
public double Lng { get; set; }
public bool Clickable { get; set; } = true;
public bool Draggable { get; set; }
public bool Active { get; set; }
public void UpdatePosition(LatLngLiteral position)
{
Lat = position.Lat;
Lng = position.Lng;
}
}
}
🎮 Live Demos
Explore interactive examples and learn more features:
- 📘 Server-Side Demo: GitHub Repository
- 🌐 Client-Side Demo: Live Demo
The server-side demos include the most up-to-date examples covering:
- Markers and Info Windows
- Polylines, Polygons, and Circles
- Heat Maps and Data Layers
- Drawing Manager
- Routes and Directions
- Event Handling
- Map Styling
- And much more!
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
📄 License
This project is licensed under the MIT License.
🙏 Acknowledgments
- Built with ❤️ for the Blazor community
- Powered by the Google Maps JavaScript API
Happy Mapping! 🗺️
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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 is compatible. 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. |
-
net10.0
- Microsoft.AspNetCore.Components (>= 10.0.3)
- Microsoft.AspNetCore.Components.Web (>= 10.0.3)
- Microsoft.JSInterop (>= 10.0.3)
- OneOf (>= 3.0.271)
-
net8.0
- Microsoft.AspNetCore.Components (>= 8.0.24)
- Microsoft.AspNetCore.Components.Web (>= 8.0.24)
- Microsoft.JSInterop (>= 8.0.24)
- OneOf (>= 3.0.271)
- System.Text.Json (>= 10.0.2)
-
net9.0
- Microsoft.AspNetCore.Components (>= 9.0.13)
- Microsoft.AspNetCore.Components.Web (>= 9.0.13)
- Microsoft.JSInterop (>= 9.0.13)
- OneOf (>= 3.0.271)
NuGet packages (4)
Showing the top 4 NuGet packages that depend on BlazorGoogleMaps:
| Package | Downloads |
|---|---|
|
templar-common-libary
Package Description |
|
|
Magiq.Blazor
Provides views and services to be used in Blazor Client and Server projects. |
|
|
AeroBlazor
A blazor library, extending MudBlazor |
|
|
Microfrontend.one
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 4.15.1 | 46 | 2/23/2026 |
| 4.15.0 | 2,252 | 1/27/2026 |
| 4.14.1 | 5,569 | 12/22/2025 |
| 4.14.0 | 3,088 | 11/27/2025 |
| 4.13.8 | 2,802 | 11/18/2025 |
| 4.13.7 | 5,051 | 10/27/2025 |
| 4.13.6 | 17,980 | 8/5/2025 |
| 4.13.5 | 1,173 | 7/30/2025 |
| 4.13.4 | 2,442 | 7/27/2025 |
| 4.13.3 | 350 | 7/26/2025 |
| 4.13.2 | 1,443 | 7/15/2025 |
| 4.13.1 | 2,300 | 7/5/2025 |
| 4.13.0 | 4,742 | 6/5/2025 |
| 4.12.2 | 2,706 | 6/2/2025 |
| 4.12.1 | 459 | 6/1/2025 |
| 4.12.0 | 571 | 5/28/2025 |
| 4.11.3 | 266 | 5/28/2025 |
| 4.11.2 | 2,212 | 5/13/2025 |
| 4.11.1 | 17,685 | 4/20/2025 |
| 4.11.0 | 853 | 4/14/2025 |