Getting Started with Xamarin Maps (SfMaps)

21 Nov 202422 minutes to read

This section explains the steps required to configure the maps control and customize its elements.

Assembly deployment

After installing Essential Studio® for Xamarin, you can find all the required assemblies in the installation folders, {Syncfusion Essential Studio Installed location} \Essential Studio\{Version #}\Xamarin\lib.

E.g.: C:\Program Files (x86) \Syncfusion\Essential Studio\19.1.0.54\Xamarin\lib

NOTE

Assemblies can be found in unzipped package location(Documents/Syncfusion/{Version #}/Xamarin/lib) in Mac.

Adding SfMaps reference

You can add SfMaps reference using one of the following methods:

Method 1: Adding SfMaps reference from nuget.org

Syncfusion Xamarin components are available in nuget.org. To add SfMaps to your project, open the NuGet package manager in Visual Studio, search for Syncfusion.Xamarin.SfMaps, and then install it.

Adding SfMaps reference from NuGet

NOTE

Install the same version of SfMaps NuGet in all the projects.

Method 2: Adding SfMaps reference from toolbox

Syncfusion also provides Xamarin Toolbox. Using this toolbox, you can drag the SfMaps control to the XAML page. It will automatically install the required NuGet packages and add the namespace to the page. To install Syncfusion Xamarin Toolbox, refer to Toolbox.

Method 3: Adding SfMaps assemblies manually from the installed location

If you prefer to manually reference the assemblies instead referencing from NuGet, add the following assemblies in respective projects.

Location: {Installed location}/{version}/Xamarin/lib

PCL Syncfusion.SfMaps.XForms.dll
Syncfusion.Core.XForms.dll
Syncfusion.Licensing.dll
Android Syncfusion.SfMaps.Android.dll
Syncfusion.SfMaps.XForms.Android.dll
Syncfusion.SfMaps.XForms.dll
Syncfusion.Core.XForms.dll
Syncfusion.Core.XForms.Android.dll
Syncfusion.Licensing.dll
iOS Syncfusion.SfMaps.iOS.dll
Syncfusion.SfMaps.XForms.iOS.dll
Syncfusion.SfMaps.XForms.dll
Syncfusion.Core.XForms.dll
Syncfusion.Core.XForms.iOS.dll
Syncfusion.Licensing.dll
UWP Syncfusion.SfMaps.UWP.dll
Syncfusion.SfMaps.XForms.UWP.dll
Syncfusion.SfMaps.XForms.dll
Syncfusion.Core.XForms.dll
Syncfusion.Core.XForms.UWP.dll
Syncfusion.Licensing.dll

NOTE

To know more about obtaining our components, refer to these links for Mac and Windows.

IMPORTANT

Starting with v16.2.0.x, if you reference Syncfusion assemblies from the trial setup or from the NuGet feed, you also have to include a license key in your projects. Please refer to Syncfusion license key to know about registering Syncfusion license key in your Xamarin application to use our components.

Launching an application on each platform with SfMaps.

To use the SfMaps control inside an application, each platform requires some additional configurations. The configurations vary from platform to platform and is discussed in the following sections:

NOTE

If you are adding the references from toolbox, this step is not needed.

iOS

To launch the SfMaps in iOS, call the SfMapsRenderer.Init() in the FinishedLaunching overridden method of the AppDelegate class after the Xamarin.Forms Framework has been initialized and before the LoadApplication is called, as demonstrated in the following code example.

  • C#
  • public override bool FinishedLaunching(UIApplication app, NSDictionary options)
    {
        
        global::Xamarin.Forms.Forms.Init ();
        Syncfusion.SfMaps.XForms.iOS.SfMapsRenderer.Init();
        LoadApplication (new App ());
        
    }

    Universal Windows Platform (UWP)

    You need to initialize the maps view assemblies in App.xaml.cs in UWP project as demonstrated in the following code samples. This is required to deploy the application with maps in Release mode in UWP platform.

  • C#
  • // In App.xaml.cs
    
    protected override void OnLaunched(LaunchActivatedEventArgs e)
        {
            
        	    rootFrame.NavigationFailed += OnNavigationFailed;
        
            // Add `using System.Reflection;`
            List<Assembly> assembliesToInclude = new List<Assembly>();
        
            // Now, add all the assemblies your app uses                 
            assembliesToInclude.Add(typeof(Syncfusion.SfMaps.XForms.UWP.SfMapsRenderer).GetTypeInfo().Assembly);
    		
            // Replaces Xamarin.Forms.Forms.Init(e);        
            Xamarin.Forms.Forms.Init(e, assembliesToInclude);	
                 
        }

    Android

    The Android platform does not require any additional configuration to render the maps.

    Adding namespace

    Add the following namespace.

    xmlns:maps="clr-namespace:Syncfusion.SfMaps.XForms;assembly=Syncfusion.SfMaps.XForms"
    using Syncfusion.SfMaps.XForms;

    Initializing maps

    Create an instance for the maps control, and add it as content.

    <maps:SfMaps >
      
    </maps:SfMaps>
    SfMaps map = new SfMaps();
    	
    this.Content = map;

    Adding layers

    The maps control is maintained through layers. It can accommodate one or more shape file layers.

    <maps:SfMaps>
    
    <maps:SfMaps.Layers>
    
    <maps:ShapeFileLayer/>
    
    </maps:SfMaps.Layers>  
    
    </maps:SfMaps>
    SfMaps map = new SfMaps();
    
    ShapeFileLayer layer = new ShapeFileLayer();
    
    map.Layers.Add(layer);
    	
    this.Content = map;

    Adding shape files

    A shape file is a set of files that is stored in a non-topological geometry with the attribute information for the spatial features and records in a data set.

    The maps control supports reading and loading the shape files. A shape file can be a set of files or a single file. Generally, a shape file contains the following files:

    • Main file (.shp)
    • dBase file (.dbf)

    Android

    • Add necessary shape files to the Assets folder of ProjectFileName.Droid.
    • Right-click the added shape file, and navigate to properties.
    • Choose the AndroidAsset option under BuildAction of respective shape file.

    iOS

    • Add necessary shape files to the Resources folder of ProjectFileName.iOS.
    • Right-click the added shape file, and navigate to properties.
    • Choose the BundleResource option under BuildAction of respective shape file.

    UWP

    • Add necessary shapes files in a folder, and name it as ShapeFiles. Add this ShapeFiles folder into the Assets folder of ProjectFileName.UWP.
    • Right-click the added shape file, and navigate to properties.
    • Choose the EmbeddedResource option under BuildAction of respective shape file.

    The Uri property in shape file layer is used to retrieve the location of the shape file that is added.

    <maps:SfMaps x:Name="sfmap"  BackgroundColor="White" >
                    <maps:SfMaps.Layers >
                        <maps:ShapeFileLayer Uri="usa_state.shp"  >                        
                        </maps:ShapeFileLayer>
                    </maps:SfMaps.Layers>
        </maps:SfMaps>
    SfMaps map = new SfMaps();
    map.BackgroundColor = Color.White;
    ShapeFileLayer layer = new ShapeFileLayer();
    layer.Uri = "usa_state.shp";
    map.Layers.Add(layer);
    this.Content = map;

    The following screenshot illustrates the result of adding shape files.

    Xamarin maps shape files

    GeoJSON support

    The maps control supports reading and loading the GeoJSON files. The GeoJSON file contains attribute information for the spatial features and coordinates in a dataset.

    <maps:ShapeFileLayer Uri="usa_state.json">                        
     </maps:ShapeFileLayer>
    ShapeFileLayer layer = new ShapeFileLayer();
     layer.Uri = "usa_state.json";

    Data binding

    Data can be bound to the shape file layer using the ItemsSource, ShapeIDPath, and ShapeIdTableField properties.

    The Populate data section gives the detailed explanation of data binding.

    <maps:SfMaps.Layers >
    <maps:ShapeFileLayer Uri="usa_state.shp" ItemsSource="{Binding Data}"
                                              ShapeIDPath="State" ShapeIDTableField="STATE_NAME" >
    </maps:ShapeFileLayer>
                    </maps:SfMaps.Layers>
    ShapeFileLayer layer = new ShapeFileLayer();
                layer.Uri = "usa_state.shp";
                layer.ItemsSource =viewModel.Data;
                layer.ShapeIDTableField = "STATE_NAME";
                layer.ShapeIDPath = "State";			
                map.Layers.Add(layer);

    Adding markers

    Markers are used to identify the shapes. They can be added to the shape file layers as demonstrated in the following code sample. Markers can be customized using the MarkerSettings property in the shape file layer.

    The detailed explanation of marker and its customization are provided under Markers section.

    <maps:ShapeFileLayer.Markers>
                  <maps:MapMarker Label = "California" Latitude = "37" Longitude = "-120">                
                  </maps:MapMarker>
     </maps:ShapeFileLayer.Markers>
    MapMarker marker = new MapMarker();
    marker.Label = "California";
    marker.Latitude = "37";
    marker.Longitude = "-120";
    layer.Markers.Add(marker);

    Color mapping

    The color mapping support allows you customize the shape colors based on the underlying value of shape received from the bound data. Both the range color mapping and equal color mapping are supported in maps.

    The detailed explanation of color mapping is provided in colorMapping section.

    <maps:ShapeSetting.ColorMappings>
    <maps:EqualColorMapping Color="#D84444" LegendLabel="Romney" Value = "Romney"></maps:EqualColorMapping>
    <maps:EqualColorMapping Color="#316DB5" LegendLabel="Obama" Value="Obama"></maps:EqualColorMapping>
    </maps:ShapeSetting.ColorMappings>
    EqualColorMapping colorMapping = new EqualColorMapping();
                colorMapping.Color = Color.FromHex("#D84444");
                colorMapping.LegendLabel = "Romney";
                colorMapping.Value = "Romney";
    
                EqualColorMapping colorMapping1 = new EqualColorMapping();
                colorMapping1.Color = Color.FromHex("#316DB5");
                colorMapping1.LegendLabel = "Obama";
                colorMapping1.Value = "Obama";
    
                ShapeSetting shapeSetting = new ShapeSetting();           
                shapeSetting.ColorMappings.Add(colorMapping);
                shapeSetting.ColorMappings.Add(colorMapping1);

    Adding legends

    Legends interpret what the map displays. They can be added to the shape file layer as demonstrated in the following code sample. Legends will be displayed based on the data bound to the layer, and color mapping plays a major role in enabling legends.

    The detailed explanation of legend is provided under Legend section.

    <maps:ShapeFileLayer.LegendSettings>
       <maps:MapLegendSetting ShowLegend="true" LegendPosition="75,90"/>
    </maps:ShapeFileLayer.LegendSettings>
    MapLegendSetting setting = new MapLegendSetting();
    setting.ShowLegend = true;
    setting.LegendPosition = new Point(75, 90);
    layer.LegendSettings = setting;

    The following code sample gives you the complete code for map with markers and legends.

    <maps:SfMaps x:Name="sfmap"  BackgroundColor="White"  >
                    <maps:SfMaps.Layers >
                        <maps:ShapeFileLayer Uri="usa_state.shp" ShapeIDPath="State" 
                                             ShapeIDTableField="STATE_NAME" 
                                           ItemsSource="{Binding Data}"
                                             >
                            <maps:ShapeFileLayer.Markers>
                                <maps:MapMarker Label = "California" Latitude = "37" Longitude = "-120">
                                </maps:MapMarker>
                            </maps:ShapeFileLayer.Markers>
                            
                            <maps:ShapeFileLayer.MarkerSettings>
                                
                                <maps:MapMarkerSetting IconColor="LimeGreen" IconSize="25" 
                                                       LabelColor="White" LabelSize="20">
                                </maps:MapMarkerSetting>
    
                            </maps:ShapeFileLayer.MarkerSettings>
    
                            <maps:ShapeFileLayer.ShapeSettings>
                                <maps:ShapeSetting ShapeColorValuePath="Candidate" ShapeValuePath="Candidate"   >
                                    <maps:ShapeSetting.ColorMappings>
    
                                        <maps:EqualColorMapping Color="#D84444" LegendLabel="Romney" Value = "Romney"></maps:EqualColorMapping>
                                        <maps:EqualColorMapping Color="#316DB5" LegendLabel="Obama" Value="Obama"></maps:EqualColorMapping>
                                    </maps:ShapeSetting.ColorMappings>
                                </maps:ShapeSetting>
                            </maps:ShapeFileLayer.ShapeSettings>
    
                            <maps:ShapeFileLayer.LegendSettings>
                                <maps:MapLegendSetting ShowLegend="True"  
                                                       LegendPosition="30,70">
                                    <maps:MapLegendSetting.IconSize>
                                        <Size Width="20" Height="20"></Size>
                                    </maps:MapLegendSetting.IconSize>
                                </maps:MapLegendSetting>
                            </maps:ShapeFileLayer.LegendSettings>
                            
                        </maps:ShapeFileLayer>
                    </maps:SfMaps.Layers>
                </maps:SfMaps>
    SfMaps map = new SfMaps();
    
                map.BackgroundColor = Color.White;
                ShapeFileLayer layer = new ShapeFileLayer();
                layer.Uri = "usa_state.shp";
                layer.ItemsSource = viewModel.Data;
                layer.ShapeIDTableField = "STATE_NAME";
                layer.ShapeIDPath = "State";
                map.Layers.Add(layer);
    
                MapLegendSetting legendSetting = new MapLegendSetting();
                legendSetting.ShowLegend = true;
                legendSetting.LegendPosition = new Point(30, 70);
                legendSetting.IconSize = new Size(20, 20);
                layer.LegendSettings = legendSetting;
    
                MapMarker marker = new MapMarker();
                marker.Label = "California";
                marker.Latitude = "37";
                marker.Longitude = "-120";
                layer.Markers.Add(marker);
    
                MapMarkerSetting markerSetting = new MapMarkerSetting();
                markerSetting.IconColor = Color. LimeGreen;
                markerSetting.IconSize = 25;
                markerSetting.LabelColor = Color.White;
                markerSetting.LabelSize = 20;
                layer.MarkerSettings = markerSetting;
    
                EqualColorMapping colorMapping = new EqualColorMapping();
                colorMapping.Color = Color.FromHex("#D84444");
                colorMapping.LegendLabel = "Romney";
                colorMapping.Value = "Romney";
    
                EqualColorMapping colorMapping1 = new EqualColorMapping();
                colorMapping1.Color = Color.FromHex("#316DB5");
                colorMapping1.LegendLabel = "Obama";
                colorMapping1.Value = "Obama";
    
                ShapeSetting shapeSetting = new ShapeSetting();
                shapeSetting.ShapeValuePath = "Candidate";
                shapeSetting.ShapeColorValuePath = "Candidate";
                shapeSetting.ColorMappings.Add(colorMapping);
                shapeSetting.ColorMappings.Add(colorMapping1);
                layer.ShapeSettings = shapeSetting;
    
                this.Content = map;

    The following screenshot illustrates the result of the above code sample.

    Xamarin maps getting started

    You can download the complete Getting started sample.

    NOTE

    You can refer to our Xamarin Maps feature tour page for its groundbreaking feature representations.

    See also

    How to make SfMaps to work in UWP in release mode when .NET Native tool chain is enabled

    How to resolve SfMaps not rendering issue in iOS and UWP