Yer Fotoğrafları (Yeni)

Platform seçin: Android iOS Web Hizmeti

Yer Fotoğrafları (Yeni), uygulamanıza yüksek kaliteli fotoğraf içerikleri eklemenize olanak tanır. Yer Fotoğrafları, Yerler veritabanında depolanan milyonlarca fotoğrafa erişmenizi sağlar. Place Photos, bitmap resminin URI'sini döndürür. Bit eşleme resminin maksimum boyutu 4.800x4.800 pikseldir.

Fotoğraf isteği gönderme

Bir yerin resmini almak için:

  1. fetchPlace() kullanarak bir Place nesnesi almak için Yer Ayrıntıları (Yeni)'ni kullanın. Yanıt Place nesnesine eklenecek alanlar listesine Place.Field PHOTO_METADATAS alanını eklediğinizden emin olun.
  2. FetchPlaceResponse için OnSuccessListener bölümünde, Place yanıt nesnesinden PhotoMetadata türündeki fotoğraf meta verisi nesnesini almak için Place.getPhotoMetadas() işlevini çağırın.
  3. İsteği yapmak ve fotoğraf meta veri nesnesini, ayrıca maksimum yükseklik, maksimum genişlik veya her ikisinin değerlerini iletmek için bir FetchResolvedPhotoUriRequest nesnesi oluşturun.
  4. Fotoğraf URI'sini istemek için PlacesClient.fetchResolvedPhotoUri() hizmetini kullanın.
  5. Bir OnSuccessListener ekleyin ve FetchResolvedPhotoUriResponse sınıfından fotoğraf URI'sini alın.

Gerekli parametreler

FetchResolvedPhotoUriRequest için gerekli parametreler şunlardır:

  • Fotoğraf meta verileri

    Döndürülecek fotoğrafın meta veri nesnesi.

  • Maksimum yükseklik veya maksimum genişlik

    Döndürülecek resmin maksimum yüksekliğini ve genişliğini piksel cinsinden belirtir. Resim belirtilen değerlerden küçükse orijinal resim döndürülür. Resim herhangi bir boyutta daha büyükse orijinal en boy oranıyla kısıtlanarak iki boyuttan daha küçük olana uyacak şekilde ölçeklendirilir. Hem maksimum yükseklik hem de maksimum genişlik özellikleri 1 ile 4.800 arasında bir tam sayı kabul eder. Maksimum yüksekliği, maksimum genişliği veya her ikisini de belirtmeniz gerekir.

    • Maksimum yükseklik parametresini ayarlamak için FetchResolvedPhotoUriRequest nesnesini oluştururken setMaxHeight() yöntemini çağırın.
    • Maksimum genişlik parametresini ayarlamak için FetchResolvedPhotoUriRequest nesnesini oluştururken setMaxWidth() yöntemini çağırın.

Yer fotoğrafı örnekleri

Aşağıdaki örnekte, yer fotoğrafı URI'sinin nasıl alınacağı gösterilmektedir.

// Define a Place ID.
final String placeId = "INSERT_PLACE_ID_HERE";

// Specify fields. Requests for photos must always have the PHOTO_METADATAS field.
final List<Place.Field> fields = Collections.singletonList(Place.Field.PHOTO_METADATAS);

// Get a Place object (this example uses fetchPlace(), but you can also use findCurrentPlace())
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.
        }
    });
});

İlişkilendirmeler

Çoğu durumda yer fotoğrafları ilişkilendirme olmadan kullanılabilir veya gerekli ilişkilendirme, resmin bir parçası olarak eklenir. Ancak PhotoMetadata türündeki fotoğraf meta verileri nesnesi, aşağıdaki iki ek ilişkilendirme türünden birini içerebilir:

Döndürülen PhotoMetadata nesnesi bu ilişkilendirme türlerinden birini içeriyorsa resmi görüntülediğiniz her yerde ilişkilendirmeyi uygulamanıza eklemeniz gerekir. Daha fazla bilgi için İlişkilendirmeleri görüntüleme başlıklı makaleyi inceleyin.