יצירה של מפת שדרת קניות

בחירת פלטפורמה: Android iOS JavaScript

מפה כורוטית היא סוג של מפה נושאים שבה אזורים מנהליים צבעוניות או מוצללות בהתאם לערך הנתונים. אפשר להשתמש במפעל סגנונות פונקציה כדי לעצב מפה המבוססת על נתונים שבהם כל אזור מנהלי שמשויך לטווח של ערכים מספריים. במפה לדוגמה הבאה מוצג מפת כורוקפלת של מדינות ארצות הברית.

בדוגמה הזו, הנתונים מכילים מזהה מקום של המדינה. הסגנון הפונקציה של היצרן צובעת כל מצב באופן מותנה בהתאם לערך המגובב (hashed) של מזהה המקום של המדינה.

צילום מסך שבו מוצגת מפת כוורופלט של המדינות בארה"ב.

  1. אם עדיין לא עשית זאת, יש לפעול לפי השלבים המפורטים ב- איך מתחילים כדי ליצור מזהה מפה וסגנון מפה חדשים. חשוב להפעיל את אזור מנהלי ברמה 1.

  2. לקבל הפניה לשכבת התכונות ברמה 1 של האזור המנהלי כאשר המפה תופעל. בארצות הברית, הרמות המנהליות האלה שתואמים לכל מדינה בנפרד.

    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. צרו פונקציה מתקדמת של סגנון ומחילים אותה על שכבת המאפיין 'אזור מנהלי' ברמה 1. הדוגמה הבאה מחילה את לפוליגון שמייצג כל מדינה בארצות הברית.

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