Harita ekleme

Platform seçin: Android iOS JavaScript

Bu konuda, Android için Haritalar SDK'sını kullanacak şekilde projeyi yapılandırdıktan sonra Android uygulamasına temel bir haritanın nasıl ekleneceği açıklanmaktadır. Eklediğiniz haritanın türünü ve özelliklerini değiştirebilirsiniz.

Genel Bakış

Android için Haritalar SDK'sı, bir haritanın yaşam döngüsünü, işlevini ve verilerini yönetmek için uygulamanızın kullanabileceği çeşitli sınıflar sağlar. Sınıflar, haritanın ilk durumunu ayarlama ve çalışma zamanında kullanıcıdan gelen hareket girişine yanıt verme gibi Android kullanıcı arayüzü modeline dayalı kullanıcı etkileşimlerini destekler.

Haritalarla ilgili ana arayüz ve sınıflar:

  • GoogleMap: Temel harita özelliklerini ve verilerini yönetmek için giriş noktası. Uygulamanız yalnızca bir SupportMapFragment veya MapView nesnesinden alındıktan sonra bir GoogleMap nesnesine erişebilir.

  • SupportMapFragment: GoogleMap nesnesinin yaşam döngüsünü yönetmek için kullanılan bir fragman.

  • MapView: GoogleMap nesnesinin yaşam döngüsünü yönetmek için kullanılan bir görünüm.

  • OnMapReadyCallback: GoogleMap nesnesi için etkinlikleri ve kullanıcı etkileşimini yöneten bir geri çağırma arayüzü.

GoogleMap nesnesi aşağıdaki işlemleri otomatik olarak gerçekleştirir:

  • Google Haritalar hizmetine bağlanıyor.
  • Harita parçaları indiriliyor.
  • Cihaz ekranında karolar gösteriliyor.
  • Kaydırma ve yakınlaştırma gibi çeşitli kontrolleri gösterme
  • Haritayı hareket ettirerek ve yakınlaştırıp uzaklaştırarak kaydırma ve yakınlaştırma hareketlerine yanıt verme.

Uygulamanızda GoogleMap nesnesi kullanmak için harita için kapsayıcı nesnesi olarak bir SupportMapFragment veya MapView nesnesi kullanmanız ve ardından GoogleMap nesnesini kapsayıcıdan almanız gerekir. Kapsayıcı sınıfları bir Android fragmanından veya görünümünden türetildiği için haritaya, Android temel sınıflarının yaşam döngüsü yönetimi ve kullanıcı arayüzü özelliklerini sağlar. SupportMapFragment sınıfı, GoogleMap nesnesi için daha modern ve yaygın bir kapsayıcıdır.

Kodu görüntüleme

Aşağıdaki kod, bir snippet'i statik olarak eklerken bu konuda kullanılan tam Java etkinliğinden alınmıştır. Android projesi, Boş proje şablonundan oluşturuldu ve ardından proje yapılandırması kılavuzuna göre güncellendi. Bu konudaki adımları uyguladıktan sonra kodunuz proje şablonuna göre farklılık gösterebilir.

  package com.example.mapsetup;

  import androidx.appcompat.app.AppCompatActivity;

  import android.os.Bundle;

  import com.google.android.gms.maps.GoogleMap;
  import com.google.android.gms.maps.OnMapReadyCallback;
  import com.google.android.gms.maps.SupportMapFragment;
  import com.google.android.gms.maps.model.LatLng;
  import com.google.android.gms.maps.model.MarkerOptions;

  // Implement OnMapReadyCallback.
  public class MainActivity extends AppCompatActivity implements OnMapReadyCallback {

      @Override
      protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          // Set the layout file as the content view.
          setContentView(R.layout.activity_main);

          // Get a handle to the fragment and register the callback.
          SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
                  .findFragmentById(R.id.map);
          mapFragment.getMapAsync(this);

      }

      // Get a handle to the GoogleMap object and display marker.
      @Override
      public void onMapReady(GoogleMap googleMap) {
          googleMap.addMarker(new MarkerOptions()
                  .position(new LatLng(0, 0))
                  .title("Marker"));
      }
  }

Harita eklemek için

Bu bölümde, harita kapsayıcısı olarak bir parça kullanılarak temel bir haritanın nasıl ekleneceği açıklanmaktadır. Bunun yerine bir görünüm de kullanabilirsiniz. Örnek için GitHub'daki RawMapViewDemoActivity dosyasına bakın.

Temel adımlar:

  1. SDK'yı almak, API anahtarı edinmek ve gerekli çerçeveleri eklemek için şu makaledeki adımları uygulayın:

    1. Google Cloud Console'da ayarlama

    2. API anahtarı kullanma

    3. Android Studio projesi oluşturma

  2. Haritayı işleyen bir SupportMapFragment nesnesi ekleyin. Parçayı statik veya dinamik olarak ekleyebilirsiniz.

  3. OnMapReadyCallback arayüzünü uygulayın.

  4. İçerik görünümü olarak sayfa düzeni dosyasını ayarlayın.

  5. Parçayı statik olarak eklediyseniz parçanın bir adını alın.

  6. Geri aramayı kaydedin.

  7. GoogleMap nesnesine erişin.

SupportMapFragment nesnesi ekleme

Uygulamanıza statik veya dinamik olarak bir SupportMapFragment nesnesi ekleyebilirsiniz. En basit yöntem, statik olarak eklemektir. Parçayı dinamik olarak eklerseniz parça üzerinde ek işlemler (ör. çalışma zamanında kaldırma ve değiştirme) yapabilirsiniz.

Statik olarak bir parça eklemek için

Haritayı işleyecek etkinliğin düzenleme dosyasında:

  1. fragment öğesi ekleyin.
  2. Ad beyanını ekleyin xmlns:map="http://schemas.android.com/apk/res-auto". Bu, maps özel XML özelliklerinin kullanılmasını sağlar.
  3. fragment öğesinde android:name özelliğini com.google.android.gms.maps.SupportMapFragment olarak ayarlayın.
  4. fragment öğesine android:id özelliğini ekleyin ve bu özelliği R.id.map kaynak kimliğine (@+id/map) ayarlayın.

Örneğin, fragment öğesi içeren tam bir düzen dosyası aşağıda verilmiştir:

<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:map="http://schemas.android.com/apk/res-auto"
    android:name="com.google.android.gms.maps.SupportMapFragment"
    android:id="@+id/map"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

Dinamik olarak bir snippet eklemek için

Etkinlikte:

  1. SupportMapFragment örneği oluşturun.
  2. Fragment'i etkinliğe ekleyen bir işlem gönderin. Daha fazla bilgi için Parça İşlemleri başlıklı makaleyi inceleyin.

Örneğin:

Kotlin

val mapFragment = SupportMapFragment.newInstance()
supportFragmentManager
    .beginTransaction()
    .add(R.id.my_container, mapFragment)
    .commit()

      

Java

SupportMapFragment mapFragment = SupportMapFragment.newInstance();
getSupportFragmentManager()
    .beginTransaction()
    .add(R.id.my_container, mapFragment)
    .commit();

      

OnMapReadyCallback arayüzünü uygulama

Etkinlik beyanını aşağıdaki gibi güncelleyin:

Kotlin

class MainActivity : AppCompatActivity(), OnMapReadyCallback {

    // ...
}

      

Java

class MainActivity extends AppCompatActivity implements OnMapReadyCallback {
    // ...
}

      

İçerik görünümünü ayarlama

Etkinliğinizin onCreate yönteminde setContentView yöntemini çağırın ve düzen dosyasını içerik görünümü olarak ayarlayın.

Örneğin, düzen dosyası main.xml olarak adlandırılmışsa:

Kotlin

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.main)
}

      

Java

@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
}

      

Parçanın adını alın ve geri çağırma işlevini kaydedin

  1. Parçanın adını almak için FragmentManager.findFragmentById yöntemini çağırın ve düzen dosyanızdaki parçanın kaynak kimliğini iletin. Parçayı dinamik olarak eklediyseniz, herkese açık kullanıcı adını zaten aldığınız için bu adımı atlayın.

  2. Parça üzerinde geri çağırma işlevini ayarlamak için getMapAsync yöntemini çağırın.

Örneğin, snippet'i statik olarak eklediyseniz:

Kotlin

val mapFragment = supportFragmentManager
    .findFragmentById(R.id.map) as SupportMapFragment
mapFragment.getMapAsync(this)

      

Java

SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
    .findFragmentById(R.id.map);
mapFragment.getMapAsync(this);

      

GoogleMap nesnesinin adını alma

GoogleMapnesnesinin adını almak için onMapReady geri çağırma yöntemini kullanın. Geri çağırma işlevi, harita kullanıcı girişi almaya hazır olduğunda tetiklenir. Haritayı güncellemek için kullanabileceğiniz, GoogleMap sınıfının null olmayan bir örneğini sağlar.

Bu örnekte, onMapReady geri çağırma işlevi GoogleMap nesnesine ait bir tutamaç alır ve ardından haritaya bir işaretçi eklenir:

Kotlin

override fun onMapReady(googleMap: GoogleMap) {
    googleMap.addMarker(
        MarkerOptions()
            .position(LatLng(0.0, 0.0))
            .title("Marker")
    )
}

      

Java

@Override
public void onMapReady(GoogleMap googleMap) {
    googleMap.addMarker(new MarkerOptions()
        .position(new LatLng(0, 0))
        .title("Marker"));
}

      

Harita ve işaretçi Null Adası&#39;nın ortasına yerleştirilmiş ekran görüntüsü.

Uygulamayı başarıyla derleyip çalıştırdığınızda Null Adası'nda (sıfır derece enlem ve sıfır derece boylam) bir işaretçi içeren bir harita gösterilir.

Etkinliğin tamamını görüntülemek için kodu inceleyin:

Tamamlanan Etkinliği Görüntüleme


Sırada ne var?

Bu adımları tamamladıktan sonra harita ayarlarını yapılandırabilirsiniz.