Bermigrasi ke Place Details (Baru)

Places SDK for iOS mendukung Place Details yang sudah ada. Jika Anda sudah terbiasa dengan Places SDK for iOS yang sudah ada, Place Details versi baru akan membuat perubahan berikut:

  • Menggunakan model penetapan harga baru. Guna mendapatkan informasi harga untuk semua API, lihat Harga untuk Places SDK for iOS (Baru).

  • Penyamaran kolom wajib diisi. Anda harus menentukan kolom yang ingin ditampilkan dalam respons. Tidak ada daftar default untuk kolom yang ditampilkan. Jika Anda menghapus daftar ini, metode akan menampilkan error.

  • Untuk membuat permintaan, panggil metode GMSPlacesClient fetchPlaceWithRequest: baru.

  • Meneruskan permintaan:

  • Respons akan berisi instance GMSPlace yang berisi detail tentang tempat. Nilai dalam properti types dari instance GMSPlace sekarang ditentukan oleh Tabel A dan Tabel B.

  • Instance GMSPlace respons berisi properti reviews baru dari jenis GMSPlaceReview. Saat aplikasi Anda menampilkan informasi yang diperoleh dari instance GMSPlace, seperti foto dan ulasan, aplikasi juga harus menampilkan atribusi yang diperlukan.

    Untuk mengetahui informasi selengkapnya, lihat dokumentasi tentang atribusi.

  • Instance GMSPlace respons berisi fungsi anggota berikut:

    • isOpen menghitung apakah suatu tempat buka pada waktu tertentu.

    • isOpenAtDate menghitung apakah tempat buka pada tanggal tertentu.

    Fungsi ini hanya tersedia jika Anda mengaktifkan Places SDK for iOS. Fitur tersebut tidak tersedia saat Anda mengaktifkan Places SDK for iOS (Baru). Untuk informasi selengkapnya, lihat Memilih versi SDK Anda.

Contoh permintaan

Dengan Place Details (Baru), Anda membuat permintaan dan meneruskan semua parameter dalam instance GMSFetchPlaceRequest. Contoh ini juga menggunakan mask kolom sehingga respons hanya menyertakan nama tampilan dan URL situs untuk tempat tersebut:

Swift

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

// Specify the place data types to return.
let fields: [GMSPlaceProperty] = [.name, .website]

// Create the GMSFetchPlaceRequest instance.
let fetchPlaceRequest = GMSFetchPlaceRequest(placeID: placeID, placeProperties: fields)

client.fetchPlaceWithRequest(fetchPlaceRequest: fetchPlaceRequest, callback: {
  (place: GMSPlace?, error: Error?) in
  guard let place, error == nil else { return }
  print("Place found: \(place.name)")
})

Objective-C

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

// Specify the place data types to return.
NSArray<GMSPlaceProperty *> *fields = @[GMSPlacePropertyName, GMSPlacePropertyWebsite];

// Create the GMSFetchPlaceRequest instance.
GMSFetchPlaceRequest *fetchPlaceRequest = [[GMSFetchPlaceRequest alloc] initWithPlaceID:placeID placeProperties: fields];

[placesClient fetchPlaceWithRequest: fetchPlaceRequest, callback: ^(GMSPlace *_Nullable place, NSError *_Nullable error) {
  if (error == null) {
    NSLog(@"Place Found: %@", place.name);
  }
}];