Learn how to display the current device location on a map A map is a collection of layers that are displayed in 2D. It is typically composed of a basemap layer and data layers. Learn more or scene A scene is a collection of layers that are displayed in 3D. It is typically composed of a basemap layer, data layers, and 3D data. Learn more .

display device location

You can display the device location on a map or scene. This is important for workflows that require the user’s current location, such as finding nearby businesses, navigating from the current location, or identifying and collecting geospatial information.

By default, location display uses the device’s location provider. Your app can also process input from other location providers, such as an external GPS receiver or a provider that returns a simulated location. For more information, see the Show device location topic.

This tutorial builds a cross-platform app using the .NET Multi-platform App UI (.NET MAUI) framework. .NET MAUI allows you to build native cross-platform apps from a shared code base. If you’d prefer to build this app as a Windows desktop app, see the Windows Presentation Foundation (WPF) version of this tutorial.

Prerequisites

Before starting this tutorial:

Optionally, you may want to install the ArcGIS Maps SDK for .NET to get access to project templates in Visual Studio (Windows only) and offline copies of the NuGet packages.

Develop or download

You have two options for completing this tutorial:

  1. Option 1: Develop the code or
  2. Option 2: Download the completed solution

Option 1: Develop the code

Open a Visual Studio solution

  1. Open the Visual Studio solution you created by completing the Display a map (.NET MAUI) tutorial.
  2. Continue with the following instructions to display the current device location on the map.

Update the tutorial name used in the project (optional)

The Visual Studio solution, project, and the namespace for all classes currently use the name DisplayAMap. Follow the steps below if you prefer the name to reflect the current tutorial. These steps are not required, your code will still work if you keep the original name.

Android location permissions

Android apps do not have access to location information by default. In the app manifest, you must add properties to request location permissions.

  1. In the Visual Studio > Solution Explorer, navigate to the Platforms\Android folder.

  2. Click AndroidManifest.xml to open the manifest editor.

  3. In the Required permissions section, check ACCESS_COARSE_LOCATION and ACCESS_FINE_LOCATION.

  4. Save and close AndroidManifest.xml.

  5. Location services need to be enabled on your Android device if they aren’t already. Navigate to Settings > Location and make sure Use location is switched on.

iOS and MacOS location permissions

iOS and MacOS prevent apps from accessing location information until the user grants permission. In the Information Property List, you must add a key-value pair to request authorization to use location services.

  1. In the Visual Studio > Solution Explorer, navigate to Platforms\iOS.

  2. Right-click Info.plist. Click Open With.. from the context menu and select Automatic Editor Selector (XML). Click OK to open the file.

  3. Add the required key-value pair.

    Info.plist
    42 collapsed lines
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
    <plist version="1.0">
    <dict>
    <key>LSRequiresIPhoneOS</key>
    <true/>
    <key>UIDeviceFamily</key>
    <array>
    <integer>1</integer>
    <integer>2</integer>
    </array>
    <key>UIRequiredDeviceCapabilities</key>
    <array>
    <string>arm64</string>
    </array>
    <key>UISupportedInterfaceOrientations</key>
    <array>
    <string>UIInterfaceOrientationPortrait</string>
    <string>UIInterfaceOrientationLandscapeLeft</string>
    <string>UIInterfaceOrientationLandscapeRight</string>
    </array>
    <key>UISupportedInterfaceOrientations~ipad</key>
    <array>
    <string>UIInterfaceOrientationPortrait</string>
    <string>UIInterfaceOrientationPortraitUpsideDown</string>
    <string>UIInterfaceOrientationLandscapeLeft</string>
    <string>UIInterfaceOrientationLandscapeRight</string>
    </array>
    <key>CFBundleURLTypes</key>
    <array>
    <dict>
    <key>CFBundleURLName</key>
    <string>My App</string>
    <key>CFBundleURLSchemes</key>
    <array>
    <string>my-app</string>
    </array>
    <key>CFBundleTypeRole</key>
    <string>Editor</string>
    </dict>
    </array>
    <key>XSAppIconAssets</key>
    <string>Assets.xcassets/appicon.appiconset</string>
    <key>NSLocationWhenInUseUsageDescription</key>
    <string>Your location is displayed on the map.</string>
    </dict>
    </plist>
  4. Save and close Info.plist.

  5. Repeat steps 2-4, this time modifying the Info.plist file in the Platforms\MacCatalyst folder.

  6. Location services need to be enabled on your Apple devices if they aren’t already. Navigate to Settings > Privacy & Security > Location Services and make sure Location Services is switched on.

Show the current location

Each map view has its own instance of a LocationDisplay for showing the current location (point) of the device A device is nearly any kind of computer, including desktops, laptops, mobile phones, and tablets. Learn more . The location is displayed as an overlay in the map view A map view is a user interface that displays map layers and graphics in 2D. It controls the area (extent) of the map that is visible and supports user interactions such as pan and zoom. Learn more .

  1. In the Visual Studio > Solution Explorer, double-click MapViewModel.cs to open the file.

  2. Remove code from the SetupMap() function that sets the map’s InitialViewpoint. The map will zoom to the extent An extent is a bounding rectangle with points that delineate an area for a map or scene. Learn more of the current location, so this code is no longer needed.

    MapViewModel.cs
    private void SetupMap()
    {
    // Create a new map with a 'topographic vector' basemap.
    Map = new Map(BasemapStyle.ArcGISTopographic);
    var mapCenterPoint = new MapPoint(-118.805, 34.027, SpatialReferences.Wgs84);
    Map.InitialViewpoint = new Viewpoint(mapCenterPoint, 100000);
    }
  3. Save and close the MapViewModel.cs file.

  4. In the Visual Studio > Solution Explorer, double-click MainPage.xaml.cs to open the file.

  5. Add using statements at the top of the file, after the namespace declaration.

    MainPage.xaml.cs
    namespace DisplayDeviceLocation;
    using Esri.ArcGISRuntime.UI;
    using System.ComponentModel;
    public partial class MainPage : ContentPage
    {
  6. Add a new function DisplayDeviceLocationAsync below the MainPage constructor.

    MainPage.xaml.cs
    public MainPage()
    {
    InitializeComponent();
    }
    private async Task DisplayDeviceLocationAsync()
    {
    }
  7. Add code to DisplayDeviceLocationAsync() that requests access to location.

    MainPage.xaml.cs
    private async Task DisplayDeviceLocationAsync()
    {
    PermissionStatus status = await Permissions.RequestAsync<Permissions.LocationWhenInUse>();
    }
  8. Add code to DisplayDeviceLocationAsync() that enables the LocationDisplay for the map view if permission was granted. Assign a LocationDisplayAutoPanMode that centers the map at the device location.

    MainPage.xaml.cs
    private async Task DisplayDeviceLocationAsync()
    {
    PermissionStatus status = await Permissions.RequestAsync<Permissions.LocationWhenInUse>();
    MyMapView.LocationDisplay.IsEnabled = status == PermissionStatus.Granted || status == PermissionStatus.Restricted;
    MyMapView.LocationDisplay.AutoPanMode = LocationDisplayAutoPanMode.Recenter;
    }
  9. In the MainPage constructor, add code to subscribe to the PropertyChanged event of the map view. If LocationDisplay is the property being changed, call DisplayDeviceLocationAsync().

    MainPage.xaml.cs
    22 collapsed lines
    // Copyright 2023 Esri
    // Licensed under the Apache License, Version 2.0 (the "License");
    // you may not use this file except in compliance with the License.
    // You may obtain a copy of the License at
    //
    // https://www.apache.org/licenses/LICENSE-2.0
    //
    // Unless required by applicable law or agreed to in writing, software
    // distributed under the License is distributed on an "AS IS" BASIS,
    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    // See the License for the specific language governing permissions and
    // limitations under the License.
    namespace DisplayDeviceLocation;
    using Esri.ArcGISRuntime.UI;
    using System.ComponentModel;
    public partial class MainPage : ContentPage
    {
    public MainPage()
    {
    InitializeComponent();
    MyMapView.PropertyChanged += (object sender, PropertyChangedEventArgs e) =>
    {
    // The map view's location display is initially null, so check for a location display property change before enabling it.
    if (e.PropertyName == nameof(LocationDisplay))
    {
    _ = DisplayDeviceLocationAsync();
    }
    };
    }
    private async Task DisplayDeviceLocationAsync()
    {
    PermissionStatus status = await Permissions.RequestAsync<Permissions.LocationWhenInUse>();
    MyMapView.LocationDisplay.IsEnabled = status == PermissionStatus.Granted || status == PermissionStatus.Restricted;
    MyMapView.LocationDisplay.AutoPanMode = LocationDisplayAutoPanMode.Recenter;
    }
    2 collapsed lines
    }

Run the app

Click Debug > Start Debugging (or press <F5> on the keyboard) to run the app. If your app uses user authentication, enter your ArcGIS Online credentials when prompted.

Deploy the app to a Windows, Mac, iOS, or Android device. Allow the app to access your precise location if prompted. You will see your device’s current location displayed on the map. Different location symbols are used depending on the auto pan mode and whether a location is acquired. See LocationDisplayAutoPanMode for details.

Alternatively, you can download the tutorial solution, as follows.

Option 2: Download the solution

  1. Click the Download solution link in the right-hand panel of the page.

  2. Unzip the file to a location on your machine.

  3. Open the .sln file in Visual Studio.

Since the downloaded solution does not contain authentication credentials, you must first set up authentication to create credentials, and then add the developer credentials to the solution.

Set up authentication

To access the secure ArcGIS location services ArcGIS Location Services, also referred to as Location Services, are services hosted by Esri that provide geospatial functionality for developing mapping applications. They include the ArcGIS Basemap Styles service, ArcGIS Static Basemap Tiles service, ArcGIS Places service, ArcGIS Geocoding service, ArcGIS Routing service, ArcGIS GeoEnrichment service, and ArcGIS Elevation service. An ArcGIS Location Platform or ArcGIS Online account is required to use the services. Learn more used in this tutorial, you must implement API key authentication API key authentication is a type of authentication that uses an API key to authenticate requests to ArcGIS services and secure portal items. Learn more or user authentication User authentication is a type of authentication that allows users with an ArcGIS account to sign into an application and allow it to access ArcGIS content, services, and resources on their behalf. The typical authorization protocol used is OAuth2.0. Learn more using an ArcGIS Location Platform An ArcGIS Location Platform account, formerly known as an ArcGIS Developer account, is an identity associated with an ArcGIS Location Platform subscription. Learn more or an ArcGIS Online An ArcGIS Online account, also known as an ArcGIS Organization account, is an identity associated with an ArcGIS Online subscription. It can be used to access ArcGIS tools and develop applications with ArcGIS location services for an organization. Learn more account.

To complete this tutorial, click on the tab in the switcher below for your authentication type of choice, either API key authentication or User authentication.

Create a new API key access token An access token is an authorization string that provides access to secure ArcGIS content, data, and services. Its capabilities are determined by the privileges it supports. It is obtained by implementing API key authentication, User authentication, or App authentication. Learn more with privileges Privileges are a set of permissions assigned to ArcGIS accounts, developer credentials, and applications that grant access to secure resources and functionality in ArcGIS. Learn more to access the secure resources used in this tutorial.

  1. Complete the Create an API key tutorial and create an API key with the following privilege(s) Privileges are a set of permissions assigned to ArcGIS accounts, developer credentials, and applications that grant access to secure resources and functionality in ArcGIS. Learn more :

    • Privileges
      • Location services > Basemaps
  2. Copy and paste the API key access token into a safe location. It will be used in a later step.

Set developer credentials in the solution

To allow your app users to access ArcGIS location services ArcGIS Location Services, also referred to as Location Services, are services hosted by Esri that provide geospatial functionality for developing mapping applications. They include the ArcGIS Basemap Styles service, ArcGIS Static Basemap Tiles service, ArcGIS Places service, ArcGIS Geocoding service, ArcGIS Routing service, ArcGIS GeoEnrichment service, and ArcGIS Elevation service. An ArcGIS Location Platform or ArcGIS Online account is required to use the services. Learn more , use the developer credentials that you created in the Set up authentication step to authenticate requests for resources.

  1. In the Solution Explorer, open MauiProgram.cs by double-clicking.

  2. Update the call to UseApiKey() on the config parameter to set your API key access token.

    MauiProgram.cs
    25 collapsed lines
    // Copyright 2023 Esri
    // Licensed under the Apache License, Version 2.0 (the "License");
    // you may not use this file except in compliance with the License.
    // You may obtain a copy of the License at
    //
    // https://www.apache.org/licenses/LICENSE-2.0
    //
    // Unless required by applicable law or agreed to in writing, software
    // distributed under the License is distributed on an "AS IS" BASIS,
    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    // See the License for the specific language governing permissions and
    // limitations under the License.
    namespace DisplayAMap;
    using Esri.ArcGISRuntime;
    using Esri.ArcGISRuntime.Maui;
    using Microsoft.Extensions.Logging;
    public static class MauiProgram
    {
    public static MauiApp CreateMauiApp()
    {
    var builder = MauiApp.CreateBuilder();
    builder
    .UseMauiApp<App>()
    .ConfigureFonts(fonts =>
    {
    fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
    fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
    });
    builder.UseArcGISRuntime(config =>
    {
    config.UseApiKey("YOUR_ACCESS_TOKEN");
    });
    #if DEBUG
    builder.Logging.AddDebug();
    #endif
    4 collapsed lines
    return builder.Build();
    }
    }
  3. Remove the line of code that sets the user authentication handler.

    MauiProgram.cs
    25 collapsed lines
    // Copyright 2023 Esri
    // Licensed under the Apache License, Version 2.0 (the "License");
    // you may not use this file except in compliance with the License.
    // You may obtain a copy of the License at
    //
    // https://www.apache.org/licenses/LICENSE-2.0
    //
    // Unless required by applicable law or agreed to in writing, software
    // distributed under the License is distributed on an "AS IS" BASIS,
    // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    // See the License for the specific language governing permissions and
    // limitations under the License.
    namespace DisplayAMap;
    using Esri.ArcGISRuntime;
    using Esri.ArcGISRuntime.Maui;
    using Microsoft.Extensions.Logging;
    public static class MauiProgram
    {
    public static MauiApp CreateMauiApp()
    {
    var builder = MauiApp.CreateBuilder();
    builder
    .UseMauiApp<App>()
    .ConfigureFonts(fonts =>
    {
    fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
    fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
    });
    builder.UseArcGISRuntime(config =>
    {
    config.UseApiKey("YOUR_ACCESS_TOKEN");
    });
    // Set up the AuthenticationManager to use OAuth for secure ArcGIS Online requests.
    UserAuth.ArcGISLoginPrompt.RegisterOAuthConfig();
    #if DEBUG
    builder.Logging.AddDebug();
    #endif
    4 collapsed lines
    return builder.Build();
    }
    }
  4. Save and close the MauiProgram.cs file.

Best Practice: The access token is stored directly in the code as a convenience for this tutorial. Do not store credentials directly in source code in a production environment.

Run the app

Click Debug > Start Debugging (or press <F5> on the keyboard) to run the app. If your app uses user authentication, enter your ArcGIS Online credentials when prompted.

Deploy the app to a Windows, Mac, iOS, or Android device. Allow the app to access your precise location if prompted. You will see your device’s current location displayed on the map. Different location symbols are used depending on the auto pan mode and whether a location is acquired. See LocationDisplayAutoPanMode for details.

What’s next?

Learn how to use additional API features, ArcGIS location services, and ArcGIS tools in these tutorials: