Aby używać stylów opartych na danych w przypadku granic, musisz utworzyć identyfikator mapy, który korzysta z wektorowej mapy JavaScript. Następnie musisz utworzyć nowy styl mapy, wybrać warstwy funkcji granic i powiązać styl z identyfikatorem mapy.
Tworzenie identyfikatora mapy
Aby utworzyć nowy identyfikator mapy, wykonaj czynności opisane w sekcji Dostosowywanie w chmurze. Ustaw Typ mapy na JavaScript i wybierz opcję Wektorowa. Zaznacz pola Przechylenie i Obrót , aby włączyć przechylanie i obracanie mapy. Jeśli używanie przechylenia lub kierunku ma negatywny wpływ na Twoją aplikację, pozostaw pola Przechylenie i Obrót odznaczone, aby użytkownicy nie mogli ich dostosowywać.

Tworzenie nowego stylu mapy
Aby utworzyć nowy styl mapy, postępuj zgodnie z instrukcjami w Zarządzanie stylami mapy . Utwórz styl i powiąż go z utworzonym identyfikatorem mapy.
Wybieranie warstw funkcji
W Konsoli interfejsów API Google możesz wybrać, które warstwy funkcji mają być wyświetlane. Określa to, jakie rodzaje granic będą widoczne na mapie (np. miejscowości, stany itp.).
Zarządzanie warstwami funkcji
- W Konsoli interfejsów API Google otwórz stronę Style mapy.
- Jeśli pojawi się prośba, wybierz projekt.
- Wybierz styl mapy.
- Aby dodać lub usunąć warstwy, kliknij menu Warstwy funkcji.
- Kliknij Zapisz , aby zapisać zmiany i udostępnić je na mapach.
Aktualizowanie kodu inicjowania mapy
Wymaga to utworzonego identyfikatora mapy. Znajdziesz go na stronie Zarządzanie mapami.
- Wczytaj interfejs Maps JavaScript API, dodając wbudowany program wczytujący bootstrap do kodu aplikacji, jak pokazano w tym fragmencie kodu:
<script> (g=>{var h,a,k,p="The Google Maps JavaScript API",c="google",l="importLibrary",q="__ib__",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=>h||(h=new Promise(async(f,n)=>{await (a=m.createElement("script"));e.set("libraries",[...r]+"");for(k in g)e.set(k.replace(/[A-Z]/g,t=>"_"+t[0].toLowerCase()),g[k]);e.set("callback",c+".maps."+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=>h=n(Error(p+" could not load."));a.nonce=m.querySelector("script[nonce]")?.nonce||"";m.head.append(a)}));d[l]?console.warn(p+" only loads once. Ignoring:",g):d[l]=(f,...n)=>r.add(f)&&u().then(()=>d[l](f,...n))})({ key: "YOUR_API_KEY", v: "weekly", // Use the 'v' parameter to indicate the version to use (weekly, beta, alpha, etc.). // Add other bootstrap parameters as needed, using camel case. }); </script>
Podczas tworzenia instancji mapy za pomocą właściwości
mapIdpodaj identyfikator mapy. Powinien to być identyfikator mapy skonfigurowany za pomocą stylu mapy z włączonymi warstwami funkcji.map = new google.maps.Map(document.getElementById('map'), { center: {lat: -34.397, lng: 150.644}, zoom: 8, mapId: 'MAP_ID' // A map ID using a style with one or more feature layers enabled. });
Więcej informacji o wczytywaniu interfejsu Maps JavaScript API.
Dodawanie warstw funkcji do mapy
Aby uzyskać odniesienie do warstwy mapy na mapie, po zainicjowaniu mapy wywołaj funkcję map.getFeatureLayer():
function initMap() { map = new google.maps.Map(document.getElementById("map"), { center: { lat: 20.773, lng: -156.01 }, zoom: 12, mapId: 'MAP_ID', }); // Add a feature layer for localities. localityLayer = map.getFeatureLayer('LOCALITY'); ... }
Sprawdzanie możliwości mapy
Style oparte na danych w przypadku granic wymagają możliwości, które są włączone w Konsoli interfejsów API Google i powiązane z identyfikatorem mapy. Identyfikatory map są tymczasowe i mogą się zmieniać, dlatego przed wywołaniem określonej możliwości (np. stylów opartych na danych) możesz wywołać funkcję map.getMapCapabilities(), aby sprawdzić, czy jest ona dostępna. Ten krok jest opcjonalny.
Poniższy przykład pokazuje, jak dodać odbiornik, aby subskrybować zmiany możliwości mapy:
// subscribe to changes map.addListener('mapcapabilities_changed', () => { const mapCapabilities = map.getMapCapabilities(); if (!mapCapabilities.isDataDrivenStylingAvailable) { // Data-driven styling is *not* available, add a fallback. // Existing feature layers are also unavailable. } });
Dalsze kroki
- Stylizowanie wielokąta granicy
- Tworzenie kartogramu
- Obsługa zdarzeń myszy
- Pobieranie identyfikatora miejsca dla regionu
- Używanie interfejsów Geocoding API i Places API ze stylami opartymi na danych w przypadku granic