โดยค่าเริ่มต้น จุดที่น่าสนใจ (POI) จะปรากฏขึ้นบนแผนที่ฐานพร้อมกับไอคอนที่เกี่ยวข้อง จุดที่น่าสนใจ ได้แก่ สวนสาธารณะ โรงเรียน อาคารของหน่วยงานราชการ และอื่นๆ
นอกจากนี้ จุดที่น่าสนใจสำหรับธุรกิจจะปรากฏขึ้นบนแผนที่โดยค่าเริ่มต้นเมื่อประเภทแผนที่คือ normal
จุดที่น่าสนใจของธุรกิจแสดงถึงธุรกิจต่างๆ เช่น ร้านค้า ร้านอาหาร โรงแรม และอื่นๆ จุดที่น่าสนใจทางธุรกิจในแผนที่ในอาคาร (แปลนอาคาร) จะปรากฏบนแผนที่โหมด Lite เท่านั้น
จุดที่น่าสนใจจะสอดคล้องกับรหัสสถานที่ตามที่กำหนดไว้ใน SDK ของ Places สำหรับ Android ตัวอย่างเช่น สวนสันทนาการเป็นจุดที่น่าสนใจ แต่สิ่งต่างๆ อย่างน้ำพุมักจะไม่ใช่จุดที่น่าสนใจ (เว้นแต่มีความสำคัญในประเทศหรือมีความสำคัญทางประวัติศาสตร์)
ฟังเหตุการณ์การคลิกบนจุดที่น่าสนใจ
หากต้องการตอบกลับเมื่อผู้ใช้แตะจุดที่น่าสนใจ ให้ใช้ OnPoiClickListener
ดังที่แสดงในตัวอย่างโค้ดต่อไปนี้
Kotlin
internal class OnPoiClickDemoActivity : AppCompatActivity(), OnMapReadyCallback, OnPoiClickListener { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.poi_click_demo) val mapFragment = supportFragmentManager.findFragmentById(R.id.map) as SupportMapFragment mapFragment.getMapAsync(this) } override fun onMapReady(map: GoogleMap) { map.setOnPoiClickListener(this) } override fun onPoiClick(poi: PointOfInterest) { Toast.makeText(this, """Clicked: ${poi.name} Place ID:${poi.placeId} Latitude:${poi.latLng.latitude} Longitude:${poi.latLng.longitude}""", Toast.LENGTH_SHORT ).show() } }
Java
class OnPoiClickDemoActivity extends AppCompatActivity implements OnMapReadyCallback, GoogleMap.OnPoiClickListener { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.poi_click_demo); SupportMapFragment mapFragment; mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map); mapFragment.getMapAsync(this); } @Override public void onMapReady(GoogleMap map) { map.setOnPoiClickListener(this); } @Override public void onPoiClick(PointOfInterest poi) { Toast.makeText(this, "Clicked: " + poi.name + "\nPlace ID:" + poi.placeId + "\nLatitude:" + poi.latLng.latitude + " Longitude:" + poi.latLng.longitude, Toast.LENGTH_SHORT).show(); } }
โดยค่าเริ่มต้น จุดที่น่าสนใจจะปรากฏบนแผนที่ แต่ไม่มี UI เริ่มต้นเมื่อคลิก กล่าวคือ API จะไม่แสดงหน้าต่างข้อมูลหรืออินเทอร์เฟซผู้ใช้อื่นๆ โดยอัตโนมัติเมื่อผู้ใช้แตะจุดที่น่าสนใจ
ตามตัวอย่างข้างต้น คุณตั้งค่า OnPoiClickListener
บนแผนที่โดยโทรไปที่ GoogleMap.setOnPoiClickListener(OnPoiClickListener)
เมื่อผู้ใช้คลิก (แตะ) จุดที่น่าสนใจ แอปของคุณจะได้รับเหตุการณ์ OnPoiClick(PointOfInterest)
ที่ระบุจุดสนใจ (POI) ที่ผู้ใช้คลิก PointOfInterest
มีพิกัดละติจูด/ลองจิจูด รหัสสถานที่ และชื่อจุดสนใจ
หยุดจุดที่น่าสนใจไม่ให้แสดงบนแผนที่
คุณซ่อนจุดที่น่าสนใจ (POI) ได้โดยใช้รูปแบบที่กำหนดเองกับจุดที่น่าสนใจทั้งหมดหรือกับหมวดหมู่ที่เจาะจงของจุดที่น่าสนใจ
การประกาศรูปแบบ JSON ต่อไปนี้จะซ่อนจุดที่น่าสนใจของธุรกิจทั้งหมดบนแผนที่
[
{
"featureType": "poi.business",
"stylers": [
{ "visibility": "off" }
]
}
]
อีกตัวอย่างหนึ่งก็คือ JSON ต่อไปนี้ช่วยลดความซับซ้อนในการแสดงจุดที่น่าสนใจในทุกหมวดหมู่
[
{
"featureType": "poi",
"stylers": [
{ "visibility": "simplified" }
]
}
]
สำหรับโค้ด Java และรายละเอียดอื่นๆ โปรดดูคู่มือการซ่อนฟีเจอร์แผนที่ด้วยการจัดรูปแบบ