Obsługa zdarzeń

Ten przykład pokazuje, jak nasłuchiwać i obsługiwać niektóre zdarzenia na mapie.

Więcej informacji znajdziesz w dokumentacji.

Rozpocznij

Zanim wypróbujesz przykładowy kod, musisz skonfigurować środowisko programistyczne. Więcej informacji znajdziesz na stronie z przykładowym kodem pakietu SDK Map Google na Androida.

Wyświetl kod

Kotlin



class EventsDemoActivity : AppCompatActivity(), OnMapClickListener,
    OnMapLongClickListener, OnCameraIdleListener, OnMapReadyCallback {

    private lateinit var tapTextView: TextView
    private lateinit var cameraTextView: TextView
    private lateinit var map: GoogleMap

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.events_demo)
        tapTextView = findViewById(R.id.tap_text)
        cameraTextView = findViewById(R.id.camera_text)
        val mapFragment = supportFragmentManager.findFragmentById(R.id.map) as SupportMapFragment?
        mapFragment?.getMapAsync(this)
    }

    override fun onMapReady(googleMap: GoogleMap) {
        // return early if the map was not initialised properly
        map = googleMap
        map.setOnMapClickListener(this)
        map.setOnMapLongClickListener(this)
        map.setOnCameraIdleListener(this)
    }

    override fun onMapClick(point: LatLng) {
        tapTextView.text = "tapped, point=$point"
    }

    override fun onMapLongClick(point: LatLng) {
        tapTextView.text = "long pressed, point=$point"
    }

    override fun onCameraIdle() {
        if (!::map.isInitialized) return
        cameraTextView.text = map.cameraPosition.toString()
    }
}

      

Java


public class EventsDemoActivity extends AppCompatActivity
        implements OnMapClickListener, OnMapLongClickListener, OnCameraIdleListener,
        OnMapReadyCallback {

    private TextView tapTextView;
    private TextView cameraTextView;
    private GoogleMap map;

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

        tapTextView = findViewById(R.id.tap_text);
        cameraTextView = findViewById(R.id.camera_text);

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

    @Override
    public void onMapReady(GoogleMap map) {
        this.map = map;
        this.map.setOnMapClickListener(this);
        this.map.setOnMapLongClickListener(this);
        this.map.setOnCameraIdleListener(this);
    }

    @Override
    public void onMapClick(LatLng point) {
        tapTextView.setText("tapped, point=" + point);
    }

    @Override
    public void onMapLongClick(LatLng point) {
        tapTextView.setText("long pressed, point=" + point);
    }

    @Override
    public void onCameraIdle() {
        cameraTextView.setText(map.getCameraPosition().toString());
    }
}

      

Klonowanie i uruchamianie próbek

Do lokalnego uruchomienia tego przykładu wymagany jest Git. Poniższe polecenie sklonuje repozytorium przykładowej aplikacji.

git clone git@github.com:googlemaps-samples/android-samples.git

Zaimportuj przykładowy projekt do Android Studio:

  1. W Android Studio wybierz Plik > Nowy > Importuj projekt.
  2. Przejdź do lokalizacji, w której zostało zapisane repozytorium, i wybierz katalog projektu dla języka Kotlin lub Java:

    • Kotlin: PATH-REPO/android-samples/ApiDemos/kotlin
    • Java: PATH-REPO/android-samples/ApiDemos/java
  3. Wybierz Otwórz. Android Studio tworzy projekt za pomocą narzędzia do kompilacji Gradle.
  4. Utwórz pusty plik secrets.properties w tym samym katalogu co plik local.properties projektu. Więcej informacji znajdziesz w artykule Dodawanie klucza interfejsu API do projektu.
  5. Dodaj do pola secrets.properties ten ciąg znaków, zastępując fragment YOUR_API_KEY wartością swojego klucza interfejsu API:

    MAPS_API_KEY=YOUR_API_KEY
  6. Uruchom aplikację.