Ukrywanie obiektów mapy przy użyciu stylu

Wybierz platformę: Android iOS JavaScript

Oprócz zmiany stylu elementów na mapie możesz je też całkowicie ukryć. W tym przykładzie pokazujemy, jak ukryć na mapie punkty orientacyjne i ikony transportu publicznego.

Stylizacja działa tylko w przypadku typu mapy normal. Stylizacja nie ma wpływu na mapy wewnętrzne, więc ukrywanie funkcji za pomocą stylizacji nie zapobiega wyświetlaniu na mapie planów pięter budynków.

Przekazywanie obiektu stylu JSON do mapy

Aby nadać mapie styl, wywołaj funkcję GoogleMap.setMapStyle(), przekazując obiekt MapStyleOptions zawierający deklaracje stylów w formacie JSON. Dane JSON możesz wczytywać z zasosobu nieprzetworzonego lub z ciągu znaków, jak w tych przykładach:

Zasób niezdefiniowany

W tym przykładowym kodzie zakładamy, że projekt zawiera surowy 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)));
    }
}

Zdefiniuj w zasobie /res/raw/style_json.json zasób surowy zawierający tę deklarację w formacie JSON, aby ukryć punkty zainteresowania biznesowego (POI):

Ta deklaracja stylu ukrywa punkty usługowe i ikony transportu publicznego:

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

Zasób tekstowy

W tym przykładzie kodu zakładamy, że projekt zawiera zasób 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)));
    }
}

Zdefiniuj zasób ciągu znaków w pliku /res/values/style_strings.xml, zawierający tę deklarację stylu JSON, aby ukryć punkty zainteresowania biznesowego (POI). W tym pliku musisz użyć ukośnika wstecznego, aby uciec cudzysłowom:

Ta deklaracja stylu ukrywa punkty usługowe i ikony transportu publicznego:

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

Deklaracje stylu JSON

Mapy stylizowane używają 2 koncepcji do stosowania kolorów i innych zmian stylu do mapy:

  • Selektory określają komponenty geograficzne, które możesz stylizować na mapie. Obejmują one drogi, parki, zbiorniki wodne i inne obiekty oraz ich etykiety. Selektory obejmują funkcjeelementy określone jako właściwości featureTypeelementType.
  • Stylers to właściwości koloru i widoczności, które możesz stosować do elementów mapy. Określają wyświetlany kolor za pomocą kombinacji wartości odcienia, koloru i jasności/gamma.

Szczegółowy opis opcji stylizacji w pliku JSON znajdziesz w dokumentacji referencyjnej dotyczącej stylów.

Kreator stylizacji Maps Platform

Aby szybko wygenerować obiekt stylizacji JSON, użyj Kreatora stylizacji na platformie Mapy. Pakiet SDK Map na Androida obsługuje te same deklaracje stylu co interfejs Maps JavaScript API.

Pełne przykłady kodu

Repozytorium ApiDemos na GitHubie zawiera przykłady, które pokazują, jak używać stylów.