Utwórz mapę chokole

Wybierz platformę: Android iOS JavaScript

Mapa choropletyczna to rodzaj mapy tematycznej, na której obszary administracyjne są zabarwione lub zacienione zgodnie z wartością danych. Za pomocą funkcji stylu fabrycznego możesz nadać styl mapie na podstawie danych, w których każdy obszar administracyjny jest powiązany z zakresem wartości liczbowych. Przykładowa mapa poniżej przedstawia mapę chorochromatyczną stanów w Stanach Zjednoczonych.

W tym przykładzie dane obejmują identyfikator miejsca w stanie. Funkcja stylefactory nadaje kolory poszczególnym stanom na podstawie zaszyfrowanej wartości identyfikatora miejsca dla danego stanu.

Zrzut ekranu przedstawiający mapę choropletywną stanów USA.

  1. Jeśli jeszcze tego nie zrobiono, wykonaj czynności opisane w sekcji Pierwsze kroki, aby utworzyć nowy identyfikator mapy i nowy styl mapy. Pamiętaj, aby włączyć warstwę obiektów Obszar administracyjny poziomu 1.

  2. Początkowy odczyt mapy zwraca odwołanie do warstwy obiektu Region administracyjny poziomu 1. W Stanach Zjednoczonych te poziomy administracyjne odpowiadają poszczególnym stanom.

    Java

    private FeatureLayer areaLevel1Layer;
    @Override public void onMapReady(GoogleMap map) { areaLevel1Layer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.ADMINISTRATIVE_AREA_LEVEL_1) .build());
    // Apply style factory function to ADMINISTRATIVE_AREA_LEVEL_1 layer. styleAreaLevel1Layer(); }

    Kotlin

    private var areaLevel1Layer: FeatureLayer? = null
    override fun onMapReady(googleMap: GoogleMap) { // Get the ADMINISTRATIVE_AREA_LEVEL_1 feature layer. areaLevel1Layer = googleMap.getFeatureLayer(FeatureLayerOptions.Builder() .featureType(FeatureType.ADMINISTRATIVE_AREA_LEVEL_1) .build())
    // Apply style factory function to ADMINISTRATIVE_AREA_LEVEL_1 layer. styleAreaLevel1Layer() }

  3. Utwórz funkcję fabryki stylów i zastosuj ją do warstwy obiektu Administracyjna jednostka podziału terytorialnego poziomu 1. W tym przykładzie funkcja jest stosowana do wielokąta reprezentującego poszczególne stany Stanów Zjednoczonych.

    Java

    private void styleAreaLevel1Layer() {
      FeatureLayer.StyleFactory styleFactory = (Feature feature) -> {
        if (feature instanceof PlaceFeature) {
          PlaceFeature placeFeature = (PlaceFeature) feature;
    // Return a hueColor in the range [-299,299]. If the value is // negative, add 300 to make the value positive. int hueColor = placeFeature.getPlaceId().hashCode() % 300; if (hueColor < 0) { hueColor += 300; }
    return new FeatureStyle.Builder() // Set the fill color for the state based on the hashed hue color. .fillColor(Color.HSVToColor(150, new float[] {hueColor, 1, 1})) .build(); } return null; };
    // Apply the style factory function to the feature layer. areaLevel1Layer.setFeatureStyle(styleFactory); }

    Kotlin

    private fun styleAreaLevel1Layer() {
      val styleFactory = FeatureLayer.StyleFactory { feature: Feature ->
          if (feature is PlaceFeature) {
              val placeFeature: PlaceFeature = feature as PlaceFeature
    // Return a hueColor in the range [-299,299]. If the value is // negative, add 300 to make the value positive. var hueColor: Int = placeFeature.getPlaceId().hashCode() % 300 if (hueColor < 0) { hueColor += 300 } return@StyleFactory FeatureStyle.Builder() // Set the fill color for the state based on the hashed hue color. .fillColor(Color.HSVToColor(150, floatArrayOf(hueColor.toFloat(), 1f, 1f))) .build() } return@StyleFactory null }
    // Apply the style factory function to the feature layer. areaLevel1Layer?.setFeatureStyle(styleFactory) }