
একটি পপওভার মানচিত্রের উপরে একটি তথ্য বাবল উইন্ডোতে, একটি নির্দিষ্ট স্থানে বিষয়বস্তু (সাধারণত পাঠ্য বা ছবি) প্রদর্শন করে। পপওভারটিতে একটি বিষয়বস্তু এলাকা এবং একটি টেপারড স্টেম থাকে। স্টেমের ডগা মানচিত্রের একটি নির্দিষ্ট অবস্থানের সাথে সংযুক্ত থাকে।
সাধারণত আপনি একটি মার্কারের সাথে একটি পপওভার সংযুক্ত করবেন, তবে আপনি একটি নির্দিষ্ট 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)
}