Używanie identyfikatorów map
Identyfikator mapy to identyfikator powiązany z określonym stylem lub funkcją mapy. skonfigurować styl mapy i powiązać go z identyfikatorem mapy w Google Cloud Console; Gdy odwołasz się do identyfikatora mapy w kodzie, powiązany z nią styl mapy wyświetli się w Twojej aplikacji. Wszystkie późniejsze zmiany stylu będą automatycznie wyświetlane w aplikacji bez potrzeby aktualizacji przez klientów.
Po utworzeniu identyfikatory map są powiązane z projektem i ograniczają się do jednej platformy (Android, iOS, JavaScript) lub do statycznego interfejsu API Map Google.
Aby tworzyć identyfikatory map lub zarządzać nimi w Cloud Console, musisz mieć rolę właściciela lub edytującego projekt.
Wymagane uprawnienia
Aby tworzyć identyfikatory lub style map w danym projekcie Google Cloud i nimi zarządzać, musisz mieć w tym projekcie rolę właściciela lub edytującego.
Tworzenie identyfikatora mapy
Identyfikator mapy to unikalny identyfikator reprezentujący jedno wystąpienie mapy Google. W Cloud Console w każdej chwili możesz utworzyć identyfikatory map i zaktualizować ich styl.
Aby utworzyć identyfikator mapy:
- W Cloud Console otwórz stronę zarządzania Mapami.
- Wybierz Utwórz nowy identyfikator mapy, aby wyświetlić formularz Utwórz nowy identyfikator mapy.
W formularzu wykonaj te czynności:
- Podaj nazwę mapy.
- Określ typ mapy lub platformę.
- W przypadku map JavaScript wybierz typ mapy rastrowej lub wektorowej.
- Wpisz opis mapy.
- Kliknij Dalej, aby wyświetlić nowy identyfikator mapy.
Powiązanie identyfikatora mapy ze stylem mapy
W tych instrukcjach przyjęto, że w projekcie istnieje już co najmniej jeden styl mapy.
- W Cloud Console otwórz stronę zarządzania Mapami.
- Na tej stronie wybierz istniejący identyfikator mapy z kolumny Nazwa mapy.
- Na dole tego formularza wybierz styl mapy z menu Style mapy powiązane z tym identyfikatorem mapy.
- Kliknij Zapisz.
Dodaj identyfikator mapy do swojej aplikacji
Android
Dodaj identyfikator mapy za pomocą elementu <fragment>
w pliku układu aktywności, za pomocą klasy MapView
lub automatycznie za pomocą klasy GoogleMapOptions
.
Załóżmy na przykład, że utworzony przez Ciebie identyfikator mapy jest przechowywany jako wartość w postaci ciągu znaków o nazwie map_id
w res/values/strings.xml
:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="map_id">YOUR_MAP_ID</string>
</resources>
W przypadku map dodanych przez element <fragment>
w pliku układu aktywności wszystkie fragmenty map, które powinny mieć styl niestandardowy, muszą zawierać identyfikator mapy w atrybucie map:mapId
:
<fragment xmlns:map="http://schemas.android.com/apk/res-auto"
class="com.google.android.gms.maps.SupportMapFragment"
…
map:mapId="@string/map_id" />
Możesz też użyć atrybutu map:mapId
klasy MapView
, aby określić identyfikator mapy:
<com.google.android.gms.maps.MapView
xmlns:android="http://schemas.android.com/apk/res/android"
....
map:mapId="@string/map_id" />
Aby automatycznie określić identyfikator mapy, przekaż go do instancji MapFragment
za pomocą klasy GoogleMapOptions
:
Java
MapFragment mapFragment = MapFragment.newInstance(
new GoogleMapOptions()
.mapId(getResources().getString(R.string.map_id)));
Kotlin
val mapFragment = MapFragment.newInstance(
GoogleMapOptions()
.mapId(resources.getString(R.string.map_id))
)
W Android Studio możesz utworzyć i uruchomić aplikację w zwykły sposób. Style niestandardowe skonfigurowane w pierwszym kroku zostaną zastosowane do wszystkich map o określonym identyfikatorze.
iOS
Aby utworzyć instancję mapy przy użyciu identyfikatora mapy, wykonaj następujące czynności:
- Utwórz
GMSMapID
z ciągiem identyfikatora mapy z Cloud Console. - Utwórz właściwość
GMSMapView
określającą właśnie utworzony identyfikator mapy.
Swift
let camera = GMSCameraPosition(latitude: 47.0169, longitude: -122.336471, zoom: 12)
let mapID = GMSMapID(identifier: "<YOUR MAP ID>")
let mapView = GMSMapView(frame: .zero, mapID: mapID, camera: camera)
self.view = mapView
Objective-C
GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:47.0169
longitude:-122.336471
zoom:12];
GMSMapID *mapID = [GMSMapID mapIDWithIdentifier:@"<YOUR MAP ID>"];
GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero mapID:mapID camera:camera];
self.view = mapView;
Jeśli używasz własnego identyfikatora mapy, w każdej chwili możesz go zmienić w Cloud Console, aby w ciągu ok. 6 godzin automatycznie wyświetlić go w widoku mapy Tobie i Twoim użytkownikom.
Jeśli chcesz od razu zobaczyć zmiany, możesz zamknąć aplikację i uruchomić ją ponownie, zamykając ją, wymuszając zamknięcie aplikacji z listy ostatnio używanych, a następnie ponownie otwierając. Zaktualizowana mapa będzie wtedy widoczna.
JavaScript
Aby utworzyć mapę z identyfikatorem mapy w kodzie aplikacji:
Jeśli obecnie dostosowujesz mapę, używając osadzonego kodu JSON, usuń właściwości
styles
z obiektuMapOptions
. W przeciwnym razie pomiń ten krok.Dodaj identyfikator mapy do mapy za pomocą właściwości
mapId
. Na przykład:
map = new google.maps.Map(document.getElementById('map'), { center: {lat: -34.397, lng: 150.644}, zoom: 8, mapId: 'MAP_ID' });
Mapy statyczne
Aby dodać identyfikator mapy do nowej lub istniejącej mapy, która używa jednego z interfejsów API usługi internetowej, dołącz parametr adresu URL map_id
i ustaw go jako swój identyfikator.
Ten przykład pokazuje dodawanie identyfikatora mapy do mapy za pomocą statycznego interfejsu API Map Google.
<img src="https://maps.googleapis.com/maps/api/staticmap?center=Brooklyn+Bridge,New+York,NY&zoom=13&size=600x300&maptype=roadmap&markers=color:blue%7Clabel:S%7C40.702147,-74.015794&markers=color:green%7Clabel:G%7C40.711614,-74.012318&markers=color:red%7Clabel:C%7C40.718217,-73.998284&key=YOUR_API_KEY&map_id=YOUR_MAP_ID&signature=YOUR_SIGNATURE" />
Funkcje dostępne podczas korzystania z identyfikatorów map
Styl map w Google Cloud: wybieraj style, personalizuj je i zarządzaj nimi za pomocą Google Cloud Console.
Dostępne na wszystkich platformach (Android, JavaScript, iOS i Statyczny interfejs API Map Google)
Mapy wektorowe: mapa składająca się z kafelków opartych na wektorach, które są rysowane podczas wczytywania po stronie klienta za pomocą WebGL.
Dostępne w języku JavaScript