ป๊อปโอเวอร์จะแสดงเนื้อหา (โดยปกติคือข้อความหรือรูปภาพ) ในหน้าต่างบอลลูนข้อมูล เหนือแผนที่ ณ ตำแหน่งที่ระบุ ป๊อปโอเวอร์มีพื้นที่เนื้อหาและ ก้านเรียว โดยปลายก้านจะติดอยู่กับตำแหน่งที่ระบุบนแผนที่
โดยปกติแล้ว คุณจะแนบป๊อปโอเวอร์กับเครื่องหมาย แต่คุณยังแนบป๊อปโอเวอร์กับLatLngพิกัดที่เฉพาะเจาะจงได้ด้วย
เพิ่มป๊อปโอเวอร์
หากต้องการเพิ่มป๊อปโอเวอร์ ให้สร้างออบเจ็กต์ Popover แล้วตั้งค่าตัวเลือก รวมถึง
โหมดตำแหน่งและความสูง ตำแหน่งคือออบเจ็กต์ LatLng ซึ่งมีละติจูด ลองจิจูด และระดับความสูงที่กำหนดตำแหน่งที่แสดงป๊อปโอเวอร์
หากยึดกับเครื่องหมาย ระบบจะใช้ตำแหน่งของเครื่องหมายแทน
นอกจากนี้ คุณยังควบคุมวิธีตีความระดับความสูงได้โดยตั้งค่าโหมดระดับความสูง
เนื้อหาของป๊อปโอเวอร์ต้องอยู่ใน AndroidView ป๊อปโอเวอร์จะเลื่อนได้โดยค่าเริ่มต้นและมีความสูงสูงสุดที่กำหนดไว้ล่วงหน้า
ยึดป๊อปโอเวอร์กับเครื่องหมาย
คุณยึดป๊อปโอเวอร์กับเครื่องหมายได้ เมื่อเพิ่มป๊อปโอเวอร์ที่ยึดกับเครื่องหมาย
คุณต้องเชื่อมโยงป๊อปโอเวอร์กับMarkerออบเจ็กต์
class MapManager(private val map: MapView) {
/**
* Adds a popover anchored to a marker.
* @param context The Context required to instantiate UI views.
*/
fun addPopoverToMarker(context: Context) {
// 1. Create a marker
val markerOptions = markerOptions {
position = latLngAltitude {
latitude = 37.422
longitude = -122.084
altitude = 0.0
}
}
val marker = map.addMarker(markerOptions) ?: return
// 2. Create the custom view using the passed-in context
val textView = TextView(context).apply {
text = context.getString(R.string.popover_hello)
setPadding(16, 16, 16, 16)
setBackgroundColor(Color.WHITE)
setTextColor(Color.BLACK)
}
// 3. Configure and display the popover
val options = popoverOptions {
content = textView
positionAnchor = marker
altitudeMode = AltitudeMode.RELATIVE_TO_GROUND
}
val popover = map.addPopover(options)
popover.show()
}
}
เพิ่มป๊อปอัปที่กำหนดค่าแล้ว
ตัวอย่างต่อไปนี้จะเพิ่มป๊อปโอเวอร์ที่จะปิดโดยอัตโนมัติเมื่อผู้ใช้แตะ ภายนอกป๊อปโอเวอร์ และจะไม่เลื่อนไปยังป๊อปโอเวอร์ที่เพิ่งเปิดโดยอัตโนมัติ
/**
* Adds a configured popover (auto-close enabled, auto-pan disabled).
* @param context The Context used to inflate the UI and retrieve string resources.
*/
fun addConfiguredPopover(context: Context) {
// 1. Initialize the view with the explicit context
val textView = TextView(context).apply {
text = context.getString(com.example.snippets.common.R.string.popover_info)
setPadding(12, 12, 12, 12)
setBackgroundColor(Color.WHITE)
setTextColor(Color.BLACK)
}
// 2. Configure popover behavior
val options = popoverOptions {
content = textView
// Setting a fixed coordinate anchor
positionAnchor = latLngAltitude {
latitude = 0.0
longitude = 0.0
altitude = 0.0
}
autoCloseEnabled = true // Closes automatically when the map is tapped elsewhere
autoPanEnabled = false // Map camera remains stationary when popover appears
}
// 3. Add to the map instance
map.addPopover(options)
}