इस पेज पर, मार्कर के लिए टक्कर के व्यवहार को कंट्रोल करने का तरीका बताया गया है.
मार्कर के लिए, टक्कर का व्यवहार सेट करना
टकराव के व्यवहार से यह तय होता है कि अगर कोई मार्कर किसी दूसरे मार्कर से टकराता है (ओवरलैप होता है), तो वह कैसा दिखेगा. उन्नत मार्कर बनाने का तरीका यह तय करता है कि टक्कर का व्यवहार कैसे काम करता है:
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-index देखें.अगर दो व्यू मार्कर ओवरलैप होते हैं, तो सबसे ज़्यादा
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 = CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL val advancedMarkerOptions: AdvancedMarkerOptions = AdvancedMarkerOptions() .position(LatLng(10.0, 10.0)) .collisionBehavior(collisionBehavior) val marker: Marker = map.addMarker(advancedMarkerOptions) ?: error("Failed to add marker")
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(new LatLng(10.0, 10.0)) .collisionBehavior(collisionBehavior); Marker marker = map.addMarker(options);