MPowerKit.GoogleMaps
2.0.0
Prefix Reserved
See the version list below for details.
dotnet add package MPowerKit.GoogleMaps --version 2.0.0
NuGet\Install-Package MPowerKit.GoogleMaps -Version 2.0.0
<PackageReference Include="MPowerKit.GoogleMaps" Version="2.0.0" />
paket add MPowerKit.GoogleMaps --version 2.0.0
#r "nuget: MPowerKit.GoogleMaps, 2.0.0"
// Install MPowerKit.GoogleMaps as a Cake Addin #addin nuget:?package=MPowerKit.GoogleMaps&version=2.0.0 // Install MPowerKit.GoogleMaps as a Cake Tool #tool nuget:?package=MPowerKit.GoogleMaps&version=2.0.0
MPowerKit.GoogleMaps
Google Maps SDK library for .NET MAUI. Very easy to use. Allows to interact with map in MVVM manner through bindings or with map control directly.
This library is designed for the .NET MAUI. The main control of this library GoogleMap
implements every single feature that Google Maps SDK for Android and iOS provides. Every feature of the SDK is represented as BindableProperty
, so you can build very flexible solutions that require usage of Google Maps.
Also, this library supports features from the Google Maps Utils SDK, but does not bring extra native dependencies. All code from Utils SDK is ported from Java to C#/.NET and completely cross-platform.
Table Of Contents of public API's
- Setup
- Usage
- API definition
Setup
First of all you need to make sure you have set up Google Cloud Console and obtained Google Maps API key.
Then you need to set up your project to be able to use Google Maps SDK. In your MainProgram.cs add next:
builder
.UseMauiApp<App>()
.UseMPowerKitGoogleMaps(
#if IOS
"Your iOS API key here"
#endif
);
and in Android's MainApplication.cs:
[Application]
[MetaData("com.google.android.maps.v2.API_KEY", Value = "Your Android API key here")]
public class MainApplication : MauiApplication
{
public MainApplication(IntPtr handle, JniHandleOwnership ownership) : base(handle, ownership)
{ }
protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp();
}
or in you Android's AndroidManifest.xml:
<application>
<meta-data android:name="com.google.android.geo.API_KEY" android:value="Your Android API key here" />
</application>
Also, be sure you have added permissions to your Android's AndroidManifest.xml if you want to show 'My location' on the map:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-feature android:name="android.hardware.location" android:required="false" />
<uses-feature android:name="android.hardware.location.gps" android:required="false" />
<uses-feature android:name="android.hardware.location.network" android:required="false" />
Usage
To use this library in you MAUI projects just add GoogleMap
control you your xaml file as next:
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="Sample.Views.MainPage"
xmlns:gm="clr-namespace:MPowerKit.GoogleMaps;assembly=MPowerKit.GoogleMaps">
<gm:GoogleMap />
</ContentPage>
The full list of all properties and features you can find here. Also every single feature is shown in Sample project, so it is better to download it and there you can find how to use feature you need.
API definition
!!! Important: If you cannot find documentation about some methods, events or properties here, then you can search some at offical Google Maps SDK web site.
API of this library is devided into 9 logical groups: Map features, Camera, UI Settings, Pins, Circles, Polylines, Polygons, Tiles, Ground overlays. Each logic group is represented as separate manager and responsible only for that part of logic, and preregistered in the public static dictionary inside the handler:
public static Dictionary<string, Func<IMapFeatureManager<GMap>>> ManagerMapper { get; } = new()
{
{ GoogleMap.MapManagerName, () => new MapManager() },
{ GoogleMap.CameraManagerName, () => new CameraManager() },
{ GoogleMap.UiSettingsManagerName, () => new UiSettingsManager() },
{ GoogleMap.PolylineManagerName, () => new PolylineManager() },
{ GoogleMap.PolygonManagerName, () => new PolygonManager() },
{ GoogleMap.CircleManagerName, () => new CircleManager() },
{ GoogleMap.TileOverlayManagerName, () => new HeatMapTileManager() },
{ GoogleMap.GroundOverlayManagerName, () => new GroundOverlayManager() },
{ GoogleMap.PinManagerName, () => new ClusterManager() },
};
Note: NativeMapView
is different for Android and iOS
This approach is very flexible and gives you possibility to operate with different logics in a very simple way, and it is very easy understand, add, change or remove already registered implementations by your's.
For example: if you want to remove some logic, you just need to remove registration from ManagerMapper
dictionary, as next:
GoogleMapHandler.ManagerMapper.Remove(GoogleMap.GroundOverlayManagerName);
If you want to change implementation, you can do next:
GoogleMapHandler.ManagerMapper[GoogleMap.PinManagerName] = () => new YourPinManager();
If you want to add absolutely new logic to your map, you can do next:
GoogleMapHandler.ManagerMapper["YourManagerUniqueName"] = () => new YourNewLogicManager();
and your YourNewLogicManager
should be typeof(IMapFeatureManager<NativeMapView>)
Note: You can do it in your MauiProgram.cs
or in any other place in your code. But you should understand, that this changes can be applied to the map only before navigating to the page with map.
Events and commands
Event | Command | Argument type | Description |
---|---|---|---|
NativeMapReady | NativeMapReadyCommand | Raised, when native map is initialized and rendered and ready to go. Raises only once. All operations with map should be done only after this event. IsNativeMapReady property is set after this event to true . |
|
MapCapabilitiesChanged | MapCapabilitiesChangedCommand | MapCapabilities | Raised, when map capabilities were changed, the MapCapabilities property is set to the new value. |
IndoorBuildingFocused | IndoorBuildingFocusedCommand | IndoorBuilding? | Raised, when indoor building was focused, the IndoorBuilding property is set to the new value. Can be null if no building is focused. |
IndoorLevelActivated | IndoorLevelActivatedCommand | IndoorLevel? | Raised, when indoor building was focused or active level was changed, the ActiveLevel property is set to the new value. Can have value only if IndoorBuilding is not null , otherwise null . |
MapClick | MapClickedCommand | Point | Raised, when user clicks on the map. |
MapLongClick | MapLongClickedCommand | Point | Raised, when user does long press on the map. |
PoiClick | PoiClickedCommand | PointOfInterest | Raised, when user on the 'Point of Interest'. |
CameraMoveStart | CameraMoveStartedCommand | CameraMoveReason | Raised, when camera starting change of it's position. CameraMoveReason is enum and representing the reason of camera move. |
CameraMove | CameraMoveCommand | Raised, when camera is moving. Can be risen only when camera is animated programmatically. | |
CameraPositionChanged | CameraPositionChangedCommand | CameraPosition | Raised, when camera is changing it's position, the CameraPosition property is set to the new value. |
CameraMoveCanceled | CameraMoveCanceledCommand | Raised, when camera move is canceled. Can be risen only when camera is animated programmatically and animation was canceled. Applies only to Android. | |
CameraIdle | CameraIdleCommand | VisibleRegion | Raised, when camera is idle (stopped). the CameraPosition property is set to the new value, the VisibleRegion property is set to the new value. |
PolygonClick | PolygonClickedCommand | Polygon/object | Raised, when user clicks on the polygon. The argument type of the command depends on how polygon was added to the map. |
PolylineClick | PolylineClickedCommand | Polyline/object | Raised, when user clicks on the polyline. The argument type of the command depends on how polyline was added to the map. |
CircleClick | CircleClickedCommand | Circle/object | Raised, when user clicks on the circle. The argument type of the command depends on how circle was added to the map. |
GroundOverlayClick | GroundOverlayClickedCommand | GroundOverlay/object | Raised, when user clicks on the ground overlay. The argument type of the command depends on how ground overlay was added to the map. |
PinClick | PinClickedCommand | Pin/object | Raised, when user clicks on the pin. The argument type of the command depends on how pin was added to the map. The SelectedPin property is set to the new value, but only if this pin CanBeSelected . |
PinDragStart | PinDragStartedCommand | Pin/object | Raised, when user starting drag the pin. The argument type of the command depends on how pin was added to the map. |
PinDragging | PinDraggingCommand | Pin/object | Raised, when user is dragging the pin. The argument type of the command depends on how pin was added to the map. |
PinDragEnd | PinDragEndedCommand | Pin/object | Raised, when pin dragging is ended. The argument type of the command depends on how pin was added to the map. |
InfoWindowClick | InfoWindowClickedCommand | Pin/object | Raised, when user clicks on pin's info window. The argument type of the command depends on how pin was added to the map. |
InfoWindowLongClick | InfoWindowLongClickedCommand | Pin/object | Raised, when user does long press on pin's info window. The argument type of the command depends on how pin was added to the map. |
InfoWindowClosed | InfoWindowClosedCommand | Pin/object | Raised, when pin's info window was closed. The argument type of the command depends on how pin was added to the map. |
ClusterClick | ClusterClickedCommand | Cluster | Raised, when user clicks on the cluster. The argument type can only be Cluster . |
ClusterInfoWindowClick | ClusterInfoWindowClickedCommand | Cluster | Raised, when user clicks on cluster's info window. The argument type can only be Cluster . |
ClusterInfoWindowLongClick | ClusterInfoWindowLongClickedCommand | Cluster | Raised, when user does long press on cluster's info window. The argument type can only be Cluster . |
ClusterInfoWindowClosed | ClusterInfoWindowClosedCommand | Cluster | Raised, when cluster's info window was closed. The argument type can only be Cluster . |
Public methods, actions, funcs
Method | Bindable property | Parameters | Return type | Description |
---|---|---|---|---|
TakeSnapshot | TakeSnapshotFunc | Task<Stream?> | Takes snapshot of the map in current state. Returns stream of the taken snapshot. | |
ResetMinMaxZoom | ResetMinMaxZoomAction | Resets min and max zoom properties. Applies only to Android. | ||
MoveCamera | MoveCameraAction | CameraUpdate newCameraPosition | Instantly moves camera to the new position. | |
AnimateCamera | AnimateCameraFunc | CameraUpdate newCameraPosition, int durationMils | Task | Moves camera to the new position with animation. By default animation duration is 300 ms, but can be changed. |
ProjectMapCoordsToScreenLocation | ProjectMapCoordsToScreenLocationFunc | Point latlng | Point? | Projects map coordinates to the coordinates on the screen within map control. |
ProjectScreenLocationToMapCoords | ProjectScreenLocationToMapCoordsFunc | Point screenPoint | Point? | Projects coordinates on the screen to map coordinates. |
Bindable properties
Read only properties
There are some readonly properties, which are not visible in XAML editor, but you can bind them. One condition, they can be bound only with Mode=OneWayToSource
, otherwise it will not work. This means that value can be passed only from map control to the viewmodel.
Example of usage:
<gm:GoogleMap MapCapabilities="{Binding MapCapabilities, Mode=OneWayToSource}" />
Readonly bindable property | Property type | Description |
---|---|---|
IsNativeMapReady | bool | Indicates whether native map is initialized, rendered and ready to use. Otherwise false . |
MapCapabilities | MapCapabilities | Allows to track the availability of each map capability. Always has value after IsNativeMapReady set to true . |
FocusedBuilding | IndoorBuilding | Represents a currently focused building by camera position. Can be null if there is no building focused at the moment. |
ActiveLevel | IndoorLevel | Represents an active level of a currently focused building by camera position. Can be null if there is no building focused at the moment. |
CameraPosition | CameraPosition | Represents current position of the camera and current zoom level. Never null after IsNativeMapReady set to true . |
VisibleRegion | VisibleRegion | Represents the visible map region the last time camera was idle. Always has value after IsNativeMapReady set to true . |
ResetMinMaxZoomAction | Action | Can be bound and called from viewmodel to reset min and max zoom properties. Never null . |
TakeSnapshotFunc | Func<Task<Stream?>> | Can be bound and called from viewmodel to take snapshots of the current map state. Never null . |
AnimateCameraFunc | Func<CameraUpdate, int, Task> | Can be bound and called from viewmodel to move camera to the new position with animation. By default animation duration is 300 ms, but can be changed. Never null . |
MoveCameraAction | Action<CameraUpdate, int> | Can be bound and called from viewmodel to instantly move camera to the new position. Never null . |
ProjectMapCoordsToScreenLocationFunc | Func<Point,Point?> | Can be bound and called from viewmodel to project map coordinates to coordinates on the screen whithin map control. Never null . |
ProjectScreenLocationToMapCoordsFunc | Func<Point,Point?> | Can be bound and called from viewmodel to project coordinates on the screen to map coordinates. Never null . |
Clusters | IEnumerable<Cluster> | Represents a collection of clusters if there are some pins on the map and ClusterAlgorithm is not None . The entire collection is changed each time pins being reclustered. SHould not be changed outside the map control. Default is null . |
Properties related to objects on the map
Bindable property | Property type | Description |
---|---|---|
Polylines | IEnumerable<Polyline> | Represents collection of the polylines. Supports INotifyCollectionChanged collection types, such as ObservableCollection<Polyline> . |
PolylinesSource | IEnumerable | Analogue to the ItemsSource of the CollectionView . Supports INotifyCollectionChanged collection types, such as ObservableCollection<AnyObject> . This is a BindingContext source to the Polylines property. Works in pair with PolylineItemTemplate , otherwise ignored. When this proeprty is set, the Polylines property will be replaced by new collection of polylines created from PolylineItemTemplate . The BindingContext of each polyline will be represented as each item of this collection. |
PolylineItemTemplate | DataTemplate | Analogue to the ItemTemplate of the CollectionView . Supports DataTemplateSelector . Works only in pair with PolylinesSource property, otherwise ignored. The root of this template should be typeof(Polyline) , otherwise will crash. |
Polygons | IEnumerable<Polygon> | Same as Polylines , but designed for polygons. |
PolygonsSource | IEnumerable | Same as PolylinesSource , but designed for polygons. |
PolygonItemTemplate | DataTemplate | Same as PolylineItemTemplate , but designed for polygons. |
Circles | IEnumerable<Circle> | Same as Polylines , but designed for circles. |
CirclesSource | IEnumerable | Same as PolylinesSource , but designed for circles. |
CircleItemTemplate | DataTemplate | Same as PolylineItemTemplate , but designed for circles. |
TileOverlays | IEnumerable<TileOverlay> | Same as Polylines , but designed for tiles. |
TileOverlaysSource | IEnumerable | Same as PolylinesSource , but designed for tiles. |
TileOverlayItemTemplate | DataTemplate | Same as PolylineItemTemplate , but designed for tiles. |
GroundOverlays | IEnumerable<GroundOverlay> | Same as Polylines , but designed for ground overlays. |
GroundOverlaysSource | IEnumerable | Same as PolylinesSource , but designed for ground overlays. |
GroundOverlayItemTemplate | DataTemplate | Same as PolylineItemTemplate , but designed for ground overlays. |
Pins | IEnumerable<Pin> | Same as Polylines , but designed for pins. |
PinsSource | IEnumerable | Same as PolylinesSource , but designed for pins. |
PinItemTemplate | DataTemplate | Same as PolylineItemTemplate , but designed for pins. |
SelectedPin | Pin | Represents selected pin at the moment. null if there is no selected pin at the moment. |
SelectedPinData | object | This is a BindingContext of currently selected pin. null if there is no selected pin at the moment. |
InfoWindowTemplate | DataTemplate | Setting this property will instruct to show desired DataTemplate as 'Info Window' of the pin. Supports DataTemplateSelector . Can be shown only when Pin 's CanBeSelected and ShowInfoWindowOnPinSelection both are true . The BindingContext of this template will be the BindingContext of the pin, or if pin does not have BindingContext set, this will be the pin itself. When null , the default SDK's 'Info Window' will be shown. By default is null . |
MinClusterSize | int | Minimal size of a cluster. By default is 4. |
UseBucketsForClusters | bool | Indicates whether buckets should be used for clusters, such as 10+, 50+ etc. Applicable only if ClusterIconTemplate is null . By default is false . |
ClusterAlgorithm | ClusterAlgorithm | Setting this property to the value different from None will instruct to use clusterization algorithms. If None - clusterization disabled. By default is None . |
ClusterAnimation | IClusterAnimation | Setting this property will instruct to use animated clusters when zooming in/out. If null - animation disabled. By default is new ClusterAnimation() . |
ClusterIconTemplate | DataTemplate | Setting this property will instruct to show desired DataTemplate as cluster icon. Supports DataTemplateSelector . The template should always be of type ImageSource . The BindingContext of this template will be the cluster itself. When null , the default cluster icon will be shown. By default is null . |
ClusterInfoWindowTemplate | DataTemplate | Setting this property will instruct to show desired DataTemplate as 'Info Window' of the cluster. Supports DataTemplateSelector . The BindingContext of this template will be the cluster itself. When null , the default SDK's 'Info Window' will be shown. By default is null . |
Other properties
Bindable property | Property type | Description |
---|---|---|
InitialCameraPosition | CameraUpdate | The initial position of the camera at the moment of map rendering. By default is null . Value of this property will be taken into account only before IsNativeMapReady property is set to true , otherwise it will be ignored. |
RestrictPanningToArea | LatLngBounds? | Setting this property to a non-null value will restrict user to a pan only in the bounds set. Settings this property to a null will remove pan restriction. By default is null . |
IndoorEnabled | bool | Enables indoor buildings to be able to be focuses. Works only with MapType=Normal . By default is false . |
BuildingsEnabled | bool | Enables 3D buildings on the map. Works only with MapType=Normal . By default is false . |
TrafficEnabled | bool | Enables traffic. By default is false . |
MyLocationEnabled | bool | Enables 'My location' to be shown on the map. By default is false . Before setting this property to true you must be sure the location permissions to are granted. |
MapType | MapType | Represents the type of the map. By default is Normal . |
MapColorScheme | MapColorScheme | Represents the map color theme. By default is FollowSystem . Applies only for Android. |
Padding | Thickness | Represents the edge insents of the map. By default is default(Thickness) or 0. |
MinZoom | float | Represents the minimum zoom the camera can take. By default is 2. For different MapType SDK may ignore minimum zoom settings. |
MaxZoom | float | Represents the maximum zoom the camera can take. By default is 21. For different MapType SDK may ignore maximum zoom settings. |
MapStyleJson | string | Setting this property you can change visual styling of the map. It can take url, file with .json extension from assets, or json code directly. More about styling you can read Android and iOS. For iOS this is the only way to change map color scheme. By default is null . |
HandlePoiClick | bool | Indicates whether the map control should handle clicks on 'Point of Interest'. By default is false . |
MyLocationButtonEnabled | bool | Indicates whether the map control should show 'My location' button, this will work only if MyLocationEnabled is true . By default is true . |
IndoorLevelPickerEnabled | bool | Indicates whether the map control should show indoor level picker buttons, this will work only if IndoorEnabled is true . By default is true . |
CompassEnabled | bool | Indicates whether the map control should show compass button. By default is true . |
MapToolbarEnabled | bool | Indicates whether the map control should show toolbar buttons. By default is true . Applies only for Android. |
ZoomControlsEnabled | bool | Indicates whether the map control should show zoom +- buttons. By default is true . Applies only for Android. |
ZoomGesturesEnabled | bool | Indicates whether zoom gestures are enabled. By default is true . |
ScrollGesturesEnabled | bool | Indicates whether pan (scroll) gestures are enabled. By default is true . |
TiltGesturesEnabled | bool | Indicates whether tilt (two fingers swipe) gestures are enabled. By default is true . |
RotateGesturesEnabled | bool | Indicates whether rotate (two fingers) gestures are enabled. By default is true . |
Models
Point
This structure is taken from Microsoft.Maui.Graphics
namespace just to simplify the framework and not to 'invent the bicycle'. Basically it is used to represent coordinates on the map, where X
- Latitude, Y
- Longitude. But in some cases Point
represents just point on the screen where X
- x coordinate, Y
- y coordinate. It depends on the context of usage of this structure.
LatLngBounds
A structure that represents a latitude/longitude aligned rectangle.
Property | Type | Description |
---|---|---|
SouthWest | Point | Southwest corner of the bound. |
NorthEast | Point | Northeast corner of the bound. |
WeightedLatLng
A structure that represents a latitude/longitude coordinate with weight of this coordinate. Used as point of a heat map dataset.
Property | Type | Description |
---|---|---|
Point | Point | Lat/Lon coordinate. |
Intensity | float | Weight of the coordinate. Default is 1f. |
VisibleRegion
VisibleRegion
is a struct. Contains the four points defining the four-sided polygon that is visible in a map's camera. This polygon can be a trapezoid instead of a rectangle, because a camera can have tilt. If the camera is directly over the center of the camera, the shape is rectangular, but if the camera is tilted, the shape will appear to be a trapezoid whose smallest side is closest to the point of view.
Property | Type | Description |
---|---|---|
Bounds | LatLngBounds | The smallest bounding box that includes the visible region defined in this class. |
FarLeft | Point | Point on the map that defines the far left corner of the camera. |
FarRight | Point | Point on the map that defines the far right corner of the camera. |
NearLeft | Point | Point on the map that defines the bottom left corner of the camera. |
NearRight | Point | Point on the map that defines the bottom right corner of the camera. |
MapCapabilities
MapCapabilities
is a struct that allows customers to track the availability of each capability.
Property | Type | Description |
---|---|---|
AreAdvancedMarkersAvailable | bool | true if advanced markers are available. |
IsDataDrivenStylingAvailable | bool | true if data-driven styling is available. |
PointOfInterest
PointOfInterest
is a struct that contains information about a 'Point of Interest' that was clicked on.
Property | Type | Description |
---|---|---|
Position | Point | The position of the POI. |
PlaceId | string | The placeId of the POI. |
Name | string | The name of the POI. |
Gradient
Gradient
is a class to generate a color map from a given array of colors and the fractions that the colors represent by interpolating between their HSV values. This color map is to be used in the HeatMapTileOverlay
.
Can be created only using a constructor. Constructor has 3 parameters: array of colors, array of fractions for colors (these two arrays have to be same length), and color map size to be generated by Gradient
.
ClusterAnimation
ClusterAnimation
is a subclass from BindableObject. Used to customize the behavior of clusters to be animated.
Bindable property | Type | Description |
---|---|---|
EasingIn | Easing | The easing function which is used when animating clusters which are collected together. Default is SinIn |
EasingOut | Easing | The easing function which is used when animating clusters which are being scattered. Default is SinOut |
DurationIn | TimeSpan | The duration of the EasingIn animation. Deafult is 300 ms. |
DurationOut | TimeSpan | The duration of the EasingOut animation. Deafult is 300 ms. |
CameraPosition
An immutable class that aggregates all camera position parameters such as location, zoom level, tilt angle, and bearing. Use CameraPosition.Builder
to construct a CameraPosition
instance, which you can then use in conjunction with CameraUpdateFactory
.
Property | Type | Description |
---|---|---|
Target | Point | The location on the map that the camera is pointing at. |
Zoom | float | Zoom level near the center of the screen. |
Bearing | float | Direction that the camera is pointing in, in degrees clockwise from north. |
Tilt | float | The angle, in degrees, of the camera angle from the nadir (directly facing the Earth). |
CameraUpdate
An abstract class that is used to update camera position. Can be created by different factory methods of CameraUpdateFactory
.
CameraUpdateFactory
A class containing methods for creating CameraUpdate
objects that change a map's camera. Each method returns CameraUpdate
object.
Method | Parameters | Description |
---|---|---|
ZoomIn | Returns a CameraUpdate that zooms in on the map by moving the viewpoint's height closer to the Earth's surface. |
|
ZoomOut | Returns a CameraUpdate that zooms out on the map by moving the viewpoint's height farther away from the Earth's surface. |
|
ZoomTo | float zoom | Returns a CameraUpdate that moves the camera viewpoint to a particular zoom level. |
ZoomBy | float zoomDelta | Returns a CameraUpdate that shifts the zoom level of the current camera viewpoint. |
ZoomBy | float zoomDelta, Point focusPointOnScreen | Returns a CameraUpdate that shifts the zoom level of the current camera viewpoint, focusing at the spcified point on the screen. |
ScrollBy | float dxPixels, float dyPixels | Returns a CameraUpdate that scrolls the camera over the map, shifting the center of view by the specified number of pixels in the x and y directions. |
NewCameraPosition | CameraPosition cameraPosition | Returns a CameraUpdate that moves the camera to a specified CameraPosition . |
NewLatLng | Point latLng | Returns a CameraUpdate that moves the center of the screen to a latitude and longitude specified by a point on the map. |
NewLatLngZoom | Point latLng, float zoom | Returns a CameraUpdate that moves the center of the screen to a latitude and longitude specified by a point on the map, and moves to the given zoom level. |
NewLatLngBounds | LatLngBounds bounds, double padding | Returns a CameraUpdate that transforms the camera such that the specified latitude/longitude bounds are centered on screen at the greatest possible zoom level. |
NewLatLngBounds | LatLngBounds bounds, double padding, Size size | Returns a CameraUpdate that transforms the camera such that the specified latitude/longitude bounds are centered on screen within a bounding box of specified dimensions at the greatest possible zoom level. Applies only for Android. |
FromCenterAndRadius | Point center, double radiusMeters | Returns a CameraUpdate that transforms the camera such that the specified latitude/longitude point are centered on screen within a bounding box of specified radius. |
IndoorBuilding
IndoorBuilding
is a record. Represents a building on the map that can be focused.
Property | Type | Description |
---|---|---|
DefaultLevelIndex | int | The index in the Levels list of the default level for this building. |
IsUnderground | bool | true if the building is entirely underground. |
Levels | IList<IndoorLevel> | Represents levels in the building. |
IndoorLevel
IndoorLevel
is a record. Represents a level in a building. It has only one method Activate()
, when calling this method this building's level will be activated.
Property | Type | Description |
---|---|---|
Name | string | Localized display name for the level, e.g. |
ShortName | string | Localized short display name for the level, e.g. |
CameraMoveReason
CameraMoveReason
is an enum. It indicates the reason of camera movement.
Value | Description |
---|---|
Gesture | Camera motion initiated in response to user gestures on the map. |
ApiAnimation | Non-gesture animation initiated in response to user actions. |
DeveloperAnimation | Developer initiated animation. Applies only for Android. |
MapType
MapType
is an enum. Indicates what type of map tiles that should be displayed.
Value | Description |
---|---|
None | No base map tiles. |
Normal | Basic map. |
Satellite | Satellite imagery. |
Terrain | Topographic data. |
Hybrid | Satellite imagery with roads and labels. |
MapColorScheme
MapColorScheme
is an enum. Indicates what color mode should be used to show the map. Applies only for Android.
Value | Description |
---|---|
Light | Represents light mode. |
Dark | Represents dark mode. |
FolllowSystem | Represents color mode used by system. |
CluserAlgorithm
CluserAlgorithm
is an enum. Represents an clusterization algorithm is currently used.
Value | Description |
---|---|
None | Indicates that clusterization should be disabled. |
Grid | Groups markers into a grid for clustering. This algorithm organizes items into a two-dimensional grid, facilitating the formation of clusters based on proximity within each grid cell. The grid size determines the spatial granularity of clustering, and clusters are created by aggregating items within the same grid cell. |
NonHierarchicalDistance | A simple clustering algorithm with O(nlog n) performance. Resulting clusters are not hierarchical. |
NonHierarchicalView | Algorithm that can be used for managing large numbers of items (>1000 markers). This algorithm works the same way as NonHierarchicalDistance but works, only in visible area. |
GridPreCaching | The same as Grid algorithm, but optimistically fetch clusters for adjacent zoom levels, caching them as necessary. |
NonHierarchicalDistancePreCaching | The same as NonHierarchicalDistance algorithm, but optimistically fetch clusters for adjacent zoom levels, caching them as necessary. |
ViewImageSource
ViewImageSource
is a class derived from MAUI's ImageSource
. It has only one property public View? View { get; set; }
. This type of image source can be used to show any view as image. Can be used in XAML.
TileData
TileData
is a type which contains info about tile to generate proper image for this data. Used as BindingContext
inside TileTempalte
of TileOverlay
.
Property | Type | Description |
---|---|---|
Point | Point | The point on the map with x/y coordinates to build the tile at specific zoom level. |
Zoom | int | Zoom level of the map to build the tile. |
TileSize | int | The size of tile in pixels. Default is 256. |
NoTileImageSource
NoTileImageSource
is a class derived from MAUI's ImageSource
. It has only one static property public static readonly ImageSource Instance = new NoTileImageSource();
. This type of image source should only be used to specify that there is no tile at specific coordinates and zoom level.
Distance
Distance
is an utility static class. It provides utility methods to calculate distance between coordinates or converting other units to meters, and has other useful methods and constants. All methods that operate with distance return distance in meters.
Map objects
There 6 types of objects that can be added to the map: Pin
, Circle
, Polyline
, Polygon
, TileOverlay
, GroundOverlay
. To simplify implementation of the library for polylines and polygons were used already existing classes from Microsoft.Maui.Controls.Shapes
namespace. Circle
is derived from Shape
class. Pin
, TileOverlay
, GroundOverlay
are derived from VisualElement
class.
Pin
Pin
is a subclass from VisualElement
. It is an icon placed at a particular point on the map's surface. A pin icon is drawn oriented against the device's screen rather than the map's surface; i.e., it will not necessarily change orientation due to map rotations, tilting, or zooming. Every property of the pin can be changed any time.
Property | Type | Description |
---|---|---|
Icon | ImageSource | The MAUI's ImageSource that can be used as an icon for pin. This means that you can use different sources, such as url, stream, file etc to set the icon. Also, you can use ViewImageSource to provide a custom view as pin icon. If the icon is left unset, a default icon will be displayed. |
Position | Point | Represents the latitude/longitude position of pin on the map |
AnchorX | double | Represents the X coordinate of the pin's anchor. Can take values 0.0-1.0. Default is 0.5 |
AnchorY | double | Represents the Y coordinate of the pin's anchor. Can take values 0.0-1.0. Default is 1.0 |
Title | string | A text string that's displayed in default info window when the user taps the pin. |
Snippet | string | Additional text that's displayed below the title. |
Draggable | bool | Indicates whether the pin can be dragged. Deafult is false |
ShowInfoWindowOnPinSelection | bool | Indicates whether the pin's should be shown when pin selected. Default is true . |
CanBeSelected | bool | Indicates whether the pin can be selected. Default is true . |
InfoWindowAnchor | Point | Represents the point in the pin image at which to anchor the info window when it is displayed. Default is new Point(0.5, 0.0) . |
Rotation | double | Represents the rotation of the marker in degrees clockwise about the pin's anchor point. Default is 0.0 |
IsFlat | bool | Indicates whether the pin should be flat against the map true or a billboard facing the camera false . Default is false . |
Opacity | double | Sets the opacity of the pin. Default is 1.0 |
ZIndex | int | The draw order for the pins. Pins are drawn in order of the ZIndex , with the highest ZIndex pin drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the pin is visible. Default is true . |
IsEnabled | bool | Indicates whether the pin can be clicked on. If false PinClicked event will not be fired when user clicks the pin, also it will not be selected. Default is true . |
Method | Description |
---|---|
ShowInfoWindow | Shows info window when calling. Info window will be shown only if ShowInfoWindowOnPinSelection is true . |
HideInfoWindow | Hides info window when calling. |
Cluster
Cluster
is a subclass from Pin
. Cluster represents a set of pins which are grouped by maximum distance between them. The center of a cluster is a center of grouped pins in this cluster.
Cluster
has only tow readonly properties: Size
and Items
. Size
returns count of Items
. Items
is set of pins that are clustered.
Note: You should not create clusters manually. Is is made by the framework. Change ClusterAlgorithm
property so clusterization work.
Polyline
Polyline
is a class taken from Microsoft.Maui.Controls.Shapes
namespace just to simplify the framework and not to 'invent the bicycle'. It is a list of points, where line segments are drawn between consecutive points. Every property of the polyline can be changed any time.
Property | Type | Description |
---|---|---|
Points | PointCollection | The vertices of the line. Line segments are drawn between consecutive points on the map. A polyline is not closed by default; to form a closed polyline, the start and end points must be the same. If you change the PointCollection adding or removing some points it will not update the polyline on the map. To change polyline form you need to reset this property by new PointCollection . |
Stroke | Brush | The color of the polyline represented as Brush . This means that you can use SolidColorBrush to paint polyline with a single color or use LinearGradientBrush with two colors to paint polyline with gradient (gradient will be applied from first point to the last point). Polyline will be black if this property not set. Default is null . |
StrokeThickness | double | The thickness of the polyline represented as screen pixels. Default is 0. |
StrokeLineJoin | PenLineJoin | The joint type for all vertices of the polyline except the start and end vertices. Default is Miter . Applies only for Android. |
StrokeLineCap | PenLineCap | The cap at the end vertex of this polyline. Default is Flat . Applies only for Android. |
StrokeDashArray | DoubleCollection | Solid (default, represented by null ) or a sequence of double values to be repeated along the line. Note: due to the iOS SDK implementation dash pattern's dashes and gaps lengths are represented in meters, but there is PolylineAttached.iOSPixelDependentDashedPattern attached property especially designed for this purpose to switch dash pattern to pixels and by default it will use pixels. Note: if you are using dash pattern with gradient paint, you may notice that on iOS it works different in comparison to Android. |
Opacity | double | Sets the opacity of the polyline. Default is 1.0 |
ZIndex | int | The draw order for the polylines. Polylines are drawn in order of the ZIndex , with the highest ZIndex polyline drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the polyline is visible. Default is true . |
IsEnabled | bool | Indicates whether the polyline can be clicked on. If false PolylineClicked event will not be fired when user clicks the polyline. Default is true . |
PolylineAttached.iOSPixelDependentDashedPattern | bool | This is an attached property designed for Polyline . Indicates whether the polyline's dash pattern dashes and gaps lengths should depend on pixels or meters. Default is true . |
PolylineAttached.TextureStamp | string | This is an attached property designed for Polyline . Allows you to create a polyline using a repeated texture. This should be the MauiImage file. |
Polygon
Polygon
is a class taken from Microsoft.Maui.Controls.Shapes
namespace just to simplify the framework and not to 'invent the bicycle'. A polygon on the earth's surface. A polygon can be convex or concave, it may span the 180 meridian and it can have holes that are not filled in. Every property of the polygon can be changed any time.
Property | Type | Description |
---|---|---|
Points | PointCollection | The list of vertices in clockwise or counterclockwise order. It is not necessary for the start and end points to coincide; if they do not, the polygon will be automatically closed. Line segments are drawn between consecutive points in the shorter of the two directions (east or west). If you change the PointCollection adding or removing some points it will not update the polygon on the map. To change polygon form you need to reset this property by new PointCollection . |
Stroke | Brush | The color of the polygon's outline represented as Brush . Unlike Polyline this cannot be gradient, so the only way is to assign a SolidColorBrush . Polygon's outline will be black if this property not set. Default is null . |
Fill | Brush | The fill color represented as Brush . This cannot be gradient, so the only way is to assign a SolidColorBrush . Polygon will be filled with transparent color if this property not set. Default is null . |
StrokeThickness | double | The thickness of the polygon's outline represented as screen pixels. Default is 0. |
StrokeLineJoin | PenLineJoin | The joint type defines the shape to be used when joining adjacent line segments at all vertices of the polygon's outline. Default is Miter . Applies only for Android. |
StrokeDashArray | DoubleCollection | Solid (default, represented by null ) or a sequence of double values to be repeated along the border. Applies only for Android. |
Opacity | double | Sets the opacity of the polygon. Default is 1.0 |
ZIndex | int | The draw order for the polygons. Polygons are drawn in order of the ZIndex , with the highest ZIndex polygon drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the polygon is visible. Default is true . |
IsEnabled | bool | Indicates whether the polygon can be clicked on. If false PolygonClicked event will not be fired when user clicks the polygon. Default is true . |
PolygonAttached.Holes | IEnumerable<IEnumerable<Point>> | This is an attached property designed for Polygon . A hole is a region inside the polygon that is not filled. A hole is specified in exactly the same way as the outline. A hole must be fully contained within the outline. Multiple holes can be specified, however overlapping holes are not supported. |
Circle
Circle
is a subclass of Shape
. A circle on the earth's surface (spherical cap). Every property of the circle can be changed any time.
Property | Type | Description |
---|---|---|
Center | Point | The center of the Circle is specified as a latitude/longitude point on the map. |
Radius | Double | he radius of the circle, specified in meters. It should be zero or greater. Default is 0. |
Stroke | Brush | The color of the circle's outline represented as Brush . This cannot be gradient, so the only way is to assign a SolidColorBrush . Circles's outline will be black if this property not set. Default is null . |
Fill | Brush | The fill color represented as Brush . This cannot be gradient, so the only way is to assign a SolidColorBrush . Circle will be filled with transparent color if this property not set. Default is null . |
StrokeThickness | double | The thickness of the circle's outline represented as screen pixels. Default is 0. |
Opacity | double | Sets the opacity of the circle. Default is 1.0 |
ZIndex | int | The draw order for the circles. Circles are drawn in order of the ZIndex , with the highest ZIndex circle drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the circle is visible. Default is true . |
IsEnabled | bool | Indicates whether the circle can be clicked on. If false CircleClicked event will not be fired when user clicks the circle. Default is true . |
GroundOverlay
GroundOverlay
is a subclass of VisualElement
. A ground overlay is an image that is fixed to a map. Every property of the ground overlay can be changed any time.
Property | Type | Description |
---|---|---|
Image | ImageSource | The image to be used for this overlay. The image will be scaled to fit the position provided. You must specify an image before adding the ground overlay to the map. The MAUI's ImageSource that can be used as an image for overlay. This means that you can use different sources, such as url, stream, file etc to set the image. Also, you can use ViewImageSource to provide a custom view as overlay image. Default is null . |
OverlayBounds | LatLngBounds | The 2D bounds on the Earth in which image is drawn. Changing this value will adjust position accordingly in respect to the anchor. Default is null . |
Position | Point | The position of this overlay, or more specifically, the physical position of its anchor. If this is changed, bounds will be moved around the new position in respect to the anchor. |
WidthRequest | double | Width of the bounds in meters. Used in conjuction with Position property. Setting this property will adjust overlay bounds around the position in respect to the anchor. Applies only for Android. |
HeightRequest | double | Height of the bounds in meters. Used in conjuction with Position and WidthRequest properties. Using it without WidthRequest property will not have any effect. Setting this property will adjust overlay bounds around the position in respect to the anchor. Applies only for Android. |
AnchorX | double | The x coordinate of the anchor. The anchor specifies where this overlay is anchored to the Earth in relation to bounds. If this is modified on Android after adding overlay to the map will not have any effect. If this is modified on iOS, the position will be set to the corresponding new position within bounds. Default is 0.5 |
AnchorY | double | The y coordinate of the anchor. The anchor specifies where this overlay is anchored to the Earth in relation to bounds. If this is modified on Android after adding overlay to the map will not have any effect. If this is modified on iOS, the position will be set to the corresponding new position within bounds. Default is 0.5 |
Bearing | double | The amount in degrees that the image should be rotated in a clockwise direction. The center of the rotation will be the image's anchor. Default is 0. |
Opacity | double | Sets the opacity of the ground overlay. Default is 1.0 |
ZIndex | int | The draw order for the ground overlays. Ground overlay are drawn in order of the ZIndex , with the highest ZIndex ground overlay drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the ground overlay is visible. Default is true . |
IsEnabled | bool | Indicates whether the ground overlay can be clicked on. If false GroundOverlayClicked event will not be fired when user clicks the ground overlay. Default is true . |
TileOverlay
TileOverlay
is a subclass of VisualElement
. A Tile Overlay is a set of images which are displayed on top of the base map tiles. These tiles may be transparent, allowing you to add features to existing maps.
Property | Type | Description |
---|---|---|
TileProvider | Func<Point, int, int, ImageSource?> | The TileProvider provides the images that are used in the tile overlay. |
TileTemplate | DataTemplate | TileTemplate can be used instead of TileProvider and has higher prioriy than TileProvider , this means: firstly TileTemplate property will be checked, and if it null then TileProvider property. This property supports DataTemplateSelector . Template always accepts TileData object as x:DataType for BindingContext and always should be of type ImageSource . For more look into Sample project. |
TileSize | int | Google Maps targets 256 dp (device-independent pixels) when displaying tiles. For high resolution devices, it is recommended that you return high dpi tiles (512x512 px). This is optional. Default is 256. |
FadeIn | bool | Indicates whether the tiles should fade in when appeared. Default is true . |
Opacity | double | Sets the opacity of the tiles. Default is 1.0 |
ZIndex | int | The draw order for the tiles. Tiles are drawn in order of the ZIndex , with the highest ZIndex tiles drawn on top. Default is 0. |
IsVisible | bool | Indicates whether the tiles are visible. Default is true . |
TileProvider
TileProvider
is a property of TileOverlay
. Used to provide tile images based on coordinates, zoom level and tile size.
First parameter is a Point
that represents tile coordinate (this is not Earth coordinate) at specific zoom level. Second parameter represents zoom level. Third parameter represents tile size. Return type is ImageSource?
. You can return all types of image sources as tile images, such as stream, url, file etc. Also, you can return ViewImageSource
to provide a custom view as tile image. If you return null
this means that there is no image available at the moment, but can be available later. To specify that for specific coordinates and zoom should not be any tile there, you must return NoTileImageSource.Instance
.
TileTemplate
TileTemplate
used to provide ImageSource
s for tiles in a way of templating via XAML, this can be very useful if you are trying to build completely MVVM app.
For example:
<gm:GoogleMap TileOverlaysSource="{Binding Items}"
Grid.Row="1" >
<gm:GoogleMap.TileOverlayItemTemplate>
<DataTemplate x:DataType="vm:TileOverlayDataObject">
<gm:TileOverlay Opacity="0.8">
<gm:TileOverlay.TileTemplate>
<DataTemplate x:DataType="gm:TileData">
<UriImageSource>
<UriImageSource.Uri>
<MultiBinding StringFormat="https://mt1.google.com/vt/lyrs=s&x={0}&y={1}&z={2}">
<Binding Path="Point.X" />
<Binding Path="Point.Y" />
<Binding Path="Zoom" />
</MultiBinding>
</UriImageSource.Uri>
</UriImageSource>
</DataTemplate>
</gm:TileOverlay.TileTemplate>
</gm:TileOverlay>
</DataTemplate>
</gm:GoogleMap.TileOverlayItemTemplate>
</gm:GoogleMap>
HeatMapTileOverlay
HeatMapTileOverlay
is a subclass of TileOverlay
. Represents a heat map layer. Should be used only for heat maps.
Note: You should not change or use TileProvider
property for this type of tiles.
Note: Default Opacity
is 0.7 for this type of tiles. Can be changed.
Note: TileTemplate
and TileSize
proeprties are ignored.
Property | Type | Description |
---|---|---|
Data | IEnumerable<WeightedLatLng> | Represents dataset (coordinates and intensities) heat map should be generated for. Must be set before adding this tile overlay to the map. Default is null . |
Gradient | Gradient | Represents custom gradient colors for heat map. Default is null , this means that default gradient will be used. |
Radius | int | Radius of each point of the dataset. Default is 20 for Android and 50 for iOS, minimum 10 for both, maximum 100 for Android and 200 for iOS. |
MaxIntensity | float | Intensity of each point of the dataset. Default is 0f, should take only positive numbers. |
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0-android34.0 is compatible. net8.0-ios18.0 is compatible. net9.0-android was computed. net9.0-ios was computed. |
-
net8.0-android34.0
- Microsoft.Maui.Controls (>= 8.0.3)
- Xamarin.GooglePlayServices.Maps (>= 119.0.0.2)
-
net8.0-ios18.0
- AdamE.Google.iOS.Maps (>= 9.2.0.5)
- Microsoft.Maui.Controls (>= 8.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.