Yer fotoğrafları, web sayfalarınıza yüksek kaliteli fotoğraf içerikleri eklemenize olanak tanır.
Bu sayfada, Place
sınıfındaki (yeni) ve PlacesService
sınıfındaki (eski) yer fotoğrafı özellikleri arasındaki farklar açıklanmakta ve karşılaştırma için bazı kod snippet'leri sağlanmaktadır.
PlacesService
(eski),photos
alanı istekte belirtilmişse herhangi birgetDetails()
isteği içinPlaceResult
nesnesi kapsamında en fazla 10PlacePhoto
nesnesi dizisi döndürür.textSearch()
venearbySearch()
için, varsa varsayılan olarak ilk yer fotoğrafı döndürülür.Place
sınıfı, istektephotos
alanı belirtilmişsefetchFields()
isteği kapsamında 10'a kadarPhoto
nesnesi içeren bir dizi döndürür.
Aşağıdaki tabloda, yer fotoğraflarının Place
sınıfı ile PlacesService
sınıfı arasında kullanımındaki temel farklılıklardan bazıları listelenmiştir:
PlacesService (Eski) |
Place (Yeni) |
---|---|
PlacePhoto arayüzü |
Photo sınıf |
PlacePhoto ,
html_attributions değerini dize olarak döndürür. |
Photo ,
AuthorAttribution örneği döndürür. |
Yöntemler, sonuçlar nesnesini ve google.maps.places.PlacesServiceStatus yanıtını işlemek için geri çağırma işlevinin kullanılmasını gerektirir. |
Promise'leri kullanır ve eşzamansız olarak çalışır. |
Yöntemler için PlacesServiceStatus kontrolü gerekir. |
Zorunlu durum kontrolü yoktur, standart hata işleme kullanılabilir. |
PlacesService , bir harita veya div öğesi kullanılarak örneklenmelidir. |
Place , harita veya sayfa öğesine referans vermeden gerektiği her yerde örneklendirilebilir. |
Kod karşılaştırması
Bu bölümde, Yerler hizmeti ile Yer sınıfı arasındaki farkları göstermek için yer fotoğraflarıyla ilgili kod karşılaştırılmaktadır. Kod snippet'leri, ilgili API'lerde yer fotoğrafları istemek için gereken kodu gösterir.
Yerler hizmeti (eski)
Aşağıdaki snippet'te, PlacesService
kullanarak geri gelen fotoğraflar gösterilmekte ve sayfada ilk fotoğraf sonucu görüntülenmektedir. Bu örnekte yer ayrıntıları isteği, name
ve photos
alanlarının yanı sıra bir yer kimliği belirtir.
Ardından, hizmet durumu kontrol edildikten sonra ilk fotoğraf sayfada gösterilir.
PlacesService
öğesi oluşturulurken bir harita veya div
öğesi belirtilmelidir. Bu örnekte harita bulunmadığından div
öğesi kullanılmıştır.
function getPhotos() {
// Construct the Place Details request.
const request = {
placeId: "ChIJydSuSkkUkFQRsqhB-cEtYnw",
fields: ["name", "photos"],
};
// Create an instance of PlacesService.
const attributionDiv = document.getElementById("attribution-div");
const service = new google.maps.places.PlacesService(attributionDiv);
// Check status and display the first photo in an img element.
service.getDetails(request, (place, status) => {
if (
status === google.maps.places.PlacesServiceStatus.OK && place
) {
const photoImg = document.getElementById('image-container');
photoImg.src = place.photos[0].getUrl({maxHeight: 400});
}
});
}
PlacesService
'teki yazar atıfları
PlacesService
, gerekli yazar ilişkilendirmelerini yazarın Google profil sayfasına yönlendiren bir URL içeren html_attributions
dizesini döndürür. Aşağıdaki snippet'te, ilk fotoğraf sonucu için ilişkilendirme verilerinin alınması gösterilmektedir.
let attributionUrl = place.photos[0].html_attributions;
Daha fazla bilgi
Yer sınıfı (yeni)
Aşağıdaki snippet'te, görünen ad ve yer fotoğrafları dahil olmak üzere yer ayrıntılarını döndürmek için fetchFields()
yönteminin kullanımı gösterilmektedir.
Öncelikle bir yer kimliği kullanılarak yeni bir Place
nesnesi oluşturulur, ardından displayName
ve photos
alanlarının belirtildiği fetchFields()
çağrısı yapılır.
Ardından, ilk yerin fotoğrafı sayfada gösterilir. Place
sınıfı kullanılırken hizmet durumu otomatik olarak ele alındığından bu durumu kontrol etmeniz gerekmez.
async function getPhotos() {
// Use a place ID to create a new Place instance.
const place = new google.maps.places.Place({
id: 'ChIJydSuSkkUkFQRsqhB-cEtYnw', // Woodland Park Zoo, Seattle WA
});
// Call fetchFields, passing the needed data fields.
await place.fetchFields({ fields: ['displayName','photos'] });
console.log(place.displayName);
console.log(place.photos[0]);
// Add the first photo to an img element.
const photoImg = document.getElementById('image-container');
photoImg.src = place.photos[0].getURI({maxHeight: 400});
}
Place
sınıfındaki yazar ilişkilendirmeleri
Place
sınıfı, yazarın adını, yazarın Google profil sayfası için URI'yi ve yazarın profil fotoğrafı için URI'yi içeren bir AuthorAttribution
örneği olarak yazar ilişkilendirmelerini döndürür. Aşağıdaki snippet'te, ilk fotoğraf sonucu için ilişkilendirme verilerinin alınması gösterilmektedir.
let name = place.photos[0].authorAttributions[0].displayName;
let attributionUrl = place.photos[0].authorAttributions[0].uri;
let photoUrl = place.photos[0].authorAttributions[0].photoUri;