Określanie stylu mapy

Wybierz platformę: Android iOS JavaScript

W tym przewodniku znajdziesz sposoby dostosowywania mapy wyświetlanej w aplikacji na Androida podczas śledzenia podróży. Wygląd i styl mapy możesz dostosować na kilka sposobów:

nadawanie mapie stylów za pomocą definiowania stylów map w Google Cloud;

Dostosuj wygląd i wygląd komponentu map za pomocą definiowania stylów map w Google Cloud. W konsoli Google Cloud możesz tworzyć i edytować style mapy dla wszystkich swoich aplikacji korzystających z Map Google bez konieczności wprowadzania zmian w kodzie. Więcej informacji znajdziesz w artykule Definiowanie stylów map w Google Cloud.

Zarówno klasy ConsumerMapView, jak i ConsumerMapFragment obsługują styl mapy w chmurze. Aby korzystać z definiowania stylów map w Google Cloud, sprawdź, czy wybrany moduł renderowania map to LATEST. W następnych sekcjach znajdziesz przykłady korzystania z definiowania stylów map w Google Cloud w ramach projektu.

ConsumerMapView

Aby w komponencie ConsumerMapView używać stylów map opartych na chmurze, ustaw pole mapId w komponencie GoogleMapOptions i przekaż obiekt GoogleMapOptions do metody getConsumerGoogleMapAsync(ConsumerMapReadyCallback, Fragment, GoogleMapOptions) lub getConsumerGoogleMapAsync(ConsumerMapReadyCallback, FragmentActivity, GoogleMapOptions).

Przykład

Java

public class SampleAppActivity extends AppCompatActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ConsumerMapView mapView = findViewById(R.id.consumer_map_view);

    if (mapView != null) {
      GoogleMapOptions optionsWithMapId = new GoogleMapOptions().mapId("map-id");
      mapView.getConsumerGoogleMapAsync(
          new ConsumerMapReadyCallback() {
            @Override
            public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
              // ...
            }
          },
          /* fragmentActivity= */ this,
          /* googleMapOptions= */ optionsWithMapId);
    }
  }
}

Kotlin

class SampleAppActivity : AppCompatActivity() {
  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    val mapView = findViewById(R.id.consumer_map_view) as ConsumerMapView

    val optionsWithMapId = GoogleMapOptions().mapId("map-id")
    mapView.getConsumerGoogleMapAsync(
      object : ConsumerGoogleMap.ConsumerMapReadyCallback() {
        override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
          // ...
        }
      },
      /* fragmentActivity= */ this,
      /* googleMapOptions= */ optionsWithMapId)
  }
}

ConsumerMapFragment

Istnieją 2 sposoby określania stylu map w chmurze we fragmentach ConsumerMapFragments:

  • Statycznie w pliku XML.
  • Dynamicznie z newInstance.

Statycznie za pomocą pliku XML

Aby używać stylów map w chmurze z plikiem XML w pliku ConsumerMapFragment, dodaj atrybut XML map:mapId z określonym atrybutem mapId. Przyjrzyj się temu przykładowi:

<fragment
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:map="http://schemas.android.com/apk/res-auto"
    android:name="com.google.android.libraries.mapsplatform.transportation.consumer.view.ConsumerMapFragment"
    android:id="@+id/consumer_map_fragment"
    map:mapId="map-id"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

Dynamicznie z użyciem newInstance

Aby używać definiowania stylów map w Google Cloud z newInstance w ConsumerMapFragment, ustaw pole mapId na GoogleMapOptions i przekaż wartość GoogleMapOptions do newInstance. Przyjrzyj się temu przykładowi:

Java

public class SampleFragmentJ extends Fragment {

  @Override
  public View onCreateView(
      @NonNull LayoutInflater inflater,
      @Nullable ViewGroup container,
      @Nullable Bundle savedInstanceState) {

    final View view = inflater.inflate(R.layout.consumer_map_fragment, container, false);

    GoogleMapOptions optionsWithMapId = new GoogleMapOptions().mapId("map-id");
    ConsumerMapFragment consumerMapFragment = ConsumerMapFragment.newInstance(optionsWithMapId);

    getParentFragmentManager()
        .beginTransaction()
        .add(R.id.consumer_map_fragment, consumerMapFragment)
        .commit();

    consumerMapFragment.getConsumerGoogleMapAsync(
        new ConsumerMapReadyCallback() {
          @Override
          public void onConsumerMapReady(@NonNull ConsumerGoogleMap consumerGoogleMap) {
            // ...
          }
        });

    return view;
  }
}

Kotlin

class SampleFragment : Fragment() {
  override fun onCreateView(
    inflater: LayoutInflater,
    container: ViewGroup?,
    savedInstanceState: Bundle?): View? {

    val view = inflater.inflate(R.layout.consumer_map_fragment, container, false)

    val optionsWithMapId = GoogleMapOptions().mapId("map-id")
    val consumerMapFragment = ConsumerMapFragment.newInstance(optionsWithMapId)

    parentFragmentManager
      .beginTransaction()
      .add(R.id.consumer_map_fragment, consumerMapFragment)
      .commit()

    consumerMapFragment.getConsumerGoogleMapAsync(
      object : ConsumerMapReadyCallback() {
        override fun onConsumerMapReady(consumerGoogleMap: ConsumerGoogleMap) {
          // ...
        }
      })

    return view
  }
}

Dostosowywanie powiększenia kamery w celu skupienia się na podróży

Podczas aktywnej sesji udostępniania podróży możesz ustawić powiększenie i ostrość kamery na jeden z dwóch sposobów:

  • AutoCamera: jeśli chcesz korzystać z funkcji AutoCamera, nie musisz nic robić. Kamera podąża za podróżą. Więcej informacji znajdziesz w sekcji AutoCamera.

  • Dostosowywanie działania aparatu: aby to zrobić, musisz wyłączyć AutoCamera, a następnie wprowadzić zmiany. Więcej informacji znajdziesz w artykule Dostosowywanie działania aparatu.

AutoCamera wyśrodkowuje kamerę

Pakiet SDK dla klientów indywidualnych udostępnia funkcję AutoCamera, która jest domyślnie włączona we wbudowanym przycisku Moja lokalizacja w pakiecie SDK Map Google. Aparat przybliża obraz, aby skupić się na trasie i kolejnych punktach nawigacyjnych.

Jeśli chcesz używać usługi AutoCamera, włącz ją. Więcej informacji znajdziesz w sekcji isAutoCameraEnabled.

„AutoAparat”

Szczegółowe informacje o przycisku Moja lokalizacja znajdziesz w dokumentacji interfejsu Maps JavaScript API.

Dostosowywanie działania kamery

Aby mieć większą kontrolę nad działaniem kamery, wyłącz AutoCamera i ręcznie dostosuj jej działanie, wykonując te czynności.

  1. Wyłącz AutoCamera, używając metody ConsumerController.setAutoCameraEnabled().

  2. Uzyskaj zalecane granice kamery za pomocą metody ConsumerController.getCameraUpdate().

  3. Podawaj wartość CameraUpdate jako argument jednej z tych funkcji Androida:

Co dalej?

Śledzenie przejazdu na urządzeniu z Androidem