MPowerKit.GoogleMaps 1.0.2

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package MPowerKit.GoogleMaps --version 1.0.2                
NuGet\Install-Package MPowerKit.GoogleMaps -Version 1.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="MPowerKit.GoogleMaps" Version="1.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MPowerKit.GoogleMaps --version 1.0.2                
#r "nuget: MPowerKit.GoogleMaps, 1.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install MPowerKit.GoogleMaps as a Cake Addin
#addin nuget:?package=MPowerKit.GoogleMaps&version=1.0.2

// Install MPowerKit.GoogleMaps as a Cake Tool
#tool nuget:?package=MPowerKit.GoogleMaps&version=1.0.2                

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.

Nuget

"Buy Me A Coffee"

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.

Table Of Contents

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<GoogleMap, NativeMapView, GoogleMapHandler>>> ManagerMapper = new()
{
    { nameof(MapManager), () => new MapManager() },
    { nameof(CameraManager), () => new CameraManager() },
    { nameof(UiSettingsManager), () => new UiSettingsManager() },
    { nameof(PolylineManager), () => new PolylineManager() },
    { nameof(PolygonManager), () => new PolygonManager() },
    { nameof(CircleManager), () => new CircleManager() },
    { nameof(TileOverlayManager), () => new TileOverlayManager() },
    { nameof(GroundOverlayManager), () => new GroundOverlayManager() },
    { nameof(PinManager), () => new PinManager() },
};

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(nameof(GroundOverlayManager));

If you want to change implementation, you can do next:

GoogleMapHandler.ManagerMapper[nameof(Pins)] = () => 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<GoogleMap, NativeMapView, GoogleMapHandler>)

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.

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.
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 map 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.
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.
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.
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.
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.

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.
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

GroundOverlay 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. You must specify the tile provider before tile is added to the map. The tile provider cannot be changed once it has been added; however, you can modify the behavior of the tile provider to return different images for specific coordinates. If the tiles provided by the tile provider change, you must call clearTileCache() afterwards to ensure that the previous tiles are no longer rendered.
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. Can be set only once. 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 there is should not be any tile, you must return NoTileImageSource.Instance.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-android34.0 is compatible.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-ios18.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.4 0 1/23/2025
2.0.3 0 1/23/2025
2.0.2 43 1/21/2025
2.0.1 44 1/21/2025
2.0.0 45 1/20/2025
1.0.3 55 1/9/2025
1.0.2 90 12/26/2024
1.0.1 88 12/23/2024
1.0.0 93 12/22/2024