בדף הזה מוסבר איך להוסיף מערך נתונים למפה ולהחיל עליו סגנון.
דרישות מוקדמות
כדי להמשיך, אתם צריכים שיהיו לכם מזהה מפה, סגנון מפה ומזהה מערך נתונים.
שיוך מזהה של מערך נתונים לסגנון מפה
כדי להחיל סגנון על התכונות של מערך נתונים, מחילים פונקציית סגנון על שכבת התכונות של מערך הנתונים במפה. שכבת התכונות של קבוצת הנתונים נוצרת כאשר משייכים קבוצת נתונים לסגנון מפה.
כדי לשייך את מערך הנתונים לסגנון המפה:
- במסוף Google Cloud, עוברים לדף Datasets.
- לוחצים על השם של מערך הנתונים. הדף פרטי מערך הנתונים יופיע.
- לוחצים על הכרטיסייה Preview (תצוגה מקדימה).
- בקטע סגנונות מפה משויכים, לוחצים על הוספת סגנון מפה.
- מסמנים את התיבות של סגנונות המפה שרוצים לשייך ולוחצים על שמירה.
החלת סגנונות על מערך הנתונים
כדי להחיל סגנונות על מערך נתונים:
יוצרים פונקציית ייצור של סגנון שמטמיעה את הממשק
FeatureLayer.StyleFactory
. הפונקציה הזו מגדירה את הלוגיקה של עיצוב מערך הנתונים.קוראים לפונקציה
FeatureLayer.setFeatureStyle()
כדי להחיל את פונקציית מפעל הסגנונות על כל מאפיין במערך הנתונים.
יצירת פונקציית ייצור של סגנון
פונקציית מפעל הסגנונות חלה על כל התכונות בשכבת מערך הנתונים בזמן שמגדירים את הפונקציה בשכבת התכונות. הפונקציה הזו צריכה להחזיר אובייקט FeatureStyle
שמציין איך לעצב את הפוליגון.
אם מפעל הסגנונות מחזיר את הערך null
, התכונה הנתונה לא תעבור עיבוד. מידע נוסף זמין במאמר הסרת סגנון משכבה.
ה-SDK של מפות Google ל-Android מעביר מכונת
Feature
לפונקציה של היצרן של סגנון. המכונה Feature
מייצגת את המטא-נתונים של התכונה, ומספקת גישה למטא-נתונים בפונקציית המפעל של הסגנון.
הפונקציה של מפעל הסגנון תמיד אמורה להחזיר תוצאות עקביות כשהיא חלה. לדוגמה, אם רוצים לצבוע קבוצה של תכונות באופן אקראי, החלק האקראי לא צריך להופיע בפונקציה של סגנון התכונה, כי זה יגרום לתוצאות לא רצויות.
הפונקציה הזו פועלת על כל התכונות בשכבה, ולכן חשוב לבצע אופטימיזציה. כדי להימנע מהשפעה על זמני העיבוד, צריך להפעיל את הפונקציה FeatureLayer.setFeatureStyle(null)
כששכבת התכונות כבר לא בשימוש.
אפשר גם להפעיל את FeatureLayer.getDatasetId()
כדי לקבל את המזהה של מערך הנתונים.
הגדרת קו חוצה, מילוי ורדיוס נקודה
כשמעצבים את התכונה 'בהגדרת היצרן', אפשר להגדיר את ההגדרות הבאות:
צבע הקו ושקיפותו של הגבול, כפי שמוגדרים בכיתה
Color
. ערך ברירת המחדל הוא שקוף (Color.TRANSPARENT
).עובי הקו של הגבול בפיקסלים של המסך. ערך ברירת המחדל הוא 2.
צבע המילוי והשקיפות כפי שמוגדרים בכיתה
Color
. ערך ברירת המחדל הוא שקוף (Color.TRANSPARENT
).רדיוס הנקודה של תכונה של נקודה, בין 0 ל-128 פיקסלים.
שימוש בכללי סגנון פשוטים
הדרך הפשוטה ביותר לעצב תכונות היא להגדיר FeatureLayer.StyleFactory
שתמיד יוצר אובייקט FeatureStyle
זהה, ללא קשר לתכונה. אפשר להחיל את אפשרויות הסגנון של התכונות ישירות על שכבת התכונות של מערך הנתונים, או להשתמש בהן בשילוב עם FeatureStyleFunction
.
שימוש בכללי סגנון הצהרתי
אפשר להגדיר כללי סגנון באופן דקלרטיבי על סמך מאפיין של תכונה, ולהחיל אותם על כל מערך הנתונים. אפשר להחזיר את null
מהפונקציה של סגנון התכונה, למשל כדי שקבוצת משנה של תכונות תישאר בלתי נראית.
לדוגמה, אפשר להשתמש ב-method DatasetFeature.getDatasetAttributes()
כדי להחזיר Map<String,String>
של מאפיינים של מערך נתונים בשביל פיצ'ר. לאחר מכן תוכלו להתאים אישית את העיצוב של התכונה על סמך המאפיינים שלה.
בדוגמה הזו נקבע הערך של המאפיין 'highlightColor' של כל מאפיין במערך נתונים כדי לשלוט בסגנון:
Kotlin
// Get the dataset feature, so we can work with all of its attributes. val datasetFeature: DatasetFeature = feature as DatasetFeature
// Create a switch statement based on the value of the // "highlightColor" attribute of the dataset. val attributeColor: MutableMap<String, String> = datasetFeature.getDatasetAttributes() when (attributeColor["highlightColor"]) { "Black" -> { ... } "Red" -> { ... } else -> { ... } }
Java
// Get the dataset feature, so we can work with all of its attributes. DatasetFeature datasetFeature = (DatasetFeature) feature;
// Create a switch statement based on the value of the // "highlightColor" attribute of the dataset. Map<String, String> attributeColor = datasetFeature.getDatasetAttributes(); switch(attributeColor.get("highlightColor")) { case "Black": ... break; case "Red": ... break; default: // Color not defined. ... break; }
החלת סגנון על שכבת התכונה של מערך הנתונים
הדוגמה הזו מחילה פונקציית סגנון להגדרות המקוריות על פוליגון בשכבת התכונות של מערך הנתונים. הגדרת היצרן של סגנון מאפשרת להחיל על הפוליגון סגנון מילוי וקו קווים מותאמים אישית:
אם עדיין לא עשיתם זאת, עליכם לפעול לפי השלבים המפורטים במאמר תחילת העבודה כדי ליצור מזהה מפה וסגנון מפה חדשים. חשוב להפעיל את שכבת המאפיינים מערכי נתונים.
קבלת הפניה לשכבת התכונות Datasets כשהמפה מופעלת.
Kotlin
private var datasetLayer: FeatureLayer? = null
override fun onMapReady(googleMap: GoogleMap) { // Get the DATASET feature layer. datasetLayer = googleMap.getFeatureLayer(FeatureLayerOptions.Builder() .featureType(FeatureType.DATASET) // Specify the dataset ID. .datasetId(YOUR_DATASET_ID) .build())
// Apply style factory function to DATASET layer. styleDatasetsLayer() }Java
private FeatureLayer datasetLayer;
@Override public void onMapReady(GoogleMap map) { // Get the DATASET feature layer. datasetLayer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.DATASET) // Specify the dataset ID. .datasetId(YOUR_DATASET_ID) .build());
// Apply style factory function to DATASET layer. styleDatasetsLayer(); }ליצור פונקציה להגדרות המקוריות של סגנון ולהחיל אותה על שכבת התכונות של מערכי הנתונים.
בדוגמה הבאה נעשה שימוש באותו מילוי ובאותה קווים לכל התכונות במערך הנתונים.
Kotlin
private fun styleDatasetsLayer() {
// Create the style factory function. val styleFactory = FeatureLayer.StyleFactory { feature: Feature ->
// Check if the feature is an instance of DatasetFeature. if (feature is DatasetFeature) {
return@StyleFactory FeatureStyle.Builder() // Define a style with green fill at 50% opacity and // solid green border. .fillColor(0x8000ff00.toInt()) .strokeColor(0xff00ff00.toInt()) .strokeWidth(2F) .build() } return@StyleFactory null }
// Apply the style factory function to the feature layer. datasetLayer?.setFeatureStyle(styleFactory) }Java
private void styleDatasetsLayer() {
// Create the style factory function. FeatureLayer.StyleFactory styleFactory = (Feature feature) -> {
// Check if the feature is an instance of DatasetFeature. if (feature instanceof DatasetFeature) {
return new FeatureStyle.Builder() // Define a style with green fill at 50% opacity and solid green border. .fillColor(0x8000ff00) .strokeColor(0xff00ff00) .strokeWidth(2) .build(); } return null; };
// Apply the style factory function to the feature layer. datasetLayer.setFeatureStyle(styleFactory); }
הסרת סגנון משכבה
כדי להסיר עיצוב משכבה, קוראים לפונקציה FeatureLayer.setFeatureStyle(null)
.
אפשר גם להחזיר את null
ממפעל הסגנון, למשל אם רוצים שקבוצת משנה של תכונות תישאר בלתי נראית.