ควบคุมลักษณะการชน ความสูง และระดับการมองเห็น

เลือกแพลตฟอร์ม: Android iOS JavaScript

หน้านี้จะแสดงวิธีควบคุมลักษณะต่อไปนี้ของเครื่องหมายขั้นสูง

  • ตั้งค่าลักษณะการทำงานเมื่อเครื่องหมายทับซ้อนกัน
  • กำหนดระดับความสูงของเครื่องหมาย
  • ควบคุมระดับการมองเห็นเครื่องหมายตามระดับการซูมแผนที่

ตั้งค่าลักษณะการทำงานเมื่อเครื่องหมายทับซ้อนกัน

ลักษณะการทำงานเมื่อเกิดการทับซ้อนจะควบคุมวิธีที่เครื่องหมายจะแสดงหากทับซ้อนกับเครื่องหมายอื่น ระบบรองรับลักษณะการทำงานของการทับซ้อนในแผนที่เวกเตอร์เท่านั้น

หากต้องการตั้งค่าลักษณะการทำงานเมื่อเกิดการชนกัน ให้ตั้งค่า AdvancedMarkerElement.collisionBehavior เป็นค่าใดค่าหนึ่งต่อไปนี้

  • REQUIRED: (ค่าเริ่มต้น) แสดงเครื่องหมายเสมอไม่ว่าจะมีการทับซ้อนกันหรือไม่
  • OPTIONAL_AND_HIDES_LOWER_PRIORITY แสดงเครื่องหมายเฉพาะในกรณีที่เครื่องหมายไม่ ทับซ้อนกับเครื่องหมายอื่นๆ หากเครื่องหมาย 2 รายการประเภทนี้ทับซ้อนกัน ระบบจะแสดงเครื่องหมายที่มี zIndex สูงกว่า หากมี zIndex เดียวกัน ระบบจะแสดงรายการที่มี ตำแหน่งหน้าจอแนวตั้งต่ำกว่า
  • REQUIRED_AND_HIDES_OPTIONAL แสดงเครื่องหมายเสมอไม่ว่าจะมีการทับซ้อนกันหรือไม่ และซ่อนเครื่องหมายหรือป้ายกำกับOPTIONAL_AND_HIDES_LOWER_PRIORITYที่ทับซ้อนกับเครื่องหมาย

ตัวอย่างต่อไปนี้แสดงการตั้งค่าลักษณะการทำงานเมื่อเครื่องหมายทับซ้อนกัน

TypeScript

const advancedMarker = new AdvancedMarkerElement({
  position: new google.maps.LatLng({ lat, lng }),
  map,
  collisionBehavior: collisionBehavior,
});

JavaScript

const advancedMarker = new AdvancedMarkerElement({
    position: new google.maps.LatLng({ lat, lng }),
    map,
    collisionBehavior: collisionBehavior,
});

กำหนดระดับความสูงของเครื่องหมาย

ในแผนที่เวกเตอร์ คุณสามารถตั้งค่าระดับความสูงที่เครื่องหมายจะปรากฏได้ ซึ่งมีประโยชน์ในการทำให้เครื่องหมายปรากฏอย่างถูกต้องเมื่อเทียบกับเนื้อหาแผนที่ 3 มิติ หากต้องการตั้งค่า ระดับความสูงสำหรับเครื่องหมาย ให้ระบุ LatLngAltitude เป็นค่าสำหรับตัวเลือก MarkerView.position ดังนี้

TypeScript

const pin = new PinElement({
    background: '#4b2e83',
    borderColor: '#b7a57a',
    glyphColor: '#b7a57a',
    scale: 2.0,
});

const markerView = new AdvancedMarkerElement({
    map,
    content: pin.element,
    // Set altitude to 20 meters above the ground.
    position: { lat: 47.65170843460547, lng: -122.30754, altitude: 20 } as google.maps.LatLngAltitudeLiteral,
});

JavaScript

const pin = new PinElement({
    background: '#4b2e83',
    borderColor: '#b7a57a',
    glyphColor: '#b7a57a',
    scale: 2.0,
});
const markerView = new AdvancedMarkerElement({
    map,
    content: pin.element,
    // Set altitude to 20 meters above the ground.
    position: { lat: 47.65170843460547, lng: -122.30754, altitude: 20 },
});

ควบคุมระดับการมองเห็นเครื่องหมายตามระดับการซูมแผนที่

ดูการเปลี่ยนแปลงระดับการมองเห็นของเครื่องหมาย (เริ่มด้วยการซูมออก)

หากต้องการควบคุมระดับการมองเห็นของเครื่องหมายขั้นสูง ให้สร้างzoom_changed Listener แล้วเพิ่มฟังก์ชันแบบมีเงื่อนไขเพื่อตั้งค่า AdvancedMarkerElement.map เป็น null หากระดับการซูมเกินระดับที่ระบุ ดังที่แสดงในตัวอย่างต่อไปนี้

TypeScript

map.addListener('zoom_changed', () => {
    const zoom = map.getZoom();
    if (zoom) {
        // Only show each marker above a certain zoom level.
        marker01.map = zoom > 14 ? map : null;
        marker02.map = zoom > 15 ? map : null;
        marker03.map = zoom > 16 ? map : null;
        marker04.map = zoom > 17 ? map : null;
    }
});

JavaScript

map.addListener("zoom_changed", () => {
  const zoom = map.getZoom();

  if (zoom) {
    // Only show each marker above a certain zoom level.
    marker01.map = zoom > 14 ? map : null;
    marker02.map = zoom > 15 ? map : null;
    marker03.map = zoom > 16 ? map : null;
    marker04.map = zoom > 17 ? map : null;
  }
});

ขั้นตอนถัดไป

ทำให้เครื่องหมายคลิกได้และเข้าถึงได้