Membuat peta koroplet

Pilih platform: Android iOS JavaScript

Peta koroplet adalah jenis peta tematik yang menampilkan wilayah administratif yang diberi warna atau diarsir sesuai dengan nilai data. Anda dapat menggunakan factory gaya untuk menata gaya peta berdasarkan data di mana setiap wilayah administratif yang terkait dengan rentang nilai numerik. Contoh peta berikut menunjukkan peta koroplet untuk negara bagian Amerika Serikat.

Dalam contoh ini, data terdiri dari ID tempat untuk status. Gaya fungsi factory secara kondisional mewarnai setiap negara bagian berdasarkan nilai hash dari ID tempat untuk status.

Screenshot yang menampilkan peta koroplet negara bagian AS.

  1. Jika Anda belum melakukannya, ikuti langkah-langkah berikut Memulai untuk membuat gaya peta dan ID peta baru. Pastikan untuk mengaktifkan Lapisan fitur Wilayah Administratif Level 1.

  2. Dapatkan referensi ke lapisan fitur Administratif Tingkat 1 saat peta akan diinisialisasi. Untuk Amerika Serikat, tingkat administratif ini sesuai dengan masing-masing negara bagian.

    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. Buat fungsi factory gaya dan terapkan ke Lapisan fitur Administratif Tingkat 1 Wilayah Administratif. Contoh berikut menerapkan fungsi ke poligon yang mewakili setiap negara bagian Amerika Serikat.

    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) }