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
importGoogleMapsclassMapStyling:UIViewController{// Set the status bar style to complement night-mode.overridevarpreferredStatusBarStyle:UIStatusBarStyle{return.lightContent}overridefuncloadView(){letcamera=GMSCameraPosition.camera(withLatitude:-33.86,longitude:151.20,zoom:14.0)letmapView=GMSMapView.map(withFrame:CGRect.zero,camera:camera)do{// Set the map style by passing the URL of the local file.ifletstyleURL=Bundle.main.url(forResource:"style",withExtension:"json"){mapView.mapStyle=tryGMSMapStyle(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"@importGoogleMaps;@interfaceMapStyling()@end@implementationMapStyling// Set the status bar style to complement night-mode.-(UIStatusBarStyle)preferredStatusBarStyle{returnUIStatusBarStyleLightContent;}-(void)loadView{GMSCameraPosition*camera=[GMSCameraPositioncameraWithLatitude:-33.86longitude:151.20zoom:12];GMSMapView*mapView=[GMSMapViewmapWithFrame:CGRectZerocamera:camera];mapView.myLocationEnabled=YES;NSBundle*mainBundle=[NSBundlemainBundle];NSURL*styleUrl=[mainBundleURLForResource:@"style"withExtension:@"json"];NSError*error;// Set the map style by passing the URL for style.json.GMSMapStyle*style=[GMSMapStylestyleWithContentsOfFileURL:styleUrlerror:&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:
W przykładach poniżej pokazujemy, jak wywołać GMSMapStyle(...) i przekazać zasób ciągu znaków:
Swift
classMapStylingStringResource:UIViewController{letMapStyle="JSON_STYLE_GOES_HERE"// Set the status bar style to complement night-mode.overridevarpreferredStatusBarStyle:UIStatusBarStyle{return.lightContent}overridefuncloadView(){letcamera=GMSCameraPosition.camera(withLatitude:-33.86,longitude:151.20,zoom:14.0)letmapView=GMSMapView.map(withFrame:CGRect.zero,camera:camera)do{// Set the map style by passing a valid JSON string.mapView.mapStyle=tryGMSMapStyle(jsonString:MapStyle)}catch{NSLog("One or more of the map styles failed to load. \(error)")}self.view=mapView}}
Objective-C
@implementationMapStylingStringResource// Paste the JSON string to use.staticNSString*constkMapStyle=@"JSON_STYLE_GOES_HERE";// Set the status bar style to complement night-mode.-(UIStatusBarStyle)preferredStatusBarStyle{returnUIStatusBarStyleLightContent;}-(void)loadView{GMSCameraPosition*camera=[GMSCameraPositioncameraWithLatitude:-33.86longitude:151.20zoom:12];GMSMapView*mapView=[GMSMapViewmapWithFrame:CGRectZerocamera:camera];mapView.myLocationEnabled=YES;NSError*error;// Set the map style by passing a valid JSON string.GMSMapStyle*style=[GMSMapStylestyleWithJSONString:kMapStyleerror:&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:
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.
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.
[[["Łatwo zrozumieć","easyToUnderstand","thumb-up"],["Rozwiązało to mój problem","solvedMyProblem","thumb-up"],["Inne","otherUp","thumb-up"]],[["Brak potrzebnych mi informacji","missingTheInformationINeed","thumb-down"],["Zbyt skomplikowane / zbyt wiele czynności do wykonania","tooComplicatedTooManySteps","thumb-down"],["Nieaktualne treści","outOfDate","thumb-down"],["Problem z tłumaczeniem","translationIssue","thumb-down"],["Problem z przykładami/kodem","samplesCodeIssue","thumb-down"],["Inne","otherDown","thumb-down"]],["Ostatnia aktualizacja: 2026-05-29 UTC."],[],["To customize map appearance, apply styles to the `kGMSTypeNormal` map type. Utilize `GMSMapStyle` by passing a URL for a local JSON file or a JSON string to the `mapStyle` property. Define styles with selectors (features and elements) and stylers (color, visibility). Create a `style.json` file for night-mode styling with the provided JSON or use a JSON string directly. Consider cloud customization for uniform styling across multiple apps. The Maps Platform Styling Wizard can help generate JSON style objects. Avoid mixing cloud and hardcoded styles.\n"]]