बॉर्डर के पॉलीगॉन को स्टाइल करें

प्लैटफ़ॉर्म चुनें: Android iOS JavaScript

किसी फीचर लेयर में, बॉर्डर पॉलीगॉन पर स्ट्रोक और भरने के लिए स्टाइल लागू करने के लिए:

  1. ऐसी स्टाइल फ़ैक्ट्री फ़ंक्शन बनाएं जो FeatureLayer.StyleFactory इंटरफ़ेस पर कॉपी करने की सुविधा मिलती है. यह फ़ंक्शन, किसी फीचर लेयर के लिए स्टाइल तय करता है.

  2. फ़ीचर लेयर पर स्टाइल फ़ैक्ट्री फ़ंक्शन लागू करने के लिए, FeatureLayer.setFeatureStyle() को कॉल करें.

निम्न उदाहरण मैप में मोहल्ला सुविधा लेयर में एक क्षेत्र.

हाना हवाई का पॉलीगॉन दिखाने वाला स्क्रीनशॉट.

स्टाइल फ़ैक्ट्री फ़ंक्शन बनाएं

शैली फ़ैक्ट्री फ़ंक्शन, प्रभावित सुविधा में हर पॉलीगॉन पर लागू होता है लेयर होती है जब आप सुविधा लेयर पर फ़ंक्शन सेट करते हैं. इस फ़ंक्शन को FeatureStyle वापस करो वह ऑब्जेक्ट जो पॉलीगॉन को स्टाइल करने का तरीका बताता है.

Android के लिए Maps SDK टूल, स्टाइल फ़ैक्ट्री फ़ंक्शन को Feature इंस्टेंस पास करता है. Feature इंस्टेंस, सुविधा के मेटाडेटा को दिखाता है. इससे आपको स्टाइल फ़ैक्ट्री फ़ंक्शन में मेटाडेटा का ऐक्सेस मिलता है.

स्टाइल फ़ैक्ट्री फ़ंक्शन को हमेशा एक जैसे नतीजे देने चाहिए, जब ऐसा हो लागू किया गया. उदाहरण के लिए, अगर आपको सुविधाओं के किसी सेट को रैंडम तरीके से रंग देना है, तो रैंडम हिस्सा सुविधा के स्टाइल फ़ंक्शन में नहीं होना चाहिए. ऐसा करने से, आपको अनचाहे नतीजे मिल सकते हैं.

यह फ़ंक्शन, लेयर में मौजूद हर फ़ीचर पर काम करता है. इसलिए, ऑप्टिमाइज़ेशन ज़रूरी है. रेंडरिंग में लगने वाले समय पर असर न पड़े, इसके लिए:

  • सिर्फ़ अपनी ज़रूरत के हिसाब से सुविधाएं लेयर चालू करें.

  • जब कोई फ़ीचर लेयर बंद हो जाए, तो FeatureLayer.setFeatureStyle(null) पर कॉल करें इस्तेमाल किया जा रहा है.

पॉलीगॉन स्ट्रोक और फ़िल सेट करें

स्टाइल फ़ैक्ट्री फ़ंक्शन में, सीमा वाले पॉलीगॉन को स्टाइल करते समय, ये चीज़ें सेट की जा सकती हैं:

  • ARGB रंग फ़ॉर्मैट में पॉलीगॉन बॉर्डर का स्ट्रोक का रंग और अपारदर्शिता, जैसा कि Color क्लास. डिफ़ॉल्ट वैल्यू पारदर्शी होती है (0x00000000).

  • स्क्रीन पिक्सल में, पॉलीगॉन बॉर्डर की स्ट्रोक चौड़ाई. डिफ़ॉल्ट वैल्यू है.

  • ARGB कलर फ़ॉर्मैट में पॉलीगॉन का भरा हुआ रंग और ओपैसिटी, जैसा कि Color क्लास के हिसाब से तय किया गया है. डिफ़ॉल्ट वैल्यू पारदर्शी होती है (0x00000000).

सुविधाओं को टारगेट करने के लिए जगह के आईडी देखना

कई ऐप्लिकेशन, किसी सुविधा की जगह के आधार पर उस पर स्टाइल लागू करते हैं. उदाहरण के लिए, हो सकता है कि आपको अलग-अलग देशों, इलाकों या क्षेत्रों के लिए स्टाइल लागू करनी हो. सुविधा की जगह की जानकारी, जगह के आईडी से दी जाती है.

जगह के आईडी, Google Places डेटाबेस और Google पर किसी जगह की खास तौर पर पहचान करते हैं मैप. जगह का आईडी पाने के लिए:

कवरेज, देश/इलाके के हिसाब से अलग-अलग होती है. यहां जाएं: Google की सीमाओं का कवरेज देखें.

भौगोलिक नाम कई सोर्स से उपलब्ध होते हैं. जैसे, भौगोलिक नामों के लिए यूएसजीएस बोर्ड और अमेरिका की गज़ेटियर फ़ाइलें.

जगह का आईडी पाने के लिए PlacesFeature का इस्तेमाल करना

PlaceFeature क्लास, Feature क्लास की सब-क्लास है. यह जगह की जानकारी (जगह के आईडी वाली सुविधा) के बारे में बताता है, जिसमें ADMINISTRATIVE_AREA_LEVEL_1, ADMINISTRATIVE_AREA_LEVEL_2 टाइप की सुविधाएं COUNTRY, LOCALITY, POSTAL_CODE, और SCHOOL_DISTRICT.

जगह का आईडी उपलब्ध होने पर, Android के लिए Maps SDK, स्टाइल फ़ैक्ट्री में PlaceFeature का इंस्टेंस पास करता है ताकि आप विशेषता के स्थान का पता लगा सकें.

स्टाइल फ़ैक्ट्री का उदाहरण

इस उदाहरण में, स्टाइल फ़ैक्ट्री फ़ंक्शन को लोकैलिटी फ़ीचर लेयर में मौजूद पॉलीगॉन पर लागू किया गया है. शैली फ़ैक्ट्री फ़ंक्शन, सुविधा का स्थान आईडी तय करता है PlaceFeature इंस्टेंस का इस्तेमाल करके. अगर जगह का आईडी हाना, हवाई का है, तो फ़ंक्शन, पॉलीगॉन में ज़रूरत के मुताबिक फ़िल और स्ट्रोक स्टाइल लागू करता है:

  1. अगर आपने अब तक ऐसा नहीं किया है, तो नया मैप आईडी और मैप स्टाइल बनाने के लिए, शुरू करें में दिया गया तरीका अपनाएं. इलाके की फ़ीचर लेयर को चालू करना न भूलें.

  2. मैप शुरू होने पर, लोकलिटी फ़ीचर लेयर का रेफ़रंस पाएं.

    Java

    private FeatureLayer localityLayer;
    @Override public void onMapReady(GoogleMap map) { // Get the LOCALITY feature layer. localityLayer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.LOCALITY) .build());
    // Apply style factory function to LOCALITY layer. styleLocalityLayer(); }

    Kotlin

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

  3. एक स्टाइल फ़ैक्ट्री फ़ंक्शन बनाएं और उसे शहर में लागू करें फ़ीचर लेयर.

    नीचे दिए गए उदाहरण में फ़ंक्शन सिर्फ़ तब लागू होता है, जब सुविधा का आईडी हाना, हवाई के लिए है ("ChIJ0zQtYiWsVHkRk8lRoB1RNPo"). अगर दिया गया प्लेस आईडी, हवाई के हना के लिए नहीं है, तो स्टाइल लागू नहीं किया जाएगा.

    Java

    private void styleLocalityLayer() {
    // Create the style factory function. FeatureLayer.StyleFactory styleFactory = (Feature feature) -> {
    // Check if the feature is an instance of PlaceFeature, // which contains a place ID. if (feature instanceof PlaceFeature) { PlaceFeature placeFeature = (PlaceFeature) feature;
    // Determine if the place ID is for Hana, HI. if (placeFeature.getPlaceId().equals("ChIJ0zQtYiWsVHkRk8lRoB1RNPo")) {
    // Use FeatureStyle.Builder to configure the FeatureStyle object // returned by the style factory function. return new FeatureStyle.Builder() // Define a style with purple fill at 50% opacity and solid purple border. .fillColor(0x80810FCB) .strokeColor(0xFF810FCB) .build(); } } return null; };
    // Apply the style factory function to the feature layer. localityLayer.setFeatureStyle(styleFactory); }

    Kotlin

    private fun styleLocalityLayer() {
    // Create the style factory function. val styleFactory = FeatureLayer.StyleFactory { feature: Feature ->
    // Check if the feature is an instance of PlaceFeature, // which contains a place ID. if (feature is PlaceFeature) { val placeFeature: PlaceFeature = feature as PlaceFeature
    // Determine if the place ID is for Hana, HI. if (placeFeature.getPlaceId().equals("ChIJ0zQtYiWsVHkRk8lRoB1RNPo")) {
    // Use FeatureStyle.Builder to configure the FeatureStyle object // returned by the style factory function. return@StyleFactory FeatureStyle.Builder() // Define a style with purple fill at 50% opacity and // solid purple border. .fillColor(0x80810FCB.toInt()) .strokeColor(0xFF810FCB.toInt()) .build() } } return@StyleFactory null }
    // Apply the style factory function to the feature layer. localityLayer?.setFeatureStyle(styleFactory) }

किसी लेयर से स्टाइल हटाना

किसी लेयर से स्टाइल हटाने के लिए, FeatureLayer.setFeatureStyle(null) को कॉल करें.