Dodawanie mapy stylu

Wybierz platformę: Android iOS JavaScript

Ta strona zawiera krótki przewodnik po definiowaniu stylu mapy na przykładzie trybu nocnego.

Przegląd

Dzięki opcjom stylu możesz dostosować prezentację standardowych stylów Map Google, zmieniając wizualne wyświetlanie elementów, takich jak drogi, parki, firmy i inne punkty zainteresowania. Oznacza to, że możesz wyróżnić określone elementy mapy lub dopasować mapę do stylu aplikacji.

Definiowanie stylu działa tylko w przypadku typu mapy kGMSTypeNormal.

Stosowanie stylów do mapy

Aby zastosować do mapy niestandardowe style mapy, wywołaj GMSMapStyle(...), aby utworzyć instancję GMSMapStyle, przekazując adres URL do lokalnego pliku JSON lub ciąg JSON zawierający definicje stylu. Przypisz instancję GMSMapStyle do właściwości mapStyle mapy.

Używanie pliku JSON

W przykładach poniżej pokazujemy, jak wywołać GMSMapStyle(...) i przekazać adres URL do pliku lokalnego:

Swift

import GoogleMaps

class MapStyling: UIViewController {

  // Set the status bar style to complement night-mode.
  override var preferredStatusBarStyle: UIStatusBarStyle {
    return .lightContent
  }

  override func loadView() {
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 14.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)

    do {
      // Set the map style by passing the URL of the local file.
      if let styleURL = Bundle.main.url(forResource: "style", withExtension: "json") {
        mapView.mapStyle = try GMSMapStyle(contentsOfFileURL: styleURL)
      } else {
        NSLog("Unable to find style.json")
      }
    } catch {
      NSLog("One or more of the map styles failed to load. \(error)")
    }

    self.view = mapView
  }
}
      

Objective-C

#import "MapStyling.h"
@import GoogleMaps;

@interface MapStyling ()

@end

@implementation MapStyling

// Set the status bar style to complement night-mode.
- (UIStatusBarStyle)preferredStatusBarStyle {
  return UIStatusBarStyleLightContent;
}

- (void)loadView {
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:12];
  GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
  mapView.myLocationEnabled = YES;

  NSBundle *mainBundle = [NSBundle mainBundle];
  NSURL *styleUrl = [mainBundle URLForResource:@"style" withExtension:@"json"];
  NSError *error;

  // Set the map style by passing the URL for style.json.
  GMSMapStyle *style = [GMSMapStyle styleWithContentsOfFileURL:styleUrl error:&error];

  if (!style) {
    NSLog(@"The style definition could not be loaded: %@", error);
  }

  mapView.mapStyle = style;
  self.view = mapView;
}

@end
      

Aby zdefiniować opcje stylu, dodaj do projektu nowy plik o nazwie style.json i wklej tę deklarację stylu JSON dla stylu trybu nocnego:

Używanie zasobu tekstowego

W przykładach poniżej pokazujemy, jak wywołać GMSMapStyle(...) i przekazać zasób ciągu znaków:

Swift

class MapStylingStringResource: UIViewController {

  let MapStyle = "JSON_STYLE_GOES_HERE"

  // Set the status bar style to complement night-mode.
  override var preferredStatusBarStyle: UIStatusBarStyle {
    return .lightContent
  }

  override func loadView() {
    let camera = GMSCameraPosition.camera(withLatitude: -33.86, longitude: 151.20, zoom: 14.0)
    let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)

    do {
      // Set the map style by passing a valid JSON string.
      mapView.mapStyle = try GMSMapStyle(jsonString: MapStyle)
    } catch {
      NSLog("One or more of the map styles failed to load. \(error)")
    }

    self.view = mapView
  }
}
      

Objective-C

@implementation MapStylingStringResource

// Paste the JSON string to use.
static NSString *const kMapStyle = @"JSON_STYLE_GOES_HERE";

// Set the status bar style to complement night-mode.
- (UIStatusBarStyle)preferredStatusBarStyle {
  return UIStatusBarStyleLightContent;
}

- (void)loadView {
  GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:-33.86
                                                          longitude:151.20
                                                               zoom:12];
  GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera];
  mapView.myLocationEnabled = YES;

  NSError *error;

  // Set the map style by passing a valid JSON string.
  GMSMapStyle *style = [GMSMapStyle styleWithJSONString:kMapStyle error:&error];

  if (!style) {
    NSLog(@"The style definition could not be loaded: %@", error);
  }

  mapView.mapStyle = style;
  self.view = mapView;
}

@end
      

Aby zdefiniować opcje stylu, wklej ten ciąg stylu jako wartość zmiennej kMapStyle:

Deklaracje stylu JSON

Mapy z własnym stylem używają 2 koncepcji, aby stosować kolory i inne zmiany stylu do mapy:

  • Selektory określają elementy geograficzne, których styl możesz zdefiniować na mapie. Należą do nich drogi, parki, zbiorniki wodne i inne elementy, a także ich etykiety. Selektory obejmują funkcje i elementy, określone jako featureType i elementType właściwości.
  • Style to właściwości koloru i widoczności, które możesz zastosować do elementów mapy. Określają one wyświetlany kolor za pomocą kombinacji odcienia, koloru, jasności i wartości gamma.

Szczegółowy opis opcji stylu JSON znajdziesz w dokumentacji stylu.

Kreator stylu Maps Platform

Użyj kreatora stylu Maps Platform , aby szybko wygenerować obiekt stylu JSON. Maps SDK na iOS obsługuje te same deklaracje stylu co Maps JavaScript API.

Pełne przykłady kodu

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

Następny krok

Dowiedz się, jak ukrywać elementy na mapie za pomocą stylu.