ऑटोकंप्लीट (नई) सेवा, एक iOS API है. किसी अनुरोध के प्रतिसाद में स्थान सुझाव देता है. अनुरोध में, यह तय करें कि टेक्स्ट की खोज स्ट्रिंग और भौगोलिक सीमाएं शामिल होती हैं, जो खोज क्षेत्र को कंट्रोल करती हैं.
ऑटोकंप्लीट (नई) सेवा, पूरी तरह से मैच कर सकती है इनपुट के शब्द और सबस्ट्रिंग, जगहों के नाम, पते वगैरह रिज़ॉल्व करने की सुविधा और प्लस कोड. इसलिए ऐप्लिकेशन उपयोगकर्ता के तौर पर क्वेरी भेज सकते हैं टाइप करते हैं, ताकि आप तुरंत जगह के सुझाव दे सकें.
जगह के सुझाव में जगहें होती हैं, जैसे कि कारोबार, पते, और जगहों के सुझाव रुचि, दिए गए इनपुट टेक्स्ट स्ट्रिंग और खोज क्षेत्र के आधार पर.
उदाहरण के लिए, आप एक ऐसी स्ट्रिंग को इनपुट के रूप में इस्तेमाल करके एपीआई को कॉल करते हैं, जिसमें उपयोगकर्ता का इनपुट, "स्पैग", जिसमें खोज क्षेत्र सिर्फ़ न्यूयॉर्क शहर तक सीमित है. इसके बाद, जवाब में जगहों के सुझाव की सूची शामिल होती है, जो खोज क्वेरी से मेल खाती है स्ट्रिंग और खोज क्षेत्र, जैसे "कैफ़े स्पैगेटी" नाम का रेस्टोरेंट, साथ ही, इस लिंक पर क्लिक करें.
जगह के बारे में सुझाव देकर, उपयोगकर्ता को इस तरह से डिज़ाइन किया गया है कि ताकि वे अपनी पसंद की जगह चुन सकें. आप एक जगह की जानकारी (नया)ज़्यादा पाने के लिए अनुरोध लौटाए गए किसी भी स्थान सुझाव के बारे में जानकारी.
ऑटोकंप्लीट की सुविधा (नए) अनुरोध
इस
GMSPlaceClient
.
पैरामीटर को इसमें पास किया जा सकता है:
GMSAutocompleteRequest
ऑब्जेक्ट है. इसके जवाब में,
GMSAutocompletePlaceSuggestion
ऑब्जेक्ट है.
एपीआई पासकोड और query
पैरामीटर ज़रूरी हैं. इन्हें भी शामिल किया जा सकता है
GMSAutocompleteSessionToken
अनुरोधों को बिलिंग सेशन से जोड़ने के लिए और
GMSAutocompleteFilter
लागू करने के लिए.
ज़रूरी और वैकल्पिक पैरामीटर के बारे में ज़्यादा जानकारी के लिए, इस दस्तावेज़ का पैरामीटर सेक्शन देखें.
Swift
let token = GMSAutocompleteSessionToken() let northWestBounds = CLLocationCoordinate2DMake(40.921628, -73.700051) let southEastBounds = CLLocationCoordinate2DMake(40.477398, -74.259087) let filter = GMSAutocompleteFilter() filter.types = [kGMSPlaceTypeRestaurant] filter.locationBias = GMSPlaceRectangularLocationOption(northWestBounds, southEastBounds) let request = GMSAutocompleteRequest(query:"Spagh") request.filter = filter request.sessionToken = token GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in if let error = error { print("Autocomplete error: \(error)") return } if let autocompleteResults = results { for result in autocompleteResults { print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))") } } })
Objective-C
CLLocationCoordinate2D northEast = CLLocationCoordinate2DMake(37.388162, -122.088137); CLLocationCoordinate2D southWest = CLLocationCoordinate2DMake(37.395804, -122.077023); GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.types = @[ kGMSPlaceTypeRestaurant ]; filter.locationBias = GMSPlaceRectangularLocationOption(northEast, southWest); GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"]; request.sessionToken = token; request.filter = filter; [[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){ // Handle response for (GMSAutocompleteSuggestion *suggestion in results) { if (suggestion.placeSuggestion) { // Show place suggestion data. } } }];
GooglePlacesSwift
let center = (37.3913916, -122.0879074) let northEast = (37.388162, -122.088137) let southWest = (37.395804, -122.077023) let bias = RectangularCoordinateRegion(northEast: northEast, southWest: southWest) let filter = AutocompleteFilter(types: [ .restaurant ], origin: center, coordinateRegionBias: bias) let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", filter: filter) switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) { case .success(let autocompleteSuggestions): // Handle suggestions. case .failure(let placesError): // Handle error. }
ऑटोकंप्लीट की सुविधा (नए) जवाब
ऑटोकंप्लीट की सुविधा से, ज़्यादा से ज़्यादा पांच वैल्यू का अरे मिल सकता है
GMSAutocompleteSuggestion
इंस्टेंस. कलेक्शन में ये शामिल हैं:
placeID
types
: इस जगह पर लागू होने वाले टाइप.distanceMeters
: मूल जगह से दूरी.attributedFullText
: किसी सुझाव का पूरा टेक्स्ट, जिसे कोई भी व्यक्ति आसानी से पढ़ सकता है.attributedPrimaryText
: किसी सुझाव का ऐसा मुख्य टेक्स्ट जिसे कोई भी व्यक्ति आसानी से पढ़ सकता है.attributedSecondaryText
: किसी सुझाव का ऐसा दूसरा टेक्स्ट जिसे कोई भी व्यक्ति आसानी से पढ़ सकता है.structuredFormat
: कोई खास नाम और साफ़ तौर पर जानकारी देने वाला टेक्स्ट, जैसे कि शहर या क्षेत्र.
ज़रूरी पैरामीटर
क्वेरी
वह टेक्स्ट स्ट्रिंग जिस पर खोजना है. पूरे शब्द और सबस्ट्रिंग की जानकारी दें, सही जगह पर नाम, पते, और प्लस कोड शामिल करें. कॉन्टेंट बनाने अपने-आप पूरा होने वाली (नई) सेवा, कैंडिडेट मैच नतीजे दिखाती है इस स्ट्रिंग और ऑर्डर के नतीजों के आधार पर तय किया जाता है कि वे कितने काम के हैं.
ज़रूरी नहीं पैरामीटर
प्रकार
किसी जगह का सिर्फ़ एक प्राइमरी टाइप टाइप टेबल में हो सकता है
A या टेबल
B प्रॉपर्टी से जुड़ा है.
उदाहरण के लिए, प्राइमरी टाइप mexican_restaurant
या steak_house
हो सकता है.
डिफ़ॉल्ट रूप से, एपीआई input
पैरामीटर के आधार पर सभी जगहों की जानकारी दिखाता है,
भले ही, जगह से जुड़ी मुख्य टाइप की वैल्यू कोई भी हो. नतीजों पर पाबंदी लगाएं
किसी विशेष प्रकार के प्राथमिक या प्राथमिक प्रकार के होने के लिए
types
पैरामीटर.
टेबल से ज़्यादा से ज़्यादा पांच टाइप वैल्यू तय करने के लिए, इस पैरामीटर का इस्तेमाल करें A या टेबल B. स्थान मेल खाना चाहिए जवाब में शामिल किए जाने वाले प्राथमिक टाइप की वैल्यू में से कोई एक.
अनुरोध को INVALID_REQUEST
गड़बड़ी के साथ अस्वीकार कर दिया जाता है, अगर:
- पाँच से ज़्यादा प्रकार बताए गए हैं.
- कोई भी अज्ञात प्रकार दर्ज किया गया है.
देश
सिर्फ़ तय किए गए क्षेत्रों की सूची के नतीजों को ही शामिल करें. इन्हें किसी अरे के तौर पर चुना गया है 15 ccTLD ("टॉप-लेवल डोमेन") दो वर्ण वाले मान. अगर यह जवाब नहीं दिया जाता है, तो जवाब पर कोई पाबंदी नहीं होगी. उदाहरण के लिए, जर्मनी और फ़्रांस तक के क्षेत्रों को सीमित करने के लिए:
Swift
let filter = GMSAutocompleteFilter() filter.countries = ["DE", "FR"]
Objective-C
GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.countries = @[ @"DE", @"FR" ];
GooglePlacesSwift
let filter = AutocompleteFilter(countries: ["DE", "FR"])
locationRestriction
और countries
, दोनों की जानकारी देने पर नतीजे
जो दो सेटिंग के प्रतिच्छेदन क्षेत्र में स्थित है.
inputOffset
शून्य-आधारित यूनिकोड वर्ण ऑफ़सेट, इसमें कर्सर की स्थिति दिखाता है
input
. कर्सर की जगह से यह तय होता है कि कौनसे सुझाव दिखाए जाएंगे. अगर आपने
खाली है, तो यह डिफ़ॉल्ट रूप से input
की लंबाई दिखाता है.
LocationBias या जगह की जानकारी पर पाबंदी
परिभाषित करने के लिए आप locationBias
या locationRestriction
को तय कर सकते हैं, लेकिन दोनों को नहीं
खोज क्षेत्र. locationRestriction
के बारे में सोचें कि वह क्षेत्र तय करता है
नतीजे इसके अंदर होने चाहिए और locationBias
होना चाहिए, जैसा कि उस क्षेत्र को तय करता है जिसमें
परिणाम क्षेत्र के पास होने चाहिए लेकिन उनसे बाहर भी हो सकते हैं.
locationBias
खोजे जाने वाले किसी क्षेत्र के बारे में बताता है. इस जगह की वजह से, इसका मतलब है कि बताई गई जगह के आस-पास के नतीजे दिखाए जा सकते हैं. इनमें ये भी शामिल हैं चुने गए क्षेत्र से बाहर के नतीजे.locationRestriction
खोजे जाने वाले किसी क्षेत्र के बारे में बताता है. इसके बाहर के नतीजे चुने गए हिस्से को लौटाया नहीं जाता है.
locationBias
या locationRestriction
इलाके को आयताकार के तौर पर बताएं
व्यूपोर्ट या सर्कल के तौर पर दिखता है.
सर्कल को सेंटर पॉइंट और मीटर में रेडियस से तय किया जाता है. दायरा ऐसा होना चाहिए
0.0 और 50000.0 के बीच. डिफ़ॉल्ट वैल्यू 0.0 है. इसके लिए
locationRestriction
, आपको दायरा 0.0 से ज़्यादा पर सेट करना होगा.
ऐसा न करने पर, अनुरोध कोई नतीजा नहीं दिखाता.
उदाहरण के लिए:
Swift
let center = CLLocationCoordinate2DMake(40.730610, -73.935242) let radius = 1000.0 filter.locationBias = GMSPlaceCircularLocationOption(center, radius)
Objective-C
CLLocationCoordinate2D center = CLLocationCoordinate2DMake(40.730610, -73.935242); radius = 1000.0; GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.locationBias = GMSPlaceCircularLocationOption(center, radius);
GooglePlacesSwift
let center = CLLocationCoordinate2DMake(40.477398, -74.259087) let bias = CircularCoordinateRegion(center: center, radius: 1000.0) let filter = AutocompleteFilter(coordinateRegionBias: bias)
आयत, अक्षांश-देशांतर का व्यूपोर्ट होता है, जिसे दो डायगनल तरीके से दिखाया जाता है
low
और high
बिंदुओं के विपरीत. व्यूपोर्ट को एक क्लोज़्ड क्षेत्र माना जाता है,
जिसका मतलब है उसकी सीमा शामिल है. अक्षांश की सीमा -90 से लेकर 90 तक के बीच होनी चाहिए
90 डिग्री शामिल है और देशांतर की सीमा -180 से 180 के बीच होनी चाहिए
डिग्री सहित:
- अगर
low
=high
है, तो व्यूपोर्ट में वह सिंगल पॉइंट होता है. - अगर
low.longitude
>high.longitude
, देशांतर की रेंज उलटी होती है ( व्यूपोर्ट, 180 डिग्री देशांतर लाइन को पार करता है). - अगर
low.longitude
= -180 डिग्री औरhigh.longitude
= 180 डिग्री है, तो व्यूपोर्ट में सभी देशांतर शामिल होते हैं. - अगर
low.longitude
= 180 डिग्री औरhigh.longitude
= -180 डिग्री है, तो देशांतर श्रेणी खाली है.
low
और high
, दोनों में जानकारी भरी जानी चाहिए. साथ ही, दिखाया गया बॉक्स नहीं होना चाहिए
खाली. व्यूपोर्ट का खाली होने पर गड़बड़ी होती है.
उदाहरण के लिए, यह व्यूपोर्ट न्यूयॉर्क शहर को पूरी तरह से घेरता है:
Swift
let high = CLLocationCoordinate2DMake(40.921628, -73.700051) let low = CLLocationCoordinate2DMake(40.477398, -74.259087) let filter = GMSAutocompleteFilter() filter.locationBias = GMSPlaceRectangularLocationOption(high, low)
Objective-C
CLLocationCoordinate2D high = CLLocationCoordinate2DMake(40.477398, -74.259087); CLLocationCoordinate2D low = CLLocationCoordinate2DMake(440.921628, -73.700051); GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.locationBias = GMSPlaceRectangularLocationOption(high, low);
GooglePlacesSwift
let northEast = CLLocationCoordinate2DMake(40.477398, -74.259087) let southWest = CLLocationCoordinate2DMake(40.921628, -73.700051) let filter = AutocompleteFilter(coordinateRegionBias: bias)
origin
वह मूल बिंदु जहां से सीधी रेखा की दूरी की गणना करनी है
गंतव्य (distanceMeters
के रूप में दिखाया गया). अगर यह वैल्यू शामिल नहीं की जाती है,
सीधी लाइन के बीच की दूरी का डेटा नहीं दिखाया जाएगा. अक्षांश और देशांतर के तौर पर दर्ज होने चाहिए
देशांतर निर्देशांक:
Swift
let filter = GMSAutocompleteFilter() filter.origin = CLLocation(latitude: 37.395804, longitude: -122.077023)
Objective-C
GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.origin = [[CLLocation alloc] initWithLatitude:37.395804 longitude: -122.077023];
GooglePlacesSwift
let filter = AutocompleteFilter(origin: CLLocation(latitude: 37.395804, longitude: -122.077023))
regionCode
रिस्पॉन्स को फ़ॉर्मैट करने के लिए इस्तेमाल किया जाने वाला क्षेत्रीय कोड, जिसे ccTLD ("टॉप-लेवल डोमेन") दो वर्ण वाला मान. ज़्यादातर ccTLD कोड, ISO 3166-1 कोड के समान होते हैं. साथ ही, कुछ अहम अपवाद. उदाहरण के लिए, यूनाइटेड किंगडम का ccTLD "uk" है (.co.uk) है, जबकि इसका ISO 3166-1 कोड "gb" है (तकनीकी तौर पर, " यूनाइटेड किंगडम ऑफ़ ग्रेट ब्रिटेन और नॉदर्न आयरलैंड").
किसी अमान्य क्षेत्र का कोड डालने पर, एपीआई INVALID_ARGUMENT
दिखाता है
गड़बड़ी. पैरामीटर, लागू कानून के आधार पर नतीजों पर असर डाल सकता है.
sessionToken
सेशन टोकन, उपयोगकर्ता की जनरेट की गई स्ट्रिंग होती हैं, जो ऑटोकंप्लीट (नया) में, "सेशन" कॉल किए जाते हैं. ऑटोकंप्लीट (नया वर्शन) में, सेशन टोकन का इस्तेमाल करके डिस्क्रीट सेशन में, उपयोगकर्ता के ऑटोकंप्लीट खोज की सुविधा के लिए क्वेरी और चुनने के चरण बिलिंग उद्देश्यों के लिए. ज़्यादा जानकारी के लिए, सेशन देखें टोकन हैं.
ऑटोकंप्लीट की सुविधा (नए) के उदाहरण
जगह की पाबंदी और locationBias का इस्तेमाल करें
ऑटोकंप्लीट (नया) डिफ़ॉल्ट रूप से, आईपी बायसिंग का इस्तेमाल
खोज वाली जगह को कंट्रोल कर सकती हैं. आईपी बायसिंग के साथ, एपीआई
किसी एक डिवाइस का इस्तेमाल कर रहे हैं. आपके पास locationRestriction
या फिर
locationBias
, लेकिन दोनों नहीं, पूरी जानकारी देने के लिए
खोजने के लिए कोई क्षेत्र.
जगह की जानकारी पर पाबंदी लगाने से पता चलता है कि किस इलाके को खोजा जाना है. बताए गए से बाहर के नतीजे क्षेत्र को लौटाया नहीं जाता है. नीचे दिए गए उदाहरण में, सीमित करने के लिए जगह की जानकारी पर पाबंदी का इस्तेमाल किया गया है 5,000 मीटर के दायरे को केंद्र में रखते हुए, सर्कुलर जगह की पाबंदी का अनुरोध सैन फ़्रांसिस्को में:
Swift
let token = GMSAutocompleteSessionToken() let center = CLLocationCoordinate2DMake(37.775061, -122.419400) let radius = 5000.0 let filter = GMSAutocompleteFilter() filter.locationRestriction = GMSPlaceCircularLocationOption(center, radius) let request = GMSAutocompleteRequest(query:"Piz") request.filter = filter request.sessionToken = token GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in if let error = error { print("Autocomplete error: \(error)") return } if let autocompleteResults = results { for result in autocompleteResults { print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))") } } })
Objective-C
CLLocationCoordinate2D center = CLLocationCoordinate2DMake(37.775061, -122.419400); radius = 5000.0; GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.locationRestriction = GMSPlaceCircularLocationOption(center, radius); GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"]; request.sessionToken = token; request.filter = filter; [[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArrayG<MSAutocompleteSuggestion * >* results, NSError * error){ // Handle response for (GMSAutocompleteSuggestion *suggestion in results) { if (suggestion.placeSuggestion) { // Show place suggestion data. } } }];
GooglePlacesSwift
let center = (37.775061, -122.419400) let radius = 5000.0 let restriction = CircularCoordinateRegion(center: center, radius: radius) let filter = AutocompleteFilter(coordinateRegionRestriction: restriction) let token = AutocompleteSessionToken() let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", sessionToken: token, filter: filter) switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) { case .success(let autocompleteSuggestions): for suggestion in autocompleteSuggestions { switch suggestion { case .place: // Show place suggestion data. } } case .failure(let placesError): // Handle error. }
स्थान पूर्वाग्रह के साथ, स्थान पूर्वाग्रह के रूप में कार्य करता है, जिसका अर्थ है कि आस-पास के परिणाम इस जगह को दिखाया जा सकता है. इसमें, तय की गई जगह से बाहर के नतीजे भी शामिल हैं क्षेत्र. अगले उदाहरण में, जगह की जानकारी के पूर्वाग्रह इस्तेमाल करने के पिछले अनुरोध को बदला गया है:
Swift
let token = GMSAutocompleteSessionToken() let center = CLLocationCoordinate2DMake(37.775061, -122.419400) let radius = 5000.0 let filter = GMSAutocompleteFilter() filter.locationBias = GMSPlaceCircularLocationOption(center, radius) let request = GMSAutocompleteRequest(query:"Piz") request.filter = filter request.sessionToken = token GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in if let error = error { print("Autocomplete error: \(error)") return } if let autocompleteResults = results { for result in autocompleteResults { print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))") } } })
Objective-C
CLLocationCoordinate2D center = CLLocationCoordinate2DMake(37.775061, -122.419400); radius = 5000.0; GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.locationBias = GMSPlaceCircularLocationOption(center, radius); GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"]; request.sessionToken = token; request.filter = filter; [[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){ // Handle response for (GMSAutocompleteSuggestion *suggestion in results) { if (suggestion.placeSuggestion) { // Show place suggestion data. } } }];
GooglePlacesSwift
let center = (37.775061, -122.419400) let radius = 5000.0 let bias = CircularCoordinateRegion(center: center, radius: radius) let filter = AutocompleteFilter(coordinateRegionBias: bias) let token = AutocompleteSessionToken() let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", sessionToken: token, filter: filter) switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) { case .success(let autocompleteSuggestions): for suggestion in autocompleteSuggestions { switch suggestion { case .place: // Show place suggestion data. } } case .failure(let placesError): // Handle error. }
इस्तेमाल के टाइप
किसी अनुरोध में मौजूद नतीजे को किसी खास टाइप के खोज नतीजों में दिखाने से रोकने के लिए, type पैरामीटर का इस्तेमाल करें प्रकार जैसा टेबल में दिया गया है A और टेबल B. आप में पांच वैल्यू तक की कैटगरी चुन सकते हैं. अगर इसे छोड़ दिया जाता है, तो सभी तरह के नतीजे दिखते हैं.
नीचे दिया गया उदाहरण "सॉकर" की क्वेरी स्ट्रिंग के बारे में बताता है और टाइप की गई गड़बड़ियों का इस्तेमाल करता है
संगठन के टाइप से जुड़े नतीजों पर पाबंदी लगाने के लिए पैरामीटर
"sporting_goods_store"
:
Swift
let token = GMSAutocompleteSessionToken() let filter = GMSAutocompleteFilter() filter.types = ["sporting_goods_store"] let request = GMSAutocompleteRequest(query:"Soccer") request.filter = filter request.sessionToken = token GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in if let error = error { print("Autocomplete error: \(error)") return } if let autocompleteResults = results { for result in autocompleteResults { print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))") } } })
Objective-C
GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.types = @[ "sporting_goods_store" ]; GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Soccer"]; request.sessionToken = token; request.filter = filter; [[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){ // Handle response for (GMSAutocompleteSuggestion *suggestion in results) { if (suggestion.placeSuggestion) { // Show place suggestion data. } } }];
GooglePlacesSwift
let filter = AutocompleteFilter(types: [ PlaceType(rawValue: "sporting_goods_store") ]) let token = AutocompleteSessionToken() let autocompleteRequest = AutocompleteRequest(query: "Soccer", sessionToken: token, filter: filter) switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) { case .success(let autocompleteSuggestions): for suggestion in autocompleteSuggestions { switch suggestion { case .place: // Show place suggestion data. } } case .failure(let placesError): // Handle error. }
ऑरिजिन का इस्तेमाल करें
अनुरोध में origin
पैरामीटर शामिल करने पर, इसकी जानकारी इस तरह दी जाएगी
अक्षांश और देशांतर निर्देशांक, एपीआई में सीधी लाइन की दूरी शामिल होती है
शुरुआत की जगह से डेस्टिनेशन तक. रिस्पॉन्स,
distanceMeters
जैसी दूरी.
यह उदाहरण मूल को सैन फ़्रांसिस्को के केंद्र पर सेट करता है:
Swift
let token = GMSAutocompleteSessionToken() let origin = CLLocation(latitude: 37.7749, longitude: -122.4194) let filter = GMSAutocompleteFilter() filter.origin = origin let request = GMSAutocompleteRequest(query:"Amoeba") request.filter = filter request.sessionToken = token GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in if let error = error { print("Autocomplete error: \(error)") return } if let autocompleteResults = results { for result in autocompleteResults { print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText)) and distance: \(String(describing: result.placeSuggestion?.distanceMeters))") } } })
Objective-C
GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init]; filter.origin = [[CLLocation alloc] initWithLatitude:37.395804 longitude:-122.077023]; GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Amoeba"]; request.sessionToken = token; request.filter = filter; [[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArrayG<MSAutocompleteSuggestion * >* results, NSError * error){ // Handle response for (GMSAutocompleteSuggestion *suggestion in results) { if (suggestion.placeSuggestion) { // Show place suggestion data. } } }];
GooglePlacesSwift
let filter = AutocompleteFilter(origin: CLLocation(latitude: 37.7749, longitude: -122.4194)) let token = AutocompleteSessionToken() let autocompleteRequest = AutocompleteRequest(query: "Amoeba", sessionToken: token, filter: filter) switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) { case .success(let autocompleteSuggestions): for suggestion in autocompleteSuggestions { switch suggestion { case .place: // Show place suggestion data. } } case .failure(let placesError): // Handle error. }
एट्रिब्यूशन
ऑटोकंप्लीट की सुविधा (नया) का इस्तेमाल एक मैप. अगर मैप को दिखाया जाता है, तो वह Google Maps होना चाहिए. जब डिसप्ले किया जाता है ऑटोकंप्लीट (नई) सेवा की मदद से मिलने वाले सुझाव मैप के बिना, आपको खोज के साथ इनलाइन दिखाया गया Google लोगो शामिल करना होगा फ़ील्ड/नतीजे. ज़्यादा जानकारी के लिए, Google लोगो दिखाना और एट्रिब्यूशन में बदल सकते हैं.