Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rungwiroon/BlazorGoogleMaps
Blazor interop for GoogleMap library
https://github.com/rungwiroon/BlazorGoogleMaps
blazor-interop google-maps
Last synced: 10 days ago
JSON representation
Blazor interop for GoogleMap library
- Host: GitHub
- URL: https://github.com/rungwiroon/BlazorGoogleMaps
- Owner: rungwiroon
- License: mit
- Created: 2019-01-01T17:18:46.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T20:40:00.000Z (11 days ago)
- Last Synced: 2024-10-28T21:31:55.414Z (11 days ago)
- Topics: blazor-interop, google-maps
- Language: C#
- Homepage:
- Size: 9.94 MB
- Stars: 329
- Watchers: 19
- Forks: 105
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-blazor - BlazorGoogleMaps - ![stars](https://img.shields.io/github/stars/rungwiroon/BlazorGoogleMaps?style=flat-square&cacheSeconds=604800) ![last commit](https://img.shields.io/github/last-commit/rungwiroon/BlazorGoogleMaps?style=flat-square&cacheSeconds=86400) Blazor interop for GoogleMap library. (Libraries & Extensions / Tools & Utilities)
README
# BlazorGoogleMaps
Blazor interop for GoogleMap library[![NuGet version (BlazorGoogleMaps)](https://img.shields.io/nuget/v/BlazorGoogleMaps)](https://www.nuget.org/packages/BlazorGoogleMaps/)
## Usage
1. Provide your Google API key to BlazorGoogleMaps with one of the following methods. (You can get a key here: https://developers.google.com/maps/documentation/javascript/get-api-key)Use the bootstrap loader with a key service (recommended):
```
services.AddBlazorGoogleMaps("YOUR_KEY_GOES_HERE");
```
OR specify google api libraries and/or version:
```
services.AddBlazorGoogleMaps(new GoogleMapsComponents.Map.MapApiLoadOptions("YOUR_KEY_GOES_HERE")
{
Version = "beta",
Libraries = "places,visualization,drawing,marker",
});
```
OR to do something more complex (e.g. looking up keys asynchronously), implement a Scoped key service and add it with something like:
```
services.AddScoped();
```OR (legacy - not recommended) Add google map script HEAD tag to wwwroot/index.html in Client side or _Host.cshtml in Server Side.
``````
2. Add path to project javascript functions file in wwwroot/index.html for Blazor WASM, or in _Host.cshtml or _HostLayout.cshtml for Blazor Server.
``````
If you want to use marker clustering add this script as well:
``````
3. Using the component is the same for both Blazor WASM and Blazor Server
```
@page "/map"
@using GoogleMapsComponents
@using GoogleMapsComponents.MapsGoogle Map
@functions {
private GoogleMap _map1;
private MapOptions mapOptions;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()
{
_bounds = await LatLngBounds.CreateAsync(_map1.JsRuntime);
}
}
```## Samples
Please check server side samples https://github.com/rungwiroon/BlazorGoogleMaps/tree/master/ServerSideDemo which are most to date
ClientSide demos online
https://rungwiroon.github.io/BlazorGoogleMaps/mapEvents**Breaking change from 4.0.0**
Migrate to .NET 8 #286.**Breaking change from 3.0.0**
Migrate from Newtonsoft.Json to System.Text.Json.**Breaking change from 2.0.0**
LatLngLiteral constructor's parameters order changed #173