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