यह पेज आपको किसी मार्कर के लिए टकराव के व्यवहार को कंट्रोल करने का तरीका बताता है.
मार्कर के लिए टक्कर का व्यवहार सेट करें
टक्कर का व्यवहार यह नियंत्रित करता है कि अगर कोई मार्कर किसी अन्य मार्कर से टकराता है (ओवरलैप करता है). उन्नत मार्कर बनाने का तरीका यह तय करता है कि टक्कर का व्यवहार कैसे काम करता है:
BitmapDescriptorFactory
का इस्तेमाल करके बनाए गए बेहतर मार्कर को बिटमैप मार्कर कहा जाता है. ये मार्कर मुख्य मैप से बनाए जाते हैं.AdvancedMarkerOptions.iconView()
तरीके का इस्तेमाल करके बनाए गए मार्कर सहित अन्य सभी ऐडवांस मार्कर को व्यू मार्कर कहा जाता है. इन्हें मुख्य मैप के ऊपर मौजूद लेयर पर बनाया जाता है.
एक से ज़्यादा मार्कर कंट्रोल करने के लिए, AdvancedMarkerOptions.collisionBehavior
को इनमें से किसी एक पर सेट करें:
CollisionBehavior.REQUIRED
: (डिफ़ॉल्ट) टक्कर पर ध्यान दिए बिना मार्कर हमेशा दिखाता है.CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL
मार्कर के साथ कोई टक्कर होने पर भी हमेशा दिखती है. साथ ही, मार्कर के साथ ओवरलैप करने वालेOPTIONAL_AND_HIDES_LOWER_PRIORITY
मार्कर या लेबल छिपाएं.CollisionBehavior.OPTIONAL_AND_HIDES_LOWER_PRIORITY
मार्कर को सिर्फ़ तब दिखाएं, जब यह अन्य मार्कर के साथ ओवरलैप न करता हो.अगर दो बिटमैप मार्कर ओवरलैप होते हैं, तो ज़्यादा
zIndex
वाला मार्कर दिखाया जाता है. अगर दोनों में एक हीzIndex
है, तो नीचे वाला वर्टिकल स्क्रीन वाला बटन दिखता है.zIndex
के बारे में ज़्यादा जानकारी के लिए, मार्कर z-इंडेक्स देखें.अगर दो व्यू मार्कर ओवरलैप होते हैं, तो सबसे ज़्यादा
zIndex
वाला मार्कर दिखाया जाता है. अगर उनमें एक जैसाzIndex
है, तो आखिरी बार बनाया गया मार्कर, इससे पहले बनाए गए किसी भी मार्कर को ओवरलैप कर देता है.व्यू मार्कर, बिटमैप मार्कर के ऊपर की लेयर पर बनाए जाते हैं. इसलिए, व्यू मार्कर, बिटमैप मार्कर को ओवरलैप करते हैं. इसलिए, आपको बेहतर टक्कर नियंत्रण के लिए एक ही तरह के मार्कर का इस्तेमाल करने की कोशिश करनी चाहिए.
निम्न उदाहरण में किसी मार्कर के लिए टकराव का व्यवहार सेट करने का तरीका दिखाया गया है:
Kotlin
// Collision behavior can only be changed in the AdvancedMarkerOptions object. // Changes to collision behavior after a marker has been created are not possible val collisionBehavior: Int = AdvancedMarkerOptions.CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL val advancedMarkerOptions: AdvancedMarkerOptions = AdvancedMarkerOptions() .position(latLng) .collisionBehavior(collisionBehavior)
val marker: Marker = map.addMarker(advancedMarkerOptions)
Java
// Collision behavior can only be changed in the AdvancedMarkerOptions object. // Changes to collision behavior after a marker has been created are not possible int collisionBehavior = AdvancedMarkerOptions.CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL; AdvancedMarkerOptions options = new AdvancedMarkerOptions() .position(latLng) .collisionBehavior(collisionBehavior);
Marker marker = map.addMarker(options);