Place Photos (novo)

Selecione a plataforma: Android iOS Web Service

É possível usar o SDK do Places para iOS (novo) para solicitar que fotos de locais sejam exibidas no seu aplicativo. As fotos retornadas pelo serviço de fotos têm origens variadas, incluindo proprietários de empresas e usuários.

As fotos são imagens de bitmap representadas por um objeto UIImage. Uma imagem bitmap tem um tamanho máximo de 4.800 x 4.800 pixels.

Solicitar uma imagem

Você pode solicitar até 10 fotos de um lugar:

  1. Chame [GMSPlacesClient lookUpPhotosForPlaceID], transmitindo um ID de lugar e um retorno de chamada GMSPlacePhotoMetadataResultCallback. Essa solicitação chama o callback GMSPlacePhotoMetadataResultCallback com um objeto GMSPlacePhotoMetadataList.

  2. Do objeto GMSPlacePhotoMetadataList no callback, a propriedade de matriz results contém as fotos, em que cada uma é representada por um objeto GMSPlacePhotoMetadata.

  3. Use o objeto GMSPlacePhotoMetadata para criar um GMSFetchPhotoRequest, incluindo o tamanho máximo da imagem solicitada.

  4. Para cada objeto GMSPlacePhotoMetadata na matriz, chame [GMSPlacesClient fetchPhotoWithRequest:callback:] transmitindo o objeto GMSFetchPhotoRequest. Esse método chama o callback GMSFetchPhotoResultCallback com uma imagem de bitmap utilizável como UIImage.

Outra maneira de solicitar fotos de um lugar é fazer uma solicitação de Place Details (New), incluindo GMSPlacePropertyPhotos na lista de campos. A vantagem de fazer uma chamada de Place Details é que o objeto de resposta GMSPlace pode conter as fotos e outros campos de dados que você quiser para o lugar.

Código de amostra

O exemplo de método a seguir coleta um ID de local e obtém a primeira foto na lista retornada. Use esse método como modelo para criar o método no seu próprio app.

Swift

// A hotel in Saigon with an attribution.
let placeID = "ChIJV4k8_9UodTERU5KXbkYpSYs"

// Request list of photos for a place
placesClient.lookUpPhotos(forPlaceID: placeID) { (photos, error) in

  guard let photoMetadata: GMSPlacePhotoMetadata = photos?.results[0] else {
    return }

  // Request individual photos in the response list
  let fetchPhotoRequest = GMSFetchPhotoRequest(photoMetadata: photoMetadata, maxSize: CGSizeMake(4800, 4800))
  self.client.fetchPhoto(with: fetchPhotoRequest, callback: {
    (photoImage: UIImage?, error: Error?) in
      guard let photoImage, error == nil else {
        print("Handle photo error: ")
        return }
      print("Display photo Image: ")
    }
  )
}

Objective-C

// A hotel in Saigon with an attribution.
NSString *placeID = @"ChIJV4k8_9UodTERU5KXbkYpSYs";

[placesClient lookUpPhotosForPlaceID:placeID callback: ^(GMSPlacePhotoMetadataList *list, NSError *error) {
  GMSPlacePhotoMetadata *photoMetadata = [list results][0];

  // Request individual photos in the response list
  GMSFetchPhotoRequest *fetchPhotoRequest = [[GMSFetchPhotoRequest alloc] initWithPhotoMetadata:photoMetadata maxSize:CGSizeMake(4800, 4800)];
  [placesClient fetchPhotoWithRequest:fetchPhotoRequest callback: ^(UIImage *_Nullable photoImage, NSError *_Nullable error) {
    if (error == nil) {
      // Display photo
    }
  }];
}];

SDK do Places Swift para iOS (pré-lançamento)

// First fetch place details
// A hotel in Saigon with an attribution.
let placeID = "ChIJV4k8_9UodTERU5KXbkYpSYs"
let fetchPlaceRequest = FetchPlaceRequest(
  placeID: placeID,
  placeProperties: [ . name, .website ]
)
var fetchedPlace: Place
switch await placesClient.fetchPlace(with: fetchPlaceRequest) {
case .success(let place):
  fetchedPlace = place
case .failure(let placesError):
  // Handle error
}

// Use the place details to fetch a photo's image.
guard let photo = fetchedPlace.photos?.first else {
  // Handle place without photos.
}
let fetchPhotoRequest =
  FetchPhotoRequest(photo: photo, maxSize: CGSizeMake(4800, 4800))
switch await placesClient.fetchPhoto(with: fetchPhotoRequest) {
case .success(let uiImage):
  // Handle image.
case .failure(let placesError):
  // Handle error
}

Armazenamento em cache

As fotos carregadas usando [GMSPlacesClient loadPlacePhoto:callback:] ou [GMSPlacesClient loadPlacePhoto:constrainedToSize:scale:callback:] são armazenadas em cache no disco e na memória pelo sistema de carregamento de URL Foundation no NSURLCache compartilhado.

Para configurar o comportamento de armazenamento em cache, é possível mudar o cache de URLs compartilhados usando [NSURLCache setSharedURLCache:] no método application:didFinishLaunchingWithOptions: do delegado do app.

Se você não quiser que o aplicativo compartilhe um NSURLCache com o SDK do Places para iOS, crie um novo NSURLCache e use-o exclusivamente no app sem configurá-lo como o cache compartilhado.

Atribuições

Na maioria dos casos, fotos de locais podem ser usadas sem atribuição ou terão a atribuição necessária incluída como parte da imagem. No entanto, se a instância GMSPlacePhotoMetadata retornada incluir qualquer attributions ou authorAttribution, será necessário incluir essas atribuições no aplicativo sempre que você mostrar a imagem. Consulte a documentação sobre atribuições.