iOS के लिए Maps SDK का इस्तेमाल करके, मैप पर होने वाले इवेंट को सुना जा सकता है. जैसे, कैमरे में बदलाव करने या मार्कर पर टैप करने से होने वाले इवेंट.
परिचय
इवेंट सुनने के लिए, आपको GMSMapViewDelegate
प्रोटोकॉल लागू करना होगा. आम तौर पर, मैप दिखाने वाले व्यू कंट्रोलर पर यह प्रोटोकॉल लागू किया जाता है. इसका एक उदाहरण यहां दिया गया है:
Swift
import GoogleMaps class Events: UIViewController, GMSMapViewDelegate { // ... }
Objective-C
@import GoogleMaps; @interface Events : UIViewController <GMSMapViewDelegate> @end
GMSMapView
बनाने के बाद, उसके प्रतिनिधि को अपने व्यू कंट्रोलर पर सेट किया जा सकता है. GMSMapViewDelegate
सिर्फ़ वैकल्पिक तरीके उपलब्ध कराता है. किसी खास इवेंट को सुनने के लिए, आपको उससे जुड़ा तरीका लागू करना होगा.
Swift
override func loadView() { super.loadView() let camera = GMSCameraPosition.camera( withLatitude: 1.285, longitude: 103.848, zoom: 12 ) let mapView = GMSMapView.map(withFrame: .zero, camera: camera) mapView.delegate = self self.view = mapView } // MARK: GMSMapViewDelegate func mapView(_ mapView: GMSMapView, didTapAt coordinate: CLLocationCoordinate2D) { print("You tapped at \(coordinate.latitude), \(coordinate.longitude)") }
Objective-C
- (void)loadView { [super loadView]; GMSCameraPosition *camera = [GMSCameraPosition cameraWithLatitude:1.285 longitude:103.848 zoom:12]; GMSMapView *mapView = [GMSMapView mapWithFrame:CGRectZero camera:camera]; mapView.delegate = self; self.view = mapView; } #pragma mark - GMSMapViewDelegate - (void)mapView:(GMSMapView *)mapView didTapAtCoordinate:(CLLocationCoordinate2D)coordinate { NSLog(@"You tapped at %f,%f", coordinate.latitude, coordinate.longitude); }
कैमरे की पोज़िशन
GMSMapViewDelegate
का इस्तेमाल करके, मैप को रेंडर करने के लिए इस्तेमाल किए गए कैमरे की जगह में हुए बदलावों को सुना जा सकता है. तीन अलग-अलग इवेंट हैं.
mapView:willMove:
से पता चलता है कि कैमरे की पोज़िशन बदलने वाली है. अगरgesture
आर्ग्युमेंट कोYES
पर सेट किया गया है, तो इसका मतलब है कि उपयोगकर्ता नेGMSMapView
पर कोई सामान्य जेस्चर किया है. जैसे, पैन या झुकाना. अगर ऐसा नहीं है, तोNO
से पता चलता है कि यह प्रोग्राम के हिसाब से किए गए बदलाव का हिस्सा है. उदाहरण के लिए,animateToCameraPosition:
जैसे तरीकों से या मैप की लेयर को सीधे अपडेट करके. अगर उपयोगकर्ता ने 'मेरी जगह' या कंपास बटन पर टैप किया है, तो यहNO
भी हो सकता है. ये बटन ऐसे ऐनिमेशन जनरेट करते हैं जिनसे कैमरे की दिशा बदलती है.mapView:idleAtCameraPosition:
को शुरू करने से पहले, इस तरीके को कई बार कॉल किया जा सकता है. हालांकि, आम तौर पर ऐसा सिर्फ़ तब होता है, जब ऐनिमेशन और जेस्चर एक ही समय पर होते हैं. उदाहरण के लिए, कोई जेस्चर किसी मौजूदा ऐनिमेशन को रद्द कर देगा औरmapView:willMove:
को दूसरी बार कॉल करेगा.mapView:didChangeCameraPosition:
को जेस्चर या ऐनिमेशन के दौरान बार-बार कॉल किया जाता है. यह कॉल हमेशाmapView:willMove:
के कॉल के बाद किया जाता है. यह कैमरे की मध्य स्थिति से आगे बढ़ गया है.आखिर में,
GMSMapView
पर कैमरे की पोज़िशन के बंद होने पर,mapView:idleAtCameraPosition:
को ट्रिगर किया जाता है. साथ ही, कैमरे की सही पोज़िशन की जानकारी दी जाती है. इस दौरान, सभी ऐनिमेशन और जेस्चर बंद हो जाते हैं.ऐप्लिकेशन इस इवेंट का इस्तेमाल,
GMSMapView
पर दिख रहे मार्कर या अन्य कॉन्टेंट को रीफ़्रेश करने के लिए कर सकते हैं. उदाहरण के लिए, कैमरे में बदलाव होने पर कॉन्टेंट को फिर से लोड करने के बजाय.
उदाहरण के लिए, कोई ऐप्लिकेशन GMSMapView
को 'चलते समय' सेटिंग से हटा सकता है. इसके बाद, कैमरे के रुकने की जगह को रिवर्स जियोकोड कर सकता है.
Swift
let geocoder = GMSGeocoder() func mapView(_ mapView: GMSMapView, willMove gesture: Bool) { mapView.clear() } func mapView(_ mapView: GMSMapView, idleAt cameraPosition: GMSCameraPosition) { geocoder.reverseGeocodeCoordinate(cameraPosition.target) { (response, error) in guard error == nil else { return } if let result = response?.firstResult() { let marker = GMSMarker() marker.position = cameraPosition.target marker.title = result.lines?[0] marker.snippet = result.lines?[1] marker.map = mapView } } }
Objective-C
GMSGeocoder *geocoder; - (void)mapView:(GMSMapView *)mapView willMove:(BOOL)gesture { [mapView clear]; } - (void)mapView:(GMSMapView *)mapView idleAtCameraPosition:(GMSCameraPosition *)cameraPosition { id handler = ^(GMSReverseGeocodeResponse *response, NSError *error) { if (error != nil) { return; } GMSReverseGeocodeResult *result = response.firstResult; GMSMarker *marker = [GMSMarker markerWithPosition:cameraPosition.target]; marker.title = result.lines[0]; marker.snippet = result.lines[1]; marker.map = mapView; }; [geocoder reverseGeocodeCoordinate:cameraPosition.target completionHandler:handler]; }
कारोबारों और अन्य लोकप्रिय जगहों के इवेंट
डिफ़ॉल्ट रूप से, दिलचस्प जगहें (पीओआई) और उनके आइकॉन, बेस मैप पर दिखते हैं. लोकप्रिय जगहों में पार्क, स्कूल, सरकारी इमारतें वगैरह शामिल हैं. साथ ही, इनमें कारोबार से जुड़ी लोकप्रिय जगहें भी शामिल हैं, जैसे कि दुकानें, रेस्टोरेंट, और होटल.
किसी पॉइंट ऑफ़ इंटरेस्ट पर क्लिक इवेंट का जवाब दिया जा सकता है. कारोबारों और अन्य लोकप्रिय जगहों के लिए बनी गाइड देखें.
अन्य इवेंट
GMSMapViewDelegate
पर उपलब्ध तरीकों की पूरी सूची के बारे में जानने के लिए, रेफ़रंस गाइड देखें.