किसी फ़ीचर लेयर में मौजूद बाउंड्री पॉलीगॉन पर स्ट्रोक और फ़िल के लिए स्टाइल लागू करने के लिए:
स्टाइल फ़ैक्ट्री फ़ंक्शन बनाएं, जो
FeatureLayer.StyleFactoryइंटरफ़ेस को लागू करता हो. यह फ़ंक्शन, किसी फ़ीचर लेयर के लिए स्टाइलिंग लॉजिक तय करता है.फ़ीचर लेयर पर स्टाइल फ़ैक्ट्री फ़ंक्शन लागू करने के लिए,
FeatureLayer.setFeatureStyle()को कॉल करें.
यहां दिए गए उदाहरण के तौर पर दिखाए गए मैप में, Locality फ़ीचर लेयर में किसी एक इलाके के लिए बाउंड्री पॉलीगॉन को हाइलाइट किया गया है.
स्टाइल फ़ैक्ट्री फ़ंक्शन बनाना
स्टाइल फ़ैक्ट्री फ़ंक्शन, चुनी गई फ़ीचर लेयर में मौजूद हर पॉलीगॉन पर लागू होता है. ऐसा तब होता है, जब फ़ीचर लेयर पर फ़ंक्शन सेट किया जाता है. इस फ़ंक्शन को
FeatureStyle
ऑब्जेक्ट दिखाना होगा. इससे यह तय होता है कि पॉलीगॉन को स्टाइल कैसे करना है.
Android के लिए Maps SDK, स्टाइल फ़ैक्ट्री फ़ंक्शन को
Feature
इंस्टेंस पास करता है. Feature इंस्टेंस, फ़ीचर के मेटाडेटा को दिखाता है. इससे आपको स्टाइल फ़ैक्ट्री फ़ंक्शन में मेटाडेटा ऐक्सेस करने की सुविधा मिलती है.
स्टाइल फ़ैक्ट्री फ़ंक्शन को लागू करने पर, हमेशा एक जैसे नतीजे मिलने चाहिए. उदाहरण के लिए, अगर आपको फ़ीचर के किसी सेट को रैंडम तरीके से रंगना है, तो रैंडम तरीके से रंगने की प्रोसेस, फ़ीचर स्टाइल फ़ंक्शन में नहीं होनी चाहिए. ऐसा करने से, अनचाहे नतीजे मिल सकते हैं.
इस फ़ंक्शन को किसी लेयर में मौजूद हर फ़ीचर पर चलाया जाता है. इसलिए, इसे ऑप्टिमाइज़ करना ज़रूरी है. रेंडरिंग के समय पर असर पड़ने से बचने के लिए:
सिर्फ़ उन फ़ीचर लेयर को चालू करें जिनकी आपको ज़रूरत है.
जब किसी फ़ीचर लेयर का इस्तेमाल न किया जा रहा हो, तब
FeatureLayer.setFeatureStyle(null)को कॉल करें.
पॉलीगॉन स्ट्रोक और फ़िल सेट करना
स्टाइल फ़ैक्ट्री फ़ंक्शन में बाउंड्री पॉलीगॉन को स्टाइल करते समय, ये सेटिंग की जा सकती हैं:
पॉलीगॉन बॉर्डर का स्ट्रोक कलर और ओपैसिटी एआरजीबी कलर फ़ॉर्मैट में,
Colorक्लास के हिसाब से. डिफ़ॉल्ट वैल्यू, पारदर्शी (0x00000000) होती है.स्क्रीन पिक्सल में पॉलीगॉन बॉर्डर की स्ट्रोक की चौड़ाई. डिफ़ॉल्ट वैल्यू 2 होती है.
पॉलीगॉन का एआरजीबी कलर फ़ॉर्मैट में
Colorक्लास के हिसाब से, फ़िल कलर और ओपैसिटी. डिफ़ॉल्ट वैल्यू, पारदर्शी (0x00000000) होती है.
टारगेट फ़ीचर के लिए, जगह के आईडी देखना
कई ऐप्लिकेशन, फ़ीचर की जगह के हिसाब से उस पर स्टाइल लागू करते हैं. उदाहरण के लिए, हो सकता है कि आपको अलग-अलग देशों, इलाकों या क्षेत्रों पर स्टाइल लागू करना हो. फ़ीचर की जगह को, जगह के आईडी से दिखाया जाता है.
जगह के आईडी, Google Places के डेटाबेस और Google Maps पर मौजूद किसी जगह की खास तौर पर पहचान करते हैं. जगह का आईडी पाने के लिए:
- Places API और जियोकोडिंग का इस्तेमाल करके नाम के हिसाब से क्षेत्रों को खोजें. साथ ही, तय की गई सीमाओं के अंदर मौजूद क्षेत्रों के लिए जगह के आईडी पाएं.
- क्लिक इवेंट से डेटा पाएं. इससे, क्लिक किए गए क्षेत्र के हिसाब से फ़ीचर मिलता है. इससे, जगह के आईडी और फ़ीचर टाइप कैटगरी को ऐक्सेस किया जा सकता है.
कवरेज, इलाके के हिसाब से अलग-अलग होता है. ज़्यादा जानकारी के लिए, Google की सीमाओं का कवरेज देखें.
भौगोलिक नाम, कई सोर्स से उपलब्ध होते हैं. जैसे, USGS Board on Geographic Names, और U.S. Gazetteer Files.
जगह का आईडी पाने के लिए, PlaceFeature का इस्तेमाल करना
The PlaceFeature
क्लास, Feature क्लास की सबक्लास है.
यह जगह के फ़ीचर (जगह के आईडी वाला फ़ीचर) को दिखाता है. इसमें ADMINISTRATIVE_AREA_LEVEL_1, ADMINISTRATIVE_AREA_LEVEL_2, COUNTRY, LOCALITY, POSTAL_CODE, और SCHOOL_DISTRICT टाइप के फ़ीचर शामिल होते हैं.
जब जगह का आईडी उपलब्ध होता है, तब Android के लिए Maps SDK, स्टाइल फ़ैक्ट्री फ़ंक्शन को PlaceFeature का इंस्टेंस पास करता है. इससे, फ़ीचर की जगह तय की जा सकती है.
स्टाइल फ़ैक्ट्री का उदाहरण
इस उदाहरण में, Locality फ़ीचर लेयर में मौजूद पॉलीगॉन पर स्टाइल फ़ैक्ट्री फ़ंक्शन लागू किया गया है. स्टाइल फ़ैक्ट्री फ़ंक्शन, PlaceFeature इंस्टेंस का इस्तेमाल करके, फ़ीचर की जगह का आईडी तय करता है. अगर जगह का आईडी, हवाई के हाना के लिए है, तो फ़ंक्शन, पॉलीगॉन पर कस्टम फ़िल और स्ट्रोक स्टाइल लागू करता है:
अगर आपने अब तक ऐसा नहीं किया है, तो नया मैप आईडी और मैप स्टाइल बनाने के लिए, शुरू करें में दिए गए तरीके अपनाएं. Locality फ़ीचर लेयर को चालू करना न भूलें.
मैप के शुरू होने पर, Locality फ़ीचर लेयर का रेफ़रंस पाएं.
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() }स्टाइल फ़ैक्ट्री फ़ंक्शन बनाएं और उसे Locality फ़ीचर लेयर पर लागू करें.
यहां दिए गए उदाहरण में, फ़ंक्शन सिर्फ़ तब लागू होता है, जब फ़ीचर की जगह का आईडी, हवाई के हाना ("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) को कॉल करें.