टकराव का व्यवहार

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

यह पेज आपको किसी मार्कर के लिए टकराव के व्यवहार को कंट्रोल करने का तरीका बताता है.

मार्कर के लिए टक्कर का व्यवहार सेट करें

टक्कर का व्यवहार यह नियंत्रित करता है कि अगर कोई मार्कर किसी अन्य मार्कर से टकराता है (ओवरलैप करता है). उन्नत मार्कर बनाने का तरीका यह तय करता है कि टक्कर का व्यवहार कैसे काम करता है:

  • 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);