الأنشطة التجارية ونقاط الاهتمام الأخرى

اختَر النظام الأساسي: Android iOS JavaScript

تظهر النقاط المهمة بشكل افتراضي على الخريطة الأساسية مع الرموز الخاصة بها. تشمل نقاط الاهتمام الحدائق والمدارس والمباني الحكومية والمزيد. بالإضافة إلى ذلك، تظهر نقاط اهتمام النشاط التجاري بشكل تلقائي على الخريطة عندما يكون نوع الخريطة 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" }
    ]
  }
]

للحصول على مزيد من التفاصيل، راجع دليل إخفاء ميزات الخريطة باستخدام التصميم.