Theo mặc định, các địa điểm thu hút (POI) sẽ xuất hiện trên bản đồ cơ sở cùng với các biểu tượng tương ứng. POI bao gồm công viên, trường học, toà nhà chính phủ và nhiều địa điểm khác.
Ngoài ra, các POI doanh nghiệp sẽ xuất hiện theo mặc định trên bản đồ khi loại bản đồ là normal. POI doanh nghiệp đại diện cho các doanh nghiệp như cửa hàng, nhà hàng, khách sạn và nhiều doanh nghiệp khác. POI doanh nghiệp trên bản đồ trong nhà (sơ đồ mặt bằng) chỉ xuất hiện trên bản đồ ở chế độ
đơn giản.
POI tương ứng với Mã địa điểm, như được xác định trong SDK Địa điểm dành cho Android. Ví dụ: công viên giải trí là POI, nhưng những thứ như đài phun nước thường không phải là POI (trừ phi chúng có ý nghĩa quốc gia hoặc lịch sử).
Theo dõi các sự kiện nhấp vào POI
Nếu muốn phản hồi khi người dùng nhấn vào một POI, bạn có thể sử dụng
OnPoiClickListener như trong mã mẫu sau:
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(); } }
POI xuất hiện trên bản đồ theo mặc định, nhưng không có giao diện người dùng mặc định khi nhấp. Tức là API không tự động hiển thị cửa sổ thông tin hoặc bất kỳ giao diện người dùng nào khác khi người dùng nhấn vào một POI.
Như mẫu ở trên cho thấy, bạn đặt
OnPoiClickListener trên bản đồ bằng cách
gọi
GoogleMap.setOnPoiClickListener(OnPoiClickListener).
Khi người dùng nhấp (nhấn) vào một POI, ứng dụng của bạn sẽ nhận được sự kiện
OnPoiClick(PointOfInterest) cho biết địa điểm yêu thích (POI) mà người dùng đã nhấp vào. The
PointOfInterest chứa toạ độ vĩ độ/kinh độ,
mã địa điểm và tên của địa điểm yêu thích.
Ngừng hiển thị POI trên bản đồ
Bạn có thể ẩn các địa điểm thu hút (POI) bằng cách áp dụng kiểu tuỳ chỉnh cho tất cả POI hoặc cho các danh mục POI cụ thể.
Tuyên bố kiểu JSON sau đây sẽ ẩn tất cả POI doanh nghiệp trên bản đồ:
[
{
"featureType": "poi.business",
"stylers": [
{ "visibility": "off" }
]
}
]
Ví dụ khác, JSON sau đây sẽ đơn giản hoá việc hiển thị tất cả danh mục POI:
[
{
"featureType": "poi",
"stylers": [
{ "visibility": "simplified" }
]
}
]
Để biết mã Java và các thông tin chi tiết khác, hãy xem hướng dẫn về cách ẩn các tính năng trên bản đồ bằng kiểu.