View on GitHub Sample viewer app

Display a basemap centered at an initial location and scale.

Image of Set initial map location sample

Use case

You can set a map’s initial location when you want to highlight a particular feature or area to establish the context.

How to use the sample

When the map loads, note the specific location and scale of the initial map view.

How it works

  1. Create a Map, specifying a basemap type, latitude and longitude in WGS84, and a level of detail.
  2. Display the map in a map view.

Relevant API

  • BasemapType
  • Map
  • MapView

About the data

The map opens with satellite imagery of a guitar-shaped field in the Pampas region of north central Argentina.

Tags

basemap, center, envelope, extent, initial, lat, latitude, level of detail, location, LOD, long, longitude, scale, zoom level

Sample Code

MainActivity.kt MainActivity.kt SetInitialMapLocationViewModel.kt SetInitialMapLocationScreen.kt
/* Copyright 2025 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
*
* http://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.
*
*/
package com.esri.arcgismaps.sample.setinitialmaplocation
import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Surface
import androidx.compose.runtime.Composable
import com.arcgismaps.ApiKey
import com.arcgismaps.ArcGISEnvironment
import com.esri.arcgismaps.sample.sampleslib.theme.SampleAppTheme
import com.esri.arcgismaps.sample.setinitialmaplocation.screens.SetInitialMapLocationScreen
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
// authentication with an API key or named user is
// required to access basemaps and other location services
ArcGISEnvironment.apiKey = ApiKey.create(BuildConfig.ACCESS_TOKEN)
setContent {
SampleAppTheme {
SetInitialMapLocationApp()
}
}
}
@Composable
private fun SetInitialMapLocationApp() {
Surface(color = MaterialTheme.colorScheme.background) {
SetInitialMapLocationScreen(
sampleName = getString(R.string.set_initial_map_location_app_name)
)
}
}
}