Android के लिए Places SDK में, ऑटोमैटिक भरने की सुविधा, उपयोगकर्ता की खोज क्वेरी के जवाब में जगहों के सुझाव दिखाती है. उपयोगकर्ता के टाइप करते ही, अपने-आप पूरी होने वाली टेक्स्ट की सुविधा, जगहों के सुझाव दिखाती है. जैसे, कारोबारों के नाम, पते, प्लस कोड, और दिलचस्प जगहों के नाम.
अपने ऐप्लिकेशन में ऑटोमैटिक भरने की सुविधा को इन तरीकों से जोड़ा जा सकता है:
- ऑटोकंप्लीट विजेट जोड़ें, ताकि डेवलपमेंट में लगने वाला समय बच सके और उपयोगकर्ताओं को एक जैसा अनुभव मिल सके.
- उपयोगकर्ताओं के हिसाब से अनुभव देने के लिए, जगह के सुझाव प्रोग्राम के हिसाब से पाएं.
अपने-आप पूरा होने वाला टेक्स्ट वाला विजेट जोड़ना
ऑटोकंप्लीट विजेट, खोज के लिए एक डायलॉग बॉक्स है. इसमें ऑटोकंप्लीट की सुविधा पहले से मौजूद होती है. जब कोई उपयोगकर्ता खोज के लिए शब्द डालता है, तो विजेट में जगहों की सूची दिखती है. जब उपयोगकर्ता कोई विकल्प चुनता है, तो एक Place
इंस्टेंस दिखाया जाता है. इसके बाद, आपका ऐप्लिकेशन चुनी गई जगह की जानकारी पाने के लिए इसका इस्तेमाल कर सकता है.
अपने ऐप्लिकेशन में ऑटोमैटिक भरने की सुविधा वाला विजेट जोड़ने के लिए, आपके पास दो विकल्प हैं:
- पहला विकल्प:
AutocompleteSupportFragment
एम्बेड करना. - दूसरा विकल्प: अपने-आप भरने की सुविधा वाली गतिविधि को लॉन्च करने के लिए, इंटेंट का इस्तेमाल करना.
पहला विकल्प: AutocompleteSupportFragment को एम्बेड करना
अपने ऐप्लिकेशन में AutocompleteSupportFragment
जोड़ने के लिए, यह तरीका अपनाएं:
- अपनी गतिविधि के एक्सएमएल लेआउट में फ़्रैगमेंट जोड़ें.
- अपनी गतिविधि या फ़्रैगमेंट में, किसी लिसनर को जोड़ें.
किसी गतिविधि में AutocompleteSupportFragment जोड़ना
किसी गतिविधि में AutocompleteSupportFragment
जोड़ने के लिए, एक्सएमएल लेआउट में नया फ़्रैगमेंट जोड़ें. उदाहरण के लिए:
<fragment android:id="@+id/autocomplete_fragment"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:name="com.google.android.libraries.places.widget.AutocompleteSupportFragment"
/>
- डिफ़ॉल्ट रूप से, फ़्रैगमेंट में कोई बॉर्डर या बैकग्राउंड नहीं होता. एक जैसा विज़ुअल दिखाने के लिए, फ़्रैगमेंट को किसी दूसरे लेआउट एलिमेंट में नेस्ट करें. जैसे, CardView.
- अगर ऑटोकंप्लीट फ़्रैगमेंट का इस्तेमाल किया जा रहा है और आपको
onActivityResult
को बदलना है, तो आपकोsuper.onActivityResult
को कॉल करना होगा. ऐसा न करने पर, फ़्रैगमेंट ठीक से काम नहीं करेगा.
किसी गतिविधि में PlaceSelectionListener जोड़ना
PlaceSelectionListener
, उपयोगकर्ता की चुनी गई जगह की जानकारी दिखाता है. यहां दिए गए कोड में, फ़्रैगमेंट का रेफ़रंस बनाने और अपने AutocompleteSupportFragment
में एक लिसनर जोड़ने का तरीका बताया गया है:
Kotlin
// Initialize the AutocompleteSupportFragment. val autocompleteFragment = supportFragmentManager.findFragmentById(R.id.autocomplete_fragment) as AutocompleteSupportFragment // Specify the types of place data to return. autocompleteFragment.setPlaceFields(listOf(Place.Field.ID, Place.Field.NAME)) // Set up a PlaceSelectionListener to handle the response. autocompleteFragment.setOnPlaceSelectedListener(object : PlaceSelectionListener { override fun onPlaceSelected(place: Place) { // TODO: Get info about the selected place. Log.i(TAG, "Place: ${place.name}, ${place.id}") } override fun onError(status: Status) { // TODO: Handle the error. Log.i(TAG, "An error occurred: $status") } })
Java
// Initialize the AutocompleteSupportFragment. AutocompleteSupportFragment autocompleteFragment = (AutocompleteSupportFragment) getSupportFragmentManager().findFragmentById(R.id.autocomplete_fragment); // Specify the types of place data to return. autocompleteFragment.setPlaceFields(Arrays.asList(Place.Field.ID, Place.Field.NAME)); // Set up a PlaceSelectionListener to handle the response. autocompleteFragment.setOnPlaceSelectedListener(new PlaceSelectionListener() { @Override public void onPlaceSelected(@NonNull Place place) { // TODO: Get info about the selected place. Log.i(TAG, "Place: " + place.getName() + ", " + place.getId()); } @Override public void onError(@NonNull Status status) { // TODO: Handle the error. Log.i(TAG, "An error occurred: " + status); } });
दूसरा विकल्प: अपने-आप पूरा होने की सुविधा वाली गतिविधि को लॉन्च करने के लिए, इंटेंट का इस्तेमाल करना
अगर आपको अपने ऐप्लिकेशन में किसी दूसरे नेविगेशन फ़्लो का इस्तेमाल करना है, तो आपका ऐप्लिकेशन किसी इंटेंट का इस्तेमाल करके, ऑटोमैटिक भरने की सुविधा को लॉन्च कर सकता है. उदाहरण के लिए, खोज फ़ील्ड के बजाय किसी आइकॉन से ऑटोमैटिक भरने की सुविधा को ट्रिगर करना.
इंटेंट का इस्तेमाल करके, अपने-आप पूरा होने वाला व्यूज़ेट लॉन्च करने के लिए, यह तरीका अपनाएं:
- अपनी पसंद का
Autocomplete
मोड पास करके, इंटेंट बनाने के लिएAutocomplete.IntentBuilder
का इस्तेमाल करें. - गतिविधि के नतीजे लॉन्चर
registerForActivityResult
को तय करें. इसका इस्तेमाल, इंटेंट को लॉन्च करने और नतीजे में उपयोगकर्ता की चुनी गई जगह के अनुमान को मैनेज करने के लिए किया जा सकता है.
अपने-आप पूरा होने वाला इंटेंट बनाना
नीचे दिए गए उदाहरण में, ऑटोमैटिक भरने की सुविधा वाले विजेट को इंटेंट के तौर पर लॉन्च करने के लिए, Autocomplete.IntentBuilder
का इस्तेमाल किया गया है:
Kotlin
// Set the fields to specify which types of place data to // return after the user has made a selection. val fields = listOf(Place.Field.ID, Place.Field.NAME) // Start the autocomplete intent. val intent = Autocomplete.IntentBuilder(AutocompleteActivityMode.FULLSCREEN, fields) .build(this) startAutocomplete.launch(intent)
Java
// Set the fields to specify which types of place data to // return after the user has made a selection. List<Place.Field> fields = Arrays.asList(Place.Field.ID, Place.Field.NAME); // Start the autocomplete intent. Intent intent = new Autocomplete.IntentBuilder(AutocompleteActivityMode.FULLSCREEN, fields) .build(this); startAutocomplete.launch(intent);
अपने-आप पूरा होने वाला व्यूज़ेट लॉन्च करने के लिए इंटेंट का इस्तेमाल करते समय, ओवरले या फ़ुल-स्क्रीन डिसप्ले मोड में से किसी एक को चुना जा सकता है. नीचे दिए गए स्क्रीनशॉट में, हर डिसप्ले मोड को अलग-अलग दिखाया गया है:
इंटेंट के नतीजे के लिए कॉलबैक रजिस्टर करना
जब उपयोगकर्ता कोई जगह चुनता है, तब सूचना पाने के लिए, registerForActivityResult()
लॉन्चर तय करें. यह लॉन्चर, गतिविधि को लॉन्च करता है और नतीजे को मैनेज भी करता है. इसकी जानकारी, यहां दिए गए उदाहरण में दी गई है. अगर उपयोगकर्ता ने कोई अनुमान चुना है, तो उसे नतीजे के ऑब्जेक्ट में मौजूद इंटेंट में डिलीवर किया जाएगा. इंटेंट को Autocomplete.IntentBuilder
ने बनाया है, इसलिए Autocomplete.getPlaceFromIntent()
तरीका उससे जगह का ऑब्जेक्ट निकाल सकता है.
Kotlin
private val startAutocomplete = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { result: ActivityResult -> if (result.resultCode == Activity.RESULT_OK) { val intent = result.data if (intent != null) { val place = Autocomplete.getPlaceFromIntent(intent) Log.i( TAG, "Place: ${place.name}, ${place.id}" ) } } else if (result.resultCode == Activity.RESULT_CANCELED) { // The user canceled the operation. Log.i(TAG, "User canceled autocomplete") } }
Java
private final ActivityResultLauncher<Intent> startAutocomplete = registerForActivityResult( new ActivityResultContracts.StartActivityForResult(), result -> { if (result.getResultCode() == Activity.RESULT_OK) { Intent intent = result.getData(); if (intent != null) { Place place = Autocomplete.getPlaceFromIntent(intent); Log.i(TAG, "Place: ${place.getName()}, ${place.getId()}"); } } else if (result.getResultCode() == Activity.RESULT_CANCELED) { // The user canceled the operation. Log.i(TAG, "User canceled autocomplete"); } });
प्रोग्राम के हिसाब से जगहों के सुझाव पाना
ऑटोमैटिक भरने की सुविधा वाले विजेट से मिलने वाले यूज़र इंटरफ़ेस (यूआई) के बजाय, अपनी पसंद के मुताबिक खोज यूज़र इंटरफ़ेस (यूआई) बनाया जा सकता है. ऐसा करने के लिए, आपके ऐप्लिकेशन को जगह की जानकारी के अनुमान, प्रोग्राम के हिसाब से चाहिए. आपका ऐप्लिकेशन, ऑटोमैटिक भरने की सुविधा वाले एपीआई से, जगह के नाम और/या पतों की सूची पा सकता है. इसके लिए, उसे PlacesClient.findAutocompletePredictions()
को कॉल करना होगा. साथ ही, इन पैरामीटर के साथ FindAutocompletePredictionsRequest
ऑब्जेक्ट को पास करना होगा:
- ज़रूरी है:
query
स्ट्रिंग, जिसमें उपयोगकर्ता ने जो टेक्स्ट टाइप किया है वह शामिल हो. - सुझाया गया:
AutocompleteSessionToken
, जो बिलिंग के मकसद से, उपयोगकर्ता की खोज के क्वेरी और चुनने के चरणों को अलग-अलग सेशन में ग्रुप करता है. सेशन तब शुरू होता है, जब उपयोगकर्ता कोई क्वेरी टाइप करना शुरू करता है और तब खत्म होता है, जब वह कोई जगह चुनता है. - इसका सुझाव दिया जाता है: यह एक
RectangularBounds
ऑब्जेक्ट है, जो अक्षांश और देशांतर की सीमाओं की जानकारी देता है. इससे नतीजों को तय किए गए इलाके तक सीमित किया जा सकता है. - ज़रूरी नहीं: एक या एक से ज़्यादा दो अक्षरों वाले देश के कोड (ISO 3166-1 अल्फ़ा-2), जिनसे पता चलता है कि किन देशों के लिए नतीजों पर पाबंदी लगानी है.
ज़रूरी नहीं:
TypeFilter
, जिसका इस्तेमाल करके नतीजों को किसी खास जगह के टाइप तक सीमित किया जा सकता है. इन तरह की जगहों के लिए,TypeFilter.GEOCODE
– कारोबारों के बजाय, सिर्फ़ जगह की जानकारी देने वाले नतीजे दिखाता है. इस अनुरोध का इस्तेमाल करके, उन नतीजों में अंतर करें जिनमें बताई गई जगह की जानकारी अस्पष्ट हो सकती है.TypeFilter.ADDRESS
– सटीक पते के साथ, ऑटोमैटिक भरने की सुविधा से मिलने वाले नतीजे दिखाता है. इस टाइप का इस्तेमाल तब करें, जब आपको पता हो कि उपयोगकर्ता पूरी तरह से जानकारी वाला पता खोज रहा है.TypeFilter.ESTABLISHMENT
– सिर्फ़ कारोबार वाली जगहें दिखाता है.TypeFilter.REGIONS
– सिर्फ़ ऐसी जगहें दिखाता है जो इनमें से किसी एक टाइप से मैच करती हैं:LOCALITY
SUBLOCALITY
POSTAL_CODE
COUNTRY
ADMINISTRATIVE_AREA_LEVEL_1
ADMINISTRATIVE_AREA_LEVEL_2
TypeFilter.CITIES
– सिर्फ़LOCALITY
याADMINISTRATIVE_AREA_LEVEL_3
से मैच होने वाले नतीजे दिखाता है.
ज़रूरी नहीं: अनुरोध के लिए ऑरिजिन की जगह की जानकारी देने वाला
LatLng
.setOrigin()
को कॉल करने पर, सेवा जवाब में ऑटोमैटिक भरने की सुविधा से मिलने वाले हर अनुमान के लिए, तय किए गए ऑरिजिन से दूरी मीटर (distanceMeters
) में दिखाती है.
जगह के टाइप के बारे में जानकारी के लिए, जगह के टाइप की गाइड देखें.
यहां दिए गए उदाहरण में, PlacesClient.findAutocompletePredictions()
पर जाने के लिए पूरा कॉल दिखाया गया है.
Kotlin
// Create a new token for the autocomplete session. Pass this to FindAutocompletePredictionsRequest, // and once again when the user makes a selection (for example when calling fetchPlace()). val token = AutocompleteSessionToken.newInstance() // Create a RectangularBounds object. val bounds = RectangularBounds.newInstance( LatLng(-33.880490, 151.184363), LatLng(-33.858754, 151.229596) ) // Use the builder to create a FindAutocompletePredictionsRequest. val request = FindAutocompletePredictionsRequest.builder() // Call either setLocationBias() OR setLocationRestriction(). .setLocationBias(bounds) //.setLocationRestriction(bounds) .setOrigin(LatLng(-33.8749937, 151.2041382)) .setCountries("AU", "NZ") .setTypesFilter(listOf(PlaceTypes.ADDRESS)) .setSessionToken(token) .setQuery(query) .build() placesClient.findAutocompletePredictions(request) .addOnSuccessListener { response: FindAutocompletePredictionsResponse -> for (prediction in response.autocompletePredictions) { Log.i(TAG, prediction.placeId) Log.i(TAG, prediction.getPrimaryText(null).toString()) } }.addOnFailureListener { exception: Exception? -> if (exception is ApiException) { Log.e(TAG, "Place not found: ${exception.statusCode}") } }
Java
// Create a new token for the autocomplete session. Pass this to FindAutocompletePredictionsRequest, // and once again when the user makes a selection (for example when calling fetchPlace()). AutocompleteSessionToken token = AutocompleteSessionToken.newInstance(); // Create a RectangularBounds object. RectangularBounds bounds = RectangularBounds.newInstance( new LatLng(-33.880490, 151.184363), new LatLng(-33.858754, 151.229596)); // Use the builder to create a FindAutocompletePredictionsRequest. FindAutocompletePredictionsRequest request = FindAutocompletePredictionsRequest.builder() // Call either setLocationBias() OR setLocationRestriction(). .setLocationBias(bounds) //.setLocationRestriction(bounds) .setOrigin(new LatLng(-33.8749937, 151.2041382)) .setCountries("AU", "NZ") .setTypesFilter(Arrays.asList(PlaceTypes.ADDRESS)) .setSessionToken(token) .setQuery(query) .build(); placesClient.findAutocompletePredictions(request).addOnSuccessListener((response) -> { for (AutocompletePrediction prediction : response.getAutocompletePredictions()) { Log.i(TAG, prediction.getPlaceId()); Log.i(TAG, prediction.getPrimaryText(null).toString()); } }).addOnFailureListener((exception) -> { if (exception instanceof ApiException) { ApiException apiException = (ApiException) exception; Log.e(TAG, "Place not found: " + apiException.getStatusCode()); } });
एपीआई,
Task
में एक FindAutocompletePredictionsResponse
दिखाता है. FindAutocompletePredictionsResponse
में, उन जगहों की सूची होती है जिनके बारे में अनुमान लगाया गया है. ये जगहें, AutocompletePrediction
ऑब्जेक्ट से दिखाई जाती हैं. अगर क्वेरी और फ़िल्टर की शर्तों से मेल खाने वाली कोई जगह नहीं है, तो हो सकता है कि सूची खाली हो.
अनुमानित जगह की जानकारी पाने के लिए, इन तरीकों का इस्तेमाल किया जा सकता है:
getFullText(CharacterStyle)
जगह की जानकारी का पूरा टेक्स्ट दिखाता है. यह प्राइमरी और सेकंडरी टेक्स्ट का कॉम्बिनेशन है. उदाहरण: "Eiffel Tower, Avenue Anatole France, Paris, France". इसके अलावा, इस तरीके से खोज के हिसाब से मैच होने वाले ब्यौरे के सेक्शन को हाइलाइट किया जा सकता है. इसके लिए,CharacterStyle
का इस्तेमाल करके अपनी पसंद की स्टाइल चुनें.CharacterStyle
पैरामीटर का इस्तेमाल करना ज़रूरी नहीं है. अगर आपको किसी भी वैल्यू को हाइलाइट करने की ज़रूरत नहीं है, तो इसे शून्य पर सेट करें.getPrimaryText(CharacterStyle)
किसी जगह के बारे में बताने वाला मुख्य टेक्स्ट दिखाता है. आम तौर पर, यह जगह का नाम होता है. उदाहरण: "ईफ़ेल टावर" और "123 पिट स्ट्रीट".getSecondaryText(CharacterStyle)
जगह की जानकारी का सहायक टेक्स्ट दिखाता है. उदाहरण के लिए, ऑटोमैटिक भरने की सुविधा के सुझाव दिखाते समय, यह दूसरी लाइन के तौर पर मददगार होती है. उदाहरण: "Avenue Anatole France, Paris, France" और "Sydney, New South Wales".getPlaceId()
जगह का अनुमान लगाने के लिए इस्तेमाल की गई जगह का आईडी दिखाता है. प्लेस आईडी, टेक्स्ट वाला ऐसा आइडेंटिफ़ायर होता है जिससे किसी जगह की खास पहचान की जा सकती है. इसका इस्तेमाल, बाद मेंPlace
ऑब्जेक्ट को फिर से पाने के लिए किया जा सकता है. Android के लिए Places SDK टूल में जगह के आईडी के बारे में ज़्यादा जानने के लिए, जगह की जानकारी देखें. प्लेस आईडी के बारे में सामान्य जानकारी पाने के लिए, प्लेस आईडी की खास जानकारी देखें.getPlaceTypes()
इससे, इस जगह से जुड़े प्लेस टाइप की सूची मिलती है.getDistanceMeters()
, इस जगह और अनुरोध में बताई गई जगह के बीच की सीधी दूरी को मीटर में दिखाता है.
सेशन टोकन
सेशन टोकन, उपयोगकर्ता की ऑटोमैटिक तरीके से पूरी होने वाली खोज की क्वेरी और चुनने के चरणों को बिलिंग के मकसद से अलग सेशन में ग्रुप करते हैं. जब उपयोगकर्ता कोई क्वेरी टाइप करना शुरू करता है, तब सेशन शुरू होता है और कोई जगह चुनने पर खत्म होता है. हर सेशन में कई क्वेरी हो सकती हैं. इसके बाद, एक जगह चुनी जा सकती है. किसी सेशन के खत्म होने के बाद, टोकन अमान्य हो जाता है. इसलिए, आपके ऐप्लिकेशन को हर सेशन के लिए नया टोकन जनरेट करना होगा. हमारा सुझाव है कि आप प्रोग्राम के हिसाब से ऑटोमैटिक भरने की सुविधा वाले सभी सेशन के लिए सेशन टोकन का इस्तेमाल करें. जब किसी फ़्रैगमेंट को एम्बेड किया जाता है या किसी इंटेंट का इस्तेमाल करके ऑटोमैटिक भरने की सुविधा को लॉन्च किया जाता है, तो एपीआई अपने-आप इसकी देखभाल करता है.
Android के लिए Places SDK टूल, हर सेशन की पहचान करने के लिए AutocompleteSessionToken
का इस्तेमाल करता है. आपके ऐप्लिकेशन को हर नए सेशन की शुरुआत में, नया सेशन टोकन पास करना चाहिए. इसके बाद, उपयोगकर्ता की चुनी गई जगह की जानकारी पाने के लिए, fetchPlace()
को कॉल करते समय, उसी टोकन को प्लेस आईडी के साथ पास करना चाहिए.
सेशन टोकन के बारे में ज़्यादा जानें.
ऑटोकंप्लीट की मदद से दिखने वाले नतीजों को सीमित करना
अपने-आप पूरी होने वाले सुझावों के नतीजों को किसी खास भौगोलिक इलाके तक सीमित किया जा सकता है. इसके अलावा, और/या नतीजों को एक या उससे ज़्यादा जगहों के टाइप या ज़्यादा से ज़्यादा पांच देशों के हिसाब से फ़िल्टर किया जा सकता है. इन पाबंदियों को ऑटोमैटिक भरने की सुविधा वाली गतिविधि,
AutocompleteSupportFragment
, और प्रोग्राम के हिसाब से ऑटोमैटिक भरने की सुविधा देने वाले एपीआई पर लागू किया जा सकता है.
नतीजों को सीमित करने के लिए, यह तरीका अपनाएं:
- तय किए गए इलाके के नतीजों को प्राथमिकता देने के लिए,
setLocationBias()
को कॉल करें. हालांकि, ऐसा हो सकता है कि तय किए गए इलाके से बाहर के कुछ नतीजे भी दिखाए जाएं. - तय किए गए इलाके में सिर्फ़ नतीजे दिखाने के लिए,
setLocationRestriction()
को कॉल करें. ऐसा करने पर, सिर्फ़ तय किए गए इलाके के नतीजे दिखाए जाएंगे. - सिर्फ़ किसी खास जगह के हिसाब से नतीजे दिखाने के लिए,
setTypesFilter()
को कॉल करें. उदाहरण के लिए,TypeFilter.ADDRESS
का इस्तेमाल करने पर, सिर्फ़ सटीक पते वाले नतीजे दिखाए जाएंगे. - सिर्फ़ पांच देशों के नतीजे दिखाने के लिए,
setCountries()
को कॉल करें. देशों के नाम, दो वर्णों वाले ISO 3166-1 अल्फ़ा-2 के मुताबिक देश कोड के तौर पर होने चाहिए.
किसी खास इलाके के हिसाब से नतीजे दिखाना
अपने-आप पूरा होने वाले सुझावों को किसी खास इलाके के हिसाब से पाने के लिए, setLocationBias()
को कॉल करें और RectangularBounds
को पास करें.
यहां दिए गए कोड के उदाहरण में, ऑस्ट्रेलिया के सिडनी इलाके के लिए ऑटोकंप्लीट के सुझावों को प्राथमिकता देने के लिए, फ़्रैगमेंट के इंस्टेंस पर setLocationBias()
को कॉल किया गया है.
Kotlin
autocompleteFragment.setLocationBias( RectangularBounds.newInstance( LatLng(-33.880490, 151.184363), LatLng(-33.858754, 151.229596) ) )
Java
autocompleteFragment.setLocationBias(RectangularBounds.newInstance( new LatLng(-33.880490, 151.184363), new LatLng(-33.858754, 151.229596)));
नतीजों को किसी खास इलाके तक सीमित करना
ऑटोमैटिक भरने की सुविधा के नतीजों को किसी खास इलाके तक सीमित करने के लिए, setLocationRestriction()
को कॉल करें और RectangularBounds
पास करें.
यहां दिए गए कोड के उदाहरण में, ऑस्ट्रेलिया के सिडनी इलाके के लिए ऑटोकंप्लीट के सुझावों को प्राथमिकता देने के लिए, फ़्रैगमेंट इंस्टेंस पर setLocationRestriction()
को कॉल किया गया है.
Kotlin
autocompleteFragment.setLocationRestriction( RectangularBounds.newInstance( LatLng(-33.880490, 151.184363), LatLng(-33.858754, 151.229596) ) )
Java
autocompleteFragment.setLocationRestriction(RectangularBounds.newInstance( new LatLng(-33.880490, 151.184363), new LatLng(-33.858754, 151.229596)));
ध्यान दें: यह पाबंदी सिर्फ़ पूरे रास्तों पर लागू होती है. रेक्टैंगल के दायरे से बाहर मौजूद सिंथेटिक नतीजे, उस रास्ते के आधार पर दिखाए जा सकते हैं जो जगह की जानकारी पर लगी पाबंदी से ओवरलैप होता है.
जगह के टाइप या टाइप के हिसाब से नतीजे फ़िल्टर करना
अपने-आप पूरा होने वाले टेक्स्ट के अनुरोध से मिलने वाले नतीजों पर पाबंदी लगाई जा सकती है, ताकि वे सिर्फ़ किसी खास तरह की जगह के नतीजे दिखाएं. जगह के टाइप पर मौजूद टेबल 1, 2, और 3 में दी गई जगह के टाइप या टाइप के कलेक्शन का इस्तेमाल करके, कोई फ़िल्टर तय करें. अगर कुछ नहीं बताया गया है, तो सभी टाइप दिखाए जाते हैं.
अपने-आप पूरा होने वाले शब्दों के नतीजों को फ़िल्टर करने के लिए, फ़िल्टर सेट करने के लिए setTypesFilter()
को कॉल करें.
किसी टाइप या टाइप कलेक्शन फ़िल्टर को तय करने के लिए:
setTypesFilter()
को कॉल करें और जगह के टाइप पर दिखाई गई टेबल 1 और टेबल 2 में से, ज़्यादा से ज़्यादा पांच टाइप वैल्यू दें. टाइप की वैल्यू, PlaceTypes में मौजूद कॉन्स्टेंट से तय होती हैं.setTypesFilter()
को कॉल करें और जगह के टाइप पर दिखाई गई टेबल 3 से टाइप कलेक्शन तय करें. कलेक्शन की वैल्यू, PlaceTypes में मौजूद स्थिर वैल्यू से तय होती हैं.अनुरोध में, टेबल 3 में दिए गए सिर्फ़ एक टाइप की अनुमति है. अगर आपने टेबल 3 से कोई वैल्यू दी है, तो टेबल 1 या टेबल 2 से कोई वैल्यू नहीं दी जा सकती. ऐसा करने पर, गड़बड़ी का मैसेज दिखता है.
यहां दिए गए कोड के उदाहरण में, AutocompleteSupportFragment
पर setTypesFilter()
को कॉल किया गया है और कई तरह की वैल्यू तय की गई हैं.
Kotlin
autocompleteFragment.setTypesFilter(listOf("landmark", "restaurant", "store"))
Java
autocompleteFragment.setTypesFilter(Arrays.asList("landmark", "restaurant", "store"));
नीचे दिए गए कोड के उदाहरण में, AutocompleteSupportFragment
पर setTypesFilter()
को कॉल करके, एक फ़िल्टर सेट करने का तरीका बताया गया है. यह फ़िल्टर, टाइप कलेक्शन की जानकारी देकर, सिर्फ़ सटीक पते वाले नतीजे दिखाता है.
Kotlin
autocompleteFragment.setTypesFilter(listOf(PlaceTypes.ADDRESS))
Java
autocompleteFragment.setTypesFilter(Arrays.asList(PlaceTypes.ADDRESS, PlaceTypes.ESTABLISHMENT));
नीचे दिए गए कोड के उदाहरण में, IntentBuilder
पर setTypesFilter()
को कॉल करके, एक फ़िल्टर सेट करने का तरीका बताया गया है. यह फ़िल्टर, किसी टाइप के कलेक्शन की जानकारी देकर, सिर्फ़ सटीक पते वाले नतीजे दिखाता है.
Kotlin
val intent = Autocomplete.IntentBuilder(AutocompleteActivityMode.FULLSCREEN, fields) .setTypesFilter(listOf(PlaceTypes.ADDRESS)) .build(this)
Java
Intent intent = new Autocomplete.IntentBuilder( AutocompleteActivityMode.FULLSCREEN, fields) .setTypesFilter(Arrays.asList(PlaceTypes.ADDRESS)) .build(this);
देश के हिसाब से नतीजे फ़िल्टर करना
अपने-आप पूरा होने वाले नतीजों को ज़्यादा से ज़्यादा पांच देशों के हिसाब से फ़िल्टर करने के लिए, देश का कोड सेट करने के लिए setCountries()
कोड डालें.
इसके बाद, फ़िल्टर को किसी फ़्रैगमेंट या इंटेंट में पास करें. देशों के नाम, दो वर्णों वाले देश कोड के तौर पर डाले जाने चाहिए. यह कोड, ISO 3166-1 Alpha-2 के मुताबिक होना चाहिए.
नीचे दिए गए कोड के उदाहरण में, AutocompleteSupportFragment
पर setCountries()
को कॉल करने का तरीका बताया गया है. इससे, सिर्फ़ तय किए गए देशों के नतीजे दिखाने वाला फ़िल्टर सेट किया जा सकता है.
Kotlin
autocompleteFragment.setCountries("AU", "NZ")
Java
autocompleteFragment.setCountries("AU", "NZ");
इस्तेमाल करने की सीमा
अब Places API का इस्तेमाल, हर दिन किए जाने वाले अनुरोधों की तय सीमा (क्यूपीडी) तक सीमित नहीं है. इसमें Android के लिए Places SDK टूल भी शामिल है. हालांकि, इस्तेमाल से जुड़ी ये सीमाएं अब भी लागू रहेंगी:
- रेट लिमिट 6,000 क्यूपीएम (हर मिनट में अनुरोध) है. इसकी गिनती, एक ही प्रोजेक्ट के क्रेडेंशियल का इस्तेमाल करने वाले सभी ऐप्लिकेशन के लिए, क्लाइंट-साइड और सर्वर-साइड अनुरोधों के योग के तौर पर की जाती है.
अपने ऐप्लिकेशन में एट्रिब्यूशन दिखाना
- अगर आपका ऐप्लिकेशन, प्रोग्राम के हिसाब से अपने-आप जानकारी भरने की सुविधा का इस्तेमाल करता है, तो आपके यूज़र इंटरफ़ेस पर 'Google की मदद से' एट्रिब्यूशन दिखना चाहिए या वह Google के ब्रैंड वाले मैप में दिखना चाहिए.
- अगर आपका ऐप्लिकेशन अपने-आप पूरा होने वाले टेक्स्ट वाले विजेट का इस्तेमाल करता है, तो आपको कुछ करने की ज़रूरत नहीं है. ज़रूरी एट्रिब्यूशन डिफ़ॉल्ट रूप से दिखता है.
- अगर आईडी से जगह की जानकारी पाने के बाद, जगह की ज़्यादा जानकारी हासिल की जाती है और उसे दिखाया जाता है, तो आपको तीसरे पक्ष के एट्रिब्यूशन भी दिखाने होंगे.
ज़्यादा जानकारी के लिए, एट्रिब्यूशन के बारे में दस्तावेज़ देखें.
जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा को ऑप्टिमाइज़ करना
इस सेक्शन में, जगह की जानकारी अपने-आप पूरी होने की सुविधा का ज़्यादा से ज़्यादा फ़ायदा पाने के लिए, सबसे सही तरीकों के बारे में बताया गया है.
यहां कुछ सामान्य दिशा-निर्देश दिए गए हैं:
- काम करने वाला यूज़र इंटरफ़ेस बनाने का सबसे तेज़ तरीका यह है कि आप Maps JavaScript API के ऑटोकंप्लीट विजेट, Android के लिए Places SDK टूल के ऑटोकंप्लीट विजेट या iOS के लिए Places SDK टूल के ऑटोकंप्लीट यूज़र इंटरफ़ेस कंट्रोल का इस्तेमाल करें
- जगह की जानकारी अपने-आप भरने की सुविधा के लिए ज़रूरी डेटा फ़ील्ड को शुरू से समझें.
- जगह के हिसाब से सुझाव और जगह की पाबंदी वाले फ़ील्ड का इस्तेमाल करना ज़रूरी नहीं है. हालांकि, इनका इस्तेमाल करने से ऑटोमैटिक भरने की सुविधा की परफ़ॉर्मेंस पर काफ़ी असर पड़ सकता है.
- गड़बड़ी को मैनेज करने की सुविधा का इस्तेमाल करके, पक्का करें कि एपीआई से गड़बड़ी का मैसेज मिलने पर, आपका ऐप्लिकेशन सही तरीके से काम करना बंद कर दे.
- पक्का करें कि आपका ऐप्लिकेशन, कोई विकल्प न चुनने पर भी काम करता हो और उपयोगकर्ताओं को आगे बढ़ने का तरीका बताता हो.
लागत को ऑप्टिमाइज़ करने के सबसे सही तरीके
बुनियादी लागत ऑप्टिमाइज़ेशन
जगह की जानकारी अपने-आप भरने की सुविधा का इस्तेमाल करने की लागत को ऑप्टिमाइज़ करने के लिए, जगह की जानकारी और जगह की जानकारी अपने-आप भरने की सुविधा वाले विजेट में फ़ील्ड मास्क का इस्तेमाल करें. इससे, आपको सिर्फ़ वही जगह का डेटा फ़ील्ड दिखेगा जिसकी ज़रूरत है.
लागत का बेहतर ऑप्टिमाइज़ेशन
हर अनुरोध के हिसाब से कीमत को ऐक्सेस करने के लिए, जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा को प्रोग्राम के तौर पर लागू करें. साथ ही, जगह की जानकारी के बजाय, चुनी गई जगह के बारे में Geocoding API के नतीजों का अनुरोध करें. अगर ये दोनों शर्तें पूरी होती हैं, तो जियोकोडिंग एपीआई के साथ हर अनुरोध के हिसाब से तय की गई कीमत, हर सेशन (सेशन के हिसाब से) कीमत के मुकाबले ज़्यादा किफ़ायती होती है:
- अगर आपको उपयोगकर्ता की चुनी गई जगह का सिर्फ़ अक्षांश/देशांतर या पता चाहिए, तो Geocoding API इस जानकारी को जगह की जानकारी वाले कॉल से कम समय में डिलीवर करता है.
- अगर उपयोगकर्ता, ऑटोकंप्लीट के अनुमान के चार या उससे कम अनुरोधों में से कोई सुझाव चुनते हैं, तो हर अनुरोध के हिसाब से कीमत, हर सेशन के हिसाब से कीमत से ज़्यादा किफ़ायती हो सकती है.
क्या आपके ऐप्लिकेशन को, चुने गए अनुमान के पते और अक्षांश/देशांतर के अलावा, कोई और जानकारी चाहिए?
हां, ज़्यादा जानकारी चाहिए
जगह की जानकारी के साथ, सेशन के हिसाब से जगह के नाम के सुझाव पाने की सुविधा का इस्तेमाल करें.
आपके ऐप्लिकेशन को जगह की जानकारी की ज़रूरत होती है, जैसे कि जगह का नाम, कारोबार की स्थिति या खुले होने का समय. इसलिए, जगह की जानकारी अपने-आप भरने की सुविधा को लागू करने के लिए, सेशन टोकन का इस्तेमाल किया जाना चाहिए. यह प्रोग्राम के हिसाब से या JavaScript, Android या iOS विजेट में पहले से मौजूद होता है. इसके लिए, हर सेशन के लिए 0.017 डॉलर और Places Data SKUs की लागत चुकाई जाती है. यह लागत, जगह की जानकारी के उन फ़ील्ड पर निर्भर करती है जिनका अनुरोध किया जाता है.1
विजेट लागू करना
सेशन मैनेजमेंट, JavaScript, Android या iOS विजेट में अपने-आप बन जाता है. इसमें, चुनी गई जगह के लिए, जगह की जानकारी के अनुरोध और जगह के ऑटोकंप्लीट होने से जुड़े अनुरोध, दोनों शामिल होते हैं. fields
पैरामीटर की वैल्यू डालना न भूलें, ताकि यह पक्का किया जा सके कि आपने सिर्फ़ उन जगह के डेटा फ़ील्ड के लिए अनुरोध किया है जिनकी आपको ज़रूरत है.
प्रोग्रामैटिक तरीके से लागू करना
जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के अनुरोधों के साथ सेशन टोकन का इस्तेमाल करें. चुने गए अनुमान के बारे में जगह की जानकारी का अनुरोध करते समय, इन पैरामीटर को शामिल करें:
- जगह के नाम के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के जवाब में मौजूद जगह का आईडी
- जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के अनुरोध में इस्तेमाल किया गया सेशन टोकन
fields
पैरामीटर, जिसमें आपके ज़रूरी जगह के डेटा फ़ील्ड की जानकारी होती है
नहीं, सिर्फ़ पते और जगह की जानकारी की ज़रूरत है
आपके ऐप्लिकेशन के लिए, जगह की जानकारी की तुलना में Geocoding API का इस्तेमाल करना ज़्यादा किफ़ायती हो सकता है. यह इस बात पर निर्भर करता है कि आपने जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा का इस्तेमाल कितना किया है. हर ऐप्लिकेशन में ऑटोमैटिक भरने की सुविधा की परफ़ॉर्मेंस अलग-अलग होती है. यह इस बात पर निर्भर करता है कि उपयोगकर्ता क्या डाल रहे हैं, ऐप्लिकेशन का इस्तेमाल कहां किया जा रहा है, और परफ़ॉर्मेंस ऑप्टिमाइज़ेशन के सबसे सही तरीके लागू किए गए हैं या नहीं.
नीचे दिए गए सवाल का जवाब देने के लिए, यह विश्लेषण करें कि आपके ऐप्लिकेशन में जगह के अपने-आप पूरे होने वाले सुझावों में से किसी एक को चुनने से पहले, उपयोगकर्ता औसतन कितने वर्ण टाइप करता है.
क्या आपके उपयोगकर्ता, जगह के लिए ऑटोकंप्लीट की मदद से मिलने वाले सुझावों में से, औसतन चार या उससे कम अनुरोधों में कोई एक सुझाव चुनते हैं?
हां
सेशन टोकन के बिना, प्रोग्राम के हिसाब से जगह की जानकारी अपने-आप पूरी होने की सुविधा लागू करें. साथ ही, चुनी गई जगह के अनुमान पर जियोकोडिंग एपीआई को कॉल करें.
Geocoding API, हर अनुरोध के लिए 0.005 डॉलर में पते और अक्षांश/देशांतर के निर्देशांक उपलब्ध कराता है. जगह की जानकारी के लिए ऑटोकंप्लीट की सुविधा - हर अनुरोध के लिए चार अनुरोध करने पर, 0.01132 डॉलर का शुल्क लगता है. इसलिए, चुनी गई जगह के सुझाव के लिए चार अनुरोधों और Geocoding API कॉल की कुल कीमत 0.01632 डॉलर होगी. यह कीमत, हर सेशन के लिए ऑटोकंप्लीट की सुविधा के शुल्क 0.017 डॉलर से कम है.1
परफ़ॉर्मेंस के सबसे सही तरीकों का इस्तेमाल करें, ताकि आपके उपयोगकर्ता कम वर्णों में भी अपनी खोज के नतीजे पा सकें.
नहीं
जगह की जानकारी के साथ, सेशन के हिसाब से जगह के नाम के सुझाव पाने की सुविधा का इस्तेमाल करें.
किसी जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के सुझाव चुनने से पहले, आपके अनुरोधों की औसत संख्या, हर सेशन के लिए तय की गई कीमत से ज़्यादा हो सकती है. इसलिए, जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा को लागू करने के लिए, आपको सेशन टोकन का इस्तेमाल करना चाहिए. यह टोकन, जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के अनुरोधों और उससे जुड़ी जगह की जानकारी के अनुरोध, दोनों के लिए इस्तेमाल किया जाना चाहिए. इसकी कुल कीमत हर सेशन के लिए 0.017 डॉलर होगी.1
विजेट लागू करना
सेशन मैनेजमेंट, JavaScript, Android या iOS विजेट में अपने-आप बन जाता है. इसमें, चुनी गई जगह के लिए, जगह की जानकारी के अनुरोध और जगह के ऑटोकंप्लीट होने से जुड़े अनुरोध, दोनों शामिल होते हैं. fields
पैरामीटर की वैल्यू डालना न भूलें, ताकि यह पक्का किया जा सके कि आपने सिर्फ़ बुनियादी डेटा फ़ील्ड का अनुरोध किया है.
प्रोग्रामैटिक तरीके से लागू करना
जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के अनुरोधों के साथ सेशन टोकन का इस्तेमाल करें. चुने गए अनुमान के बारे में जगह की जानकारी का अनुरोध करते समय, इन पैरामीटर को शामिल करें:
- जगह के नाम के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के जवाब में मौजूद जगह का आईडी
- जगह के शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा के अनुरोध में इस्तेमाल किया गया सेशन टोकन
fields
पैरामीटर, जो पते और ज्यामिति जैसे बुनियादी डेटा फ़ील्ड की जानकारी देता है
जगह की जानकारी अपने-आप पूरी होने की सुविधा के अनुरोधों को देर से भेजने पर विचार करें
जगह की जानकारी अपने-आप पूरी होने की सुविधा के अनुरोध को तब तक देर से भेजें, जब तक कि उपयोगकर्ता ने पहले तीन या चार वर्ण टाइप न कर लिए हों. इससे आपके ऐप्लिकेशन को कम अनुरोध करने होंगे. उदाहरण के लिए, उपयोगकर्ता के तीसरा वर्ण टाइप करने के बाद, हर वर्ण के लिए जगह की जानकारी के ऑटोकंप्लीट के अनुरोध करने का मतलब है कि अगर उपयोगकर्ता सात वर्ण टाइप करता है और फिर कोई ऐसा सुझाव चुनता है जिसके लिए आपने एक जियोकोडिंग एपीआई अनुरोध किया है, तो कुल लागत 0.01632 डॉलर होगी (हर अनुरोध के लिए ऑटोकंप्लीट की 4 * 0.00283 डॉलर की लागत + 0.005 डॉलर की जियोकोडिंग की लागत).1
अगर अनुरोधों में देरी करने से, प्रोग्राम के हिसाब से किए जाने वाले अनुरोधों की औसत संख्या चार से कम हो सकती है, तो Geocoding API की मदद से, जगह की जानकारी के लिए ऑटोकंप्लीट की बेहतर परफ़ॉर्मेंस लागू करने के लिए दिए गए दिशा-निर्देशों का पालन करें. ध्यान दें कि अनुरोधों में देरी होने पर, उपयोगकर्ता को लग सकता है कि क्वेरी प्रोसेस होने में देरी हो रही है. ऐसा इसलिए हो सकता है, क्योंकि वह हर नए कीस्ट्रोक के साथ सुझाव देखना चाहता हो.
परफ़ॉर्मेंस के सबसे सही तरीकों का इस्तेमाल करें, ताकि आपके उपयोगकर्ता कम वर्णों में अपने हिसाब से सुझाव पा सकें.
-
यहां दी गई कीमतें डॉलर में हैं. कीमत की पूरी जानकारी के लिए, कृपया Google Maps Platform की बिलिंग पेज पर जाएं.
परफ़ॉर्मेंस के सबसे सही तरीके
यहां दिए गए दिशा-निर्देशों में, जगह की जानकारी के लिए ऑटोकंप्लीट की सुविधा की परफ़ॉर्मेंस को ऑप्टिमाइज़ करने के तरीके बताए गए हैं:
- जगह के नाम के अपने-आप पूरे होने की सुविधा को लागू करते समय, देश से जुड़ी पाबंदियां, जगह के हिसाब से जानकारी, और प्रोग्राम के हिसाब से लागू करने के लिए, भाषा की प्राथमिकता जोड़ें. विजेट के लिए, भाषा की प्राथमिकता सेट करने की ज़रूरत नहीं होती, क्योंकि ये उपयोगकर्ता के ब्राउज़र या मोबाइल डिवाइस से भाषा की प्राथमिकताएं चुनते हैं.
- अगर जगह की जानकारी अपने-आप पूरी होने की सुविधा के साथ मैप भी दिखता है, तो मैप व्यूपोर्ट के हिसाब से जगह की जानकारी को प्राथमिकता दी जा सकती है.
- आम तौर पर, जब कोई उपयोगकर्ता ऑटोकंप्लीट की सुविधा से मिलने वाले किसी सुझाव को नहीं चुनता है, तो इसका मतलब है कि उनमें से कोई भी सुझाव, उपयोगकर्ता के हिसाब से सही नहीं है. ऐसे में, ज़्यादा काम के नतीजे पाने के लिए, उपयोगकर्ता के मूल इनपुट का फिर से इस्तेमाल किया जा सकता है:
- अगर आपको लगता है कि उपयोगकर्ता सिर्फ़ पते की जानकारी डालेगा, तो Geocoding API को कॉल करते समय, उपयोगकर्ता के मूल इनपुट का फिर से इस्तेमाल करें.
- अगर आपको लगता है कि उपयोगकर्ता किसी जगह के नाम या पते से जुड़ी क्वेरी डालेगा, तो जगह ढूंढने का अनुरोध का इस्तेमाल करें. अगर आपको सिर्फ़ किसी खास इलाके के लिए नतीजे चाहिए, तो जगह के हिसाब से नतीजे दिखाने की सुविधा का इस्तेमाल करें.
- उपयोगकर्ता, सब-प्राइमिस के पते डाल रहे हों. जैसे, किसी इमारत में मौजूद खास यूनिट या अपार्टमेंट के पते. उदाहरण के लिए, चेक के पते "Stroupežnického 3191/17, Praha" के लिए, जगह की जानकारी को ऑटोकंप्लीट करने की सुविधा से कुछ हद तक जानकारी मिलती है.
- ऐसे उपयोगकर्ता जो सड़क के सेगमेंट के प्रीफ़िक्स के साथ पते डालते हैं. जैसे, न्यूयॉर्क शहर में "23-30 29th St, Queens" या हवाई के काऊई द्वीप पर "47-380 Kamehameha Hwy, Kaneohe".
समस्या का हल
कई तरह की गड़बड़ियां हो सकती हैं. हालांकि, आपके ऐप्लिकेशन में होने वाली ज़्यादातर गड़बड़ियां, कॉन्फ़िगरेशन की गड़बड़ियों (उदाहरण के लिए, गलत एपीआई पासकोड का इस्तेमाल किया गया या एपीआई पासकोड को गलत तरीके से कॉन्फ़िगर किया गया) या कोटा से जुड़ी गड़बड़ियों (आपका ऐप्लिकेशन अपने कोटे से ज़्यादा डेटा इस्तेमाल कर रहा है) की वजह से होती हैं. कोटा के बारे में ज़्यादा जानकारी के लिए, इस्तेमाल की सीमाएं देखें.
अपने-आप पूरा होने वाले टेक्स्ट के कंट्रोल इस्तेमाल करने में होने वाली गड़बड़ियां, onActivityResult()
कॉलबैक में दिखती हैं. नतीजे की स्थिति का मैसेज पाने के लिए, Autocomplete.getStatus()
पर कॉल करें.