टैप इवेंट को मैनेज करना

डेटा से जुड़ी सुविधाओं को, टैप किए गए इवेंट के हिसाब से जवाब तैयार करने दें. साथ ही, टैप की गई सुविधा के लिए किसी एट्रिब्यूट की वैल्यू दिखाने के लिए इवेंट का इस्तेमाल करें.

टैप इवेंट के जवाब में स्टाइलिंग लागू करें.

डेटासेट लेयर के इवेंट मैनेज करना

इस उदाहरण में, YOUR_DATASET_ID आईडी वाले डेटासेट के लिए डेटा से जुड़ी सुविधाएं दिखाई गई हैं. साथ ही, टैप की गई सुविधा के लिए किसी एट्रिब्यूट की वैल्यू दिखाने के लिए, डेलीगेट फ़ंक्शन लागू किया गया है.

इस उदाहरण में, डेटासेट में न्यूयॉर्क शहर के पार्क दिखाए गए हैं. पार्क से जुड़ी हर डेटासेट सुविधा के लिए, डेटासेट में acres नाम का एक एट्रिब्यूट होता है. इसमें पार्क का सरफ़ेस एरिया होता है. टैप किए गए पार्क के लिए, acres एट्रिब्यूट की वैल्यू दिखाएं.

Swift

class SampleViewController: UIViewController {

  private lazy var mapView: GMSMapView = GMSMapView(frame: .zero, mapID: GMSMapID(identifier: "YOUR_MAP_ID"), camera: GMSCameraPosition(latitude: 40.7, longitude: -74, zoom: 12))

  // Set default styles.
  view = mapView
  let style = FeatureStyle(fill: .green.withAlphaComponent(0.5), stroke: .green, strokeWidth: 2)
  mapView.datasetFeatureLayer(of: "YOUR_DATASET_ID").style = { _ in style }
  mapView.delegate = self
}

extension SampleViewController: GMSMapViewDelegate {
  func mapView(_ mapView: GMSMapView, didTap features: [Feature], in featureLayer: FeatureLayer<Feature>, atLocation: CLLocationCoordinate2D) {
    let toast = UIAlertController(title: "Area of park", message: (features.compactMap { ($0 as? DatasetFeature)?.datasetAttributes["acres"] }).joined(separator: ", "), preferredStyle: .alert)
    present(toast, animated: true, completion: nil)
  }
}

Objective-C


@interface SampleViewController: UIViewController <GMSMapViewDelegate>
@end

@implementation SampleViewController
- (void)loadView {
    GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero mapID:[GMSMapID mapIDWithIdentifier:@"YOUR_MAP_ID"] camera:[GMSCameraPosition cameraWithLatitude:40.7 longitude:-74 zoom:12]];
    mapView.delegete = self;

    // Set default styles.
    GMSFeatureStyle *style = [GMSFeatureStyle styleWithFillColor:[[UIColor greenColor] colorWithAlphaComponent:0.5] strokeColor:[UIColor greenColor] strokeWidth:2.0];
    [_mapView datasetFeatureLayerOfDatasetID:@"YOUR_DATASET_ID"].style = ^(GMSDatasetFeature *feature) { return style; };

    self.view = mapView;
}

- (void)mapView:(GMSMapView *)mapView didTapFeatures:(NSArray<id<GMSFeature>> *)features inFeatureLayer:(GMSFeatureLayer *)featureLayer atLocation:(CLLocationCoordinate2D)location {
  NSMutableArray<NSString *> *parkAreas = [NSMutableArray array];

  for (id<GMSFeature> feature in features) {
    if (![feature isKindOfClass:[GMSDatasetFeature class]]) { continue; }
    NSString *nameDefinedInDataset = ((GMSDatasetFeature *)feature).datasetAttributes[@"acres"];
    [parkAreas addObject:nameDefinedInDataset];
  }

  UIAlertController *toast = [UIAlertController alertControllerWithTitle:@"Area of park" message:[parkAreas componentsJoinedByString:@", "] preferredStyle:UIAlertControllerStyleAlert];
  [self presentViewController:toast animated:YES completion:nil];
}
@end