หน้านี้จะแสดงวิธีควบคุมลักษณะต่อไปนี้ของเครื่องหมายขั้นสูง
- ตั้งค่าลักษณะการทำงานเมื่อเครื่องหมายทับซ้อนกัน
- กำหนดระดับความสูงของเครื่องหมาย
- ควบคุมระดับการมองเห็นเครื่องหมายตามระดับการซูมแผนที่
ตั้งค่าลักษณะการทำงานเมื่อเครื่องหมายทับซ้อนกัน
ลักษณะการทำงานของการซ้อนทับจะควบคุมวิธีที่เครื่องหมายจะแสดงหากซ้อนทับกับเครื่องหมายอื่น ระบบรองรับลักษณะการทำงานของการทับซ้อนในแผนที่เวกเตอร์เท่านั้น
หากต้องการตั้งค่าลักษณะการทำงานเมื่อเกิดการชนกัน ให้ตั้งค่า 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
เครื่องรับฟัง และเพิ่มฟังก์ชันแบบมีเงื่อนไขเพื่อตั้งค่า 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; } });
ขั้นตอนถัดไป
ทำให้เครื่องหมายคลิกได้และเข้าถึงได้