Mit dem Places SDK for iOS können Sie Fotos von Orten anfordern, die in Ihrer App angezeigt werden sollen. Die vom Fotodienst bereitgestellten Fotos stammen aus unterschiedlichen Quellen, z. B. von Geschäftsinhabern oder Nutzern. So rufen Sie Fotos für einen Ort ab:
- Rufen Sie
[GMSPlacesClient fetchPlaceFromPlaceId]
auf und übergeben Sie einen String mit einer Orts-ID und einem Rückruf. Dadurch wird der Rückruf mit einemGMSPlacePhotoMetadataList
-Objekt aufgerufen. - Rufe auf dem Objekt
GMSPlacePhotoMetadataList
die Eigenschaftresults
auf und wähle die Fotos aus, die aus dem Array geladen werden sollen. - Rufe für jeden
GMSPlacePhotoMetadata
, der aus dieser Liste geladen werden soll,[GMSPlacesClient loadPlacePhoto:callback:]
oder[GMSPlacesClient loadPlacePhoto:constrainedToSize:scale:callback:]
auf. Damit wird der Callback mit einem verwendbaren UIImage aufgerufen. Fotos dürfen maximal 1.600 Pixel breit oder hoch sein.
Beispielcode
In der folgenden Beispielmethode wird eine Orts-ID übergeben, um das erste Foto in der zurückgegebenen Liste abzurufen. Sie können diese Methode als Vorlage für die Methode verwenden, die Sie in Ihrer eigenen App erstellen.
Swift
// Specify the place data types to return (in this case, just photos). let fields: GMSPlaceField = GMSPlaceField(rawValue: UInt(GMSPlaceField.photos.rawValue))! placesClient?.fetchPlace(fromPlaceID: "INSERT_PLACE_ID_HERE", placeFields: fields, sessionToken: nil, callback: { (place: GMSPlace?, error: Error?) in if let error = error { print("An error occurred: \(error.localizedDescription)") return } if let place = place { // Get the metadata for the first photo in the place photo metadata list. let photoMetadata: GMSPlacePhotoMetadata = place.photos![0] // Call loadPlacePhoto to display the bitmap and attribution. self.placesClient?.loadPlacePhoto(photoMetadata, callback: { (photo, error) -> Void in if let error = error { // TODO: Handle the error. print("Error loading photo metadata: \(error.localizedDescription)") return } else { // Display the first image and its attributions. self.imageView?.image = photo; self.lblText?.attributedText = photoMetadata.attributions; } }) } })
Objective-C
// Specify the place data types to return (in this case, just photos). GMSPlaceField fields = (GMSPlaceFieldPhotos); NSString *placeId = @"INSERT_PLACE_ID_HERE"; [_placesClient fetchPlaceFromPlaceID:placeId placeFields:fields sessionToken:nil callback:^(GMSPlace * _Nullable place, NSError * _Nullable error) { if (error != nil) { NSLog(@"An error occurred %@", [error localizedDescription]); return; } if (place != nil) { GMSPlacePhotoMetadata *photoMetadata = [place photos][0]; [self->_placesClient loadPlacePhoto:photoMetadata callback:^(UIImage * _Nullable photo, NSError * _Nullable error) { if (error != nil) { NSLog(@"Error loading photo metadata: %@", [error localizedDescription]); return; } else { // Display the first image and its attributions. self->imageView.image = photo; self->lblText.attributedText = photoMetadata.attributions; } }]; } }];
Caching
Fotos, die über [GMSPlacesClient loadPlacePhoto:callback:]
oder [GMSPlacesClient loadPlacePhoto:constrainedToSize:scale:callback:]
geladen werden, werden vom Foundation-URL-Ladesystem im freigegebenen NSURLCache
sowohl auf dem Laufwerk als auch im Arbeitsspeicher im Cache gespeichert.
Wenn Sie das Caching-Verhalten konfigurieren möchten, können Sie den freigegebenen URL-Cache mit [NSURLCache setSharedURLCache:]
in der application:didFinishLaunchingWithOptions:
-Methode Ihres Anwendungsdelegats ändern.
Wenn Ihre Anwendung keine NSURLCache
mit dem Places SDK for iOS teilen soll, können Sie eine neue NSURLCache
erstellen und diese ausschließlich in Ihrer App verwenden, ohne sie als freigegebenen Cache festzulegen.
Attribution
In den meisten Fällen dürfen Fotos von Orten ohne Quellenangabe verwendet werden bzw. sind die erforderlichen Zuordnungen bereits im Bild eingebunden. Wenn die zurückgegebene GMSPlacePhotoMetadata
-Instanz jedoch eine Quellenangabe enthält, müssen Sie diese zusätzliche Quellenangabe immer dann in Ihre Anwendung einbinden, wenn das Bild zu sehen ist. Hinweis: Links in der Attribution müssen anklickbar sein. Weitere Informationen finden Sie in der Dokumentation zu Attributionen.
Nutzungslimits
Das Abrufen eines Bildes kostet eine Kontingenteinheit. Für das Abrufen von Fotometadaten gibt es keine Nutzungslimits. Weitere Informationen zu Nutzung und Abrechnung