تظهر تلقائيًا نقاط الاهتمام على الخريطة الأساسية مع الرموز المقابلة لها. تشمل نقاط الاهتمام المتنزهات والمدارس والمباني الحكومية وغيرها. بالإضافة إلى ذلك، تظهر نقاط الاهتمام الخاصة بالأنشطة التجارية تلقائيًا على الخريطة عندما يكون نوع الخريطة kGMSTypeNormal
. تمثّل نقاط الاهتمام الخاصة بالأنشطة التجارية أنشطة تجارية مثل المتاجر والمطاعم والفنادق وغيرها.
تتطابق نقطة الاهتمام مع معرّف المكان، كما هو محدّد في حزمة تطوير البرامج (SDK) للأماكن لنظام التشغيل iOS. على سبيل المثال، المتنزهات الترفيهية هي نقاط اهتمام، ولكنّ أشياء مثل نوافير المياه ليست نقاط اهتمام بشكل عام (إلا إذا كانت ذات أهمية وطنية أو تاريخية).
الاستماع إلى أحداث النقر على نقاط الاهتمام
إذا أردت الرد على نقرة المستخدم على نقطة اهتمام، عليك تنفيذ
GMSMapViewDelegate
،
وتنفيذ طريقة
mapView(_:didTapPOIWithPlaceID:name:location:)
،
كما هو موضّح في المثال التالي:
Swift
import GoogleMaps class POI: UIViewController, GMSMapViewDelegate { override func loadView() { let camera = GMSCameraPosition.camera( withLatitude: 47.603, longitude:-122.331, zoom:14 ) let mapView = GMSMapView.map(withFrame: .zero, camera: camera) mapView.delegate = self self.view = mapView } func mapView( _ mapView: GMSMapView, didTapPOIWithPlaceID placeID: String, name: String, location: CLLocationCoordinate2D ) { print("You tapped \(name): \(placeID), \(location.latitude)/\(location.longitude)") } }
Objective-C
#import "POI.h" @import GoogleMaps; @interface POI () <GMSMapViewDelegate> @end @implementation POI - (void)loadView { GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:47.603 longitude:-122.331 zoom:14]; GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera]; mapView.delegate = self; self.view = mapView; } #pragma mark - GMSMapViewDelegate - (void)mapView:(GMSMapView *)mapView didTapPOIWithPlaceID:(NSString *)placeID name:(NSString *)name location:(CLLocationCoordinate2D)location { NSLog(@"You tapped %@: %@, %f/%f", name, placeID, location.latitude, location.longitude); } @end
عرض التفاصيل في نافذة معلومات
تظهر "نقاط الاهتمام" على الخريطة تلقائيًا، ولكن لا يتوفّر تلقائيًا أي واجهة مستخدم عند النقر (لا تعرض واجهة برمجة التطبيقات تلقائيًا نافذة معلومات أو أي واجهة مستخدم أخرى عندما ينقر المستخدم على "نقطة اهتمام"). يوضّح المثال التالي كيفية استخدام علامة لعرض نافذة معلومات خاصة بمكان يهمّك:
Swift
// Declare GMSMarker instance at the class level. let infoMarker = GMSMarker() // Attach an info window to the POI using the GMSMarker. func mapView( _ mapView: GMSMapView, didTapPOIWithPlaceID placeID: String, name: String, location: CLLocationCoordinate2D ) { infoMarker.snippet = placeID infoMarker.position = location infoMarker.title = name infoMarker.opacity = 0; infoMarker.infoWindowAnchor.y = 1 infoMarker.map = mapView mapView.selectedMarker = infoMarker }
Objective-C
// Declare a GMSMarker instance at the class level. GMSMarker *infoMarker; // Attach an info window to the POI using the GMSMarker. - (void)mapView:(GMSMapView *)mapView didTapPOIWithPlaceID:(NSString *)placeID name:(NSString *)name location:(CLLocationCoordinate2D)location { infoMarker = [GMSMarker markerWithPosition:location]; infoMarker.snippet = placeID; infoMarker.title = name; infoMarker.opacity = 0; CGPoint pos = infoMarker.infoWindowAnchor; pos.y = 1; infoMarker.infoWindowAnchor = pos; infoMarker.map = mapView; mapView.selectedMarker = infoMarker; }
إيقاف عرض "نقاط الاهتمام" على الخريطة
يمكنك إخفاء نقاط الاهتمام من خلال تطبيق أنماط مخصّصة على جميع نقاط الاهتمام أو على فئات محدّدة من نقاط الاهتمام.
يخفي تعريف نمط JSON التالي جميع نقاط الاهتمام الخاصة بالأنشطة التجارية على الخريطة:
[
{
"featureType": "poi.business",
"stylers": [
{ "visibility": "off" }
]
}
]
كمثال آخر، يسهّل ملف JSON التالي عرض جميع فئات نقاط الاهتمام:
[
{
"featureType": "poi",
"stylers": [
{ "visibility": "simplified" }
]
}
]
لمزيد من التفاصيل، اطّلِع على دليل إخفاء ميزات الخريطة باستخدام التنسيق.