Place Photos (नया) की मदद से, अपने ऐप्लिकेशन में अच्छी क्वालिटी वाला फ़ोटोग्राफ़िक कॉन्टेंट जोड़ा जा सकता है. Place Photos की मदद से, Places डेटाबेस में सेव की गई लाखों फ़ोटो ऐक्सेस की जा सकती हैं. Place Photos, बिटमैप इमेज का यूआरआई दिखाता है. बिटमैप इमेज का साइज़ ज़्यादा से ज़्यादा 4800x4800 पिक्सल हो सकता है.
जगह की फ़ोटो के अनुरोध
किसी जगह की इमेज वापस पाने के लिए:
fetchPlace()का इस्तेमाल करकेPlaceऑब्जेक्ट को फ़ेच करने के लिए, जगह की जानकारी (नई) का इस्तेमाल करें. यह पक्का करें कि जवाबPlaceऑब्जेक्ट में शामिल करने के लिए, फ़ील्ड की सूची मेंPlace.Field PHOTO_METADATASफ़ील्ड शामिल हो.- अपने
FetchPlaceResponseके लिएOnSuccessListenerमें,Place.getPhotoMetadas()को कॉल करें, ताकि आपको जवाबPlaceऑब्जेक्ट सेPhotoMetadataटाइप का फ़ोटो मेटाडेटा ऑब्जेक्ट मिल सके. - अनुरोध करने के लिए,
FetchResolvedPhotoUriRequestऑब्जेक्ट बनाएं. साथ ही, फ़ोटो मेटाडेटा ऑब्जेक्ट और ज़्यादा से ज़्यादा ऊंचाई, ज़्यादा से ज़्यादा चौड़ाई या दोनों के लिए वैल्यू पास करें. - फ़ोटो का यूआरआई पाने का अनुरोध करने के लिए,
PlacesClient.fetchResolvedPhotoUri()का इस्तेमाल करें. OnSuccessListenerजोड़ें औरFetchResolvedPhotoUriResponseऑब्जेक्ट से फ़ोटो का यूआरआई पाएं.
ज़रूरी पैरामीटर
FetchResolvedPhotoUriRequest के लिए ज़रूरी पैरामीटर ये हैं:
-
फ़ोटो का मेटाडेटा
लौटाई जाने वाली फ़ोटो का मेटाडेटा ऑब्जेक्ट.
-
ज़्यादा से ज़्यादा ऊंचाई या ज़्यादा से ज़्यादा चौड़ाई
इससे, दिखाई जाने वाली इमेज की ज़्यादा से ज़्यादा ऊंचाई और चौड़ाई (पिक्सेल में) तय की जाती है. अगर इमेज, तय की गई वैल्यू से छोटी है, तो ओरिजनल इमेज दिखाई जाएगी. अगर इमेज का कोई भी डाइमेंशन बड़ा है, तो उसे दोनों डाइमेंशन में से छोटे डाइमेंशन के हिसाब से स्केल किया जाएगा. हालांकि, ऐसा उसके ओरिजनल आसपेक्ट रेशियो के हिसाब से ही किया जाएगा. ज़्यादा से ज़्यादा ऊंचाई और ज़्यादा से ज़्यादा चौड़ाई, दोनों प्रॉपर्टी के लिए 1 से 4800 के बीच की पूर्णांक वैल्यू स्वीकार की जाती है. आपको ज़्यादा से ज़्यादा ऊंचाई, ज़्यादा से ज़्यादा चौड़ाई या दोनों की जानकारी देनी होगी.
- ज़्यादा से ज़्यादा ऊंचाई का पैरामीटर सेट करने के लिए,
FetchResolvedPhotoUriRequestऑब्जेक्ट बनाते समयsetMaxHeight()तरीके को कॉल करें. - ज़्यादा से ज़्यादा चौड़ाई वाला पैरामीटर सेट करने के लिए,
FetchResolvedPhotoUriRequestऑब्जेक्ट बनाते समयsetMaxWidth()तरीके को कॉल करें.
- ज़्यादा से ज़्यादा ऊंचाई का पैरामीटर सेट करने के लिए,
जगह की फ़ोटो के उदाहरण
यहां दिए गए उदाहरण में, किसी जगह की फ़ोटो का यूआरआई पाने का तरीका बताया गया है.
// Define a Place ID. final String placeId = "INSERT_PLACE_ID_HERE"; // Specify fields. Requests for photos must always have the PHOTO_METADATAS field. <final ListP>lace.Field fields = Collections.singletonList(Place.Field.PHOTO_METADATAS); // Get a Place object final FetchPlaceRequest placeRequest = FetchPlaceRequest.newInstance(placeId, fields); placesClient.fetchPlace(placeRequest).addOnSuccessListener((response) -> { final Place place = response.getPlace(); // Get the photo metadata. < final List>PhotoMetadata metadata = place.getPhotoMetadatas(); if (metadata == null || metadata.isEmpty()) { Log.w(TAG, "No photo metadata."); return; } final PhotoMetadata photoMetadata = metadata.get(0); // Get the attribution text and author attributions. final String attributions = photoMetadata.getAttributions(); final AuthorAttributions authorAttributions = photoMetadata.getAuthorAttributions(); // Create a FetchResolvedPhotoUriRequest. final FetchResolvedPhotoUriRequest photoRequest = FetchResolvedPhotoUriRequest.builder(photoMetadata) .setMaxWidth(500) .setMaxHeight(300) .build(); // Request the photo URI placesClient.fetchResolvedPhotoUri(photoRequest).addOnSuccessListener((fetchResolvedPhotoUriResponse) -> { Uri uri = fetchResolvedPhotoUriResponse.getUri(); RequestOptions requestOptions = new RequestOptions().override(Target.SIZE_ORIGINAL); Glide.with(this).load(uri).apply(requestOptions).into(imageView); }).addOnFailureListener((exception) -> { if (exception instanceof ApiException) { final ApiException apiException = (ApiException) exception; Log.e(TAG, "Place not found: " + exception.getMessage()); final int statusCode = apiException.getStatusCode(); // TODO: Handle error with given status code. } }); });
एट्रिब्यूशन
ज़्यादातर मामलों में, जगह की फ़ोटो का इस्तेमाल बिना एट्रिब्यूशन के किया जा सकता है. इसके अलावा, कुछ मामलों में इमेज के साथ ज़रूरी एट्रिब्यूशन शामिल होता है. हालांकि, PhotoMetadata टाइप का फ़ोटो मेटाडेटा ऑब्जेक्ट, दो तरह के अतिरिक्त एट्रिब्यूशन में से किसी एक को शामिल कर सकता है:
- Attributions, यह एक एट्रिब्यूशन स्ट्रिंग है, जिसे
PhotoMetadata.getAttributions()ऐक्सेस करता है. - AuthorAttributions, एक
AuthorAttributionsऑब्जेक्ट है, जिसेPhotoMetadata.getAuthorAttributions()से ऐक्सेस किया जाता है.
अगर जवाब में मिले PhotoMetadata ऑब्जेक्ट में किसी भी तरह का क्रेडिट शामिल है, तो आपको अपने ऐप्लिकेशन में उस इमेज को दिखाने के लिए, क्रेडिट देना होगा. ज़्यादा जानकारी के लिए,
एट्रिब्यूशन दिखाना लेख पढ़ें.