Dodawanie mapy stylu

Wybierz platformę: Android iOS JavaScript

Z tego samouczka dowiesz się, jak dodać do aplikacji na Androida mapę ze stylem niestandardowym. W samouczku jako przykład stylu niestandardowego użyto trybu nocnego.

Opcje stylów umożliwiają dostosowywanie standardowych stylów mapy Google, np. zmianę wizualnego wyświetlania takich elementów, jak drogi, parki, firmy i inne punkty zainteresowania. Oznacza to, że możesz podkreślić, określonych elementów mapy, lub sprawić, że będzie ona współgrała ze stylem .

Styl działa tylko w przypadku mapy typu normal. Stylizacja nie ma wpływu na mapy wewnętrzne.

Pobierz kod

Klonowanie lub pobieranie przykładowych przykładów interfejsu API Map Google w wersji 2 z GitHuba.

Konfigurowanie projektu programistycznego

Aby utworzyć projekt samouczka w Android Studio, wykonaj te czynności.

  1. Pobierz i zainstaluj Android Studio.
  2. Dodaj do Android Studio pakiet Usługi Google Play.
  3. Klonowanie lub pobieranie przykładowych przykładów interfejsu API Map Google w wersji 2 jeśli nie został on wykonany podczas czytania tego samouczka.
  4. Zaimportuj projekt samouczka:

    • W Android Studio wybierz kolejno Plik > Nowe > Importuj projekt.
    • Przejdź do lokalizacji, w której zostały zapisane przykłady interfejsu API Map Google w wersji 2. po jego pobraniu.
    • Znajdź projekt StyledMap w tej lokalizacji:
      PATH-TO-SAVED-REPO/android-samples/tutorials/StyledMap
    • Wybierz katalog projektu i kliknij OK. Android Studio kompiluje teraz Twój projekt za pomocą narzędzia do kompilacji Gradle.

Uzyskiwanie klucza interfejsu API i włączanie niezbędnych interfejsów API

Aby ukończyć ten samouczek, potrzebujesz klucza interfejsu API Google z uprawnieniami do używania SDK Maps na Androida.

Kliknij przycisk poniżej, aby uzyskać klucz i aktywować interfejs API.

Kup klucz

Więcej informacji znajdziesz w przewodniku po uzyskiwaniu klucza API.

Dodawanie klucza interfejsu API do aplikacji

  1. Edytuj plik gradle.properties projektu.
  2. Wklej klucz interfejsu API do wartości właściwości GOOGLE_MAPS_API_KEY. Kiedy jeśli tworzysz aplikację, Gradle kopiuje klucz interfejsu API do aplikacji na Androida pliku manifestu.

    GOOGLE_MAPS_API_KEY=PASTE-YOUR-API-KEY-HERE
    

Tworzenie i uruchamianie aplikacji

  1. Podłącz urządzenie z Androidem do komputera. Aby włączyć opcje programisty na urządzeniu z Androidem i skonfigurować system tak, aby wykrywał urządzenie, wykonaj te instrukcje. (Możesz też użyć Menedżera urządzenia wirtualnego z Androidem (AVD), aby skonfigurować urządzenie wirtualne). Wybierając emulator, wybierz obraz, który zawiera interfejsy API Google. Więcej informacji: przewodnika dla początkujących).
  2. W Android Studio kliknij opcję menu Uruchom (lub ikonę przycisku odtwarzania). Wybierz urządzenie zgodnie z instrukcjami.

Android Studio wywołuje Gradle, aby utworzyć aplikację, a następnie uruchamia aplikację na urządzeniu lub w emulatorze. Powinna wyświetlić się mapa z ciemnym widokiem (tryb nocny). stylu, podobnie jak na tej stronie.

Rozwiązywanie problemów:

  • Jeśli nie widzisz mapy, sprawdź, czy masz otrzymany klucz interfejsu API i czy został on dodany do aplikację w sposób opisany powyżej. Sprawdź dziennik w Monitorze Androida w Android Studio, aby znaleźć komunikaty o błędach dotyczących klucza interfejsu API.
  • Aby wyświetlić logi i przeprowadzić debugowanie aplikacji, użyj narzędzi debugowania w Android Studio.

Zrozumienie kodu

W tej części samouczka objaśniamy najważniejsze elementy StyledMap, która pomoże Ci utworzyć podobną aplikację.

Dodaj zasób zawierający obiekt stylu JSON

Dodaj do projektu deweloperskiego zasób zawierający deklaracje stylów w formacie JSON. Możesz użyć surowego zasobu lub ciągu tekstowego, jak w przykładach poniżej.

Nieprzetworzony zasób

Zdefiniuj zasób surowy w pliku /res/raw/style_json.json, zawierający deklarację stylu JSON na potrzeby trybu nocnego:

Zasób tekstowy

Zdefiniuj zasób tekstowy w polu /res/values/style_strings.xml, który zawiera deklarację stylu JSON dla stylu trybu nocnego. W tym samouczku używamy ciągu tekstowego style_json. W w tym pliku musisz zastosować odwrócony ukośnik, aby zmienić znaczenie cudzysłowów:

Przekazywanie obiektu stylu JSON do mapy

Aby określić styl mapy, wywołaj GoogleMap.setMapStyle() i przekaż MapStyleOptions obiekt, który zawiera Twój styl deklaracje w formacie JSON.

Nieprzetworzony zasób

W poniższym przykładowym kodzie założono, że projekt zawiera nieprzetworzony zasób o nazwie style_json:

// Copyright 2020 Google LLC
//
// 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.example.styledmap;

import android.content.res.Resources;
import android.os.Bundle;
import android.util.Log;
import androidx.appcompat.app.AppCompatActivity;

import com.google.android.gms.maps.CameraUpdateFactory;
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.MapStyleOptions;

/**
 * A styled map using JSON styles from a raw resource.
 */
public class MapsActivityRaw extends AppCompatActivity
        implements OnMapReadyCallback {

    private static final String TAG = MapsActivityRaw.class.getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // Retrieve the content view that renders the map.
        setContentView(R.layout.activity_maps_raw);

        // Get the SupportMapFragment and register for the callback
        // when the map is ready for use.
        SupportMapFragment mapFragment =
                (SupportMapFragment) getSupportFragmentManager()
                        .findFragmentById(R.id.map);
        mapFragment.getMapAsync(this);
    }

    /**
     * Manipulates the map when it's available.
     * The API invokes this callback when the map is ready for use.
     */
    @Override
    public void onMapReady(GoogleMap googleMap) {

        try {
            // Customise the styling of the base map using a JSON object defined
            // in a raw resource file.
            boolean success = googleMap.setMapStyle(
                    MapStyleOptions.loadRawResourceStyle(
                            this, R.raw.style_json));

            if (!success) {
                Log.e(TAG, "Style parsing failed.");
            }
        } catch (Resources.NotFoundException e) {
            Log.e(TAG, "Can't find style. Error: ", e);
        }
        // Position the map's camera near Sydney, Australia.
        googleMap.moveCamera(CameraUpdateFactory.newLatLng(new LatLng(-34, 151)));
    }
}

Układ (activity_maps_raw.xml) wygląda tak:

Zasób tekstowy

W poniższym przykładowym kodzie założono, że projekt zawiera zasób w postaci ciągu znaków o nazwie style_json:

package com.example.styledmap;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;

import com.google.android.gms.maps.CameraUpdateFactory;
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.MapStyleOptions;

/**
 * A styled map using JSON styles from a string resource.
 */
public class MapsActivityString extends AppCompatActivity
        implements OnMapReadyCallback {

    private static final String TAG = MapsActivityString.class.getSimpleName();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // Retrieve the content view that renders the map.
        setContentView(R.layout.activity_maps_string);

        // Get the SupportMapFragment and register for the callback
        // when the map is ready for use.
        SupportMapFragment mapFragment =
                (SupportMapFragment) getSupportFragmentManager()
                        .findFragmentById(R.id.map);
        mapFragment.getMapAsync(this);
    }

    /**
     * Manipulates the map when it's available.
     * The API invokes this callback when the map is ready for use.
     */
    @Override
    public void onMapReady(GoogleMap googleMap) {

        // Customise the styling of the base map using a JSON object defined
        // in a string resource file. First create a MapStyleOptions object
        // from the JSON styles string, then pass this to the setMapStyle
        // method of the GoogleMap object.
        boolean success = googleMap.setMapStyle(new MapStyleOptions(getResources()
                .getString(R.string.style_json)));

        if (!success) {
            Log.e(TAG, "Style parsing failed.");
        }
        // Position the map's camera near Sydney, Australia.
        googleMap.moveCamera(CameraUpdateFactory.newLatLng(new LatLng(-34, 151)));
    }
}

Układ (activity_maps_string.xml) wygląda tak:

Więcej informacji o deklaracjach stylu JSON

W mapach stylizowanych kolory i inne zmiany stylu są stosowane do dwóch koncepcji. mapa:

  • Selektory określają komponenty geograficzne, które możesz stylizować na mapie. Są to drogi, parki, zbiorniki wodne, i ich etykiety. Selektory obejmują funkcjeelementy określone jako właściwości featureTypeelementType.
  • Style to właściwości kolorów i widoczności, których możesz użyć mają zastosowanie do elementów mapy. Definiują one wyświetlany kolor za pomocą kombinacji barw, kolorów i jasności/gamma.

Szczegółowy opis tych atrybutów znajdziesz w dokumentacji stylu Opcje stylu JSON.

Kreator stylów Maps Platform

Użyj kreatora stylów Maps Platform, aby szybko wygenerować obiekt stylu JSON. Pakiet SDK Map na Androida obsługuje te same deklaracje stylu co interfejs Maps JavaScript API.

Następny krok

Dowiedz się, jak ukryć elementy na mapie za pomocą stylizacji.