特定の施設やスポットに関する詳細情報をリクエストするには、そのプレイス ID を使用して、Place Details(新規)のリクエストを行います。場所の詳細(新規): 指定された場所に関するより包括的な情報(完全な住所、電話番号、ユーザー評価、レビューなど)を返します。
プレイス ID を取得する方法はいくつかあります。次を使用できます。
Place Details(新規)リクエスト
場所の詳細をリクエストするには、PlacesClient.fetchPlace()
を呼び出し、場所 ID とフィールドリスト、および省略可能なパラメータを含む FetchPlaceRequest
オブジェクトを渡します。
// Define a place ID.
final String placeId = "INSERT_PLACE_ID_HERE";
// Specify the list of fields to return.
final List<Place.Field> placeFields = Arrays.asList("INSERT_PLACE_FIELDS_HERE");
// Construct a request object, passing the place ID and field list.
final FetchPlaceRequest request = FetchPlaceRequest.newInstance(placeId, placeFields);
// Pass the request object and make the request
Task<FetchPlaceResponse> placeTask = placesClient.fetchPlace(request);
Place Details(新規)レスポンス
場所の詳細(新規)は、Place
オブジェクトの形式でデータを返します。このオブジェクトには、フィールドリストを使用してリクエストしたフィールドのみが含まれます。場所データの結果は空にできないため、データを含む場所の結果のみが返されます(たとえば、リクエストされた場所に写真がない場合、結果に写真フィールドは含まれません)。
データフィールドにアクセスするには、対応するメソッドを呼び出します。たとえば、地名にアクセスするには、getName()
を呼び出します。
必須パラメータ
FetchPlaceRequest
に必要なパラメータは次のとおりです。
-
プレイス ID
テキスト検索(新規)、周辺検索(新規)、自動入力(新規)から返される、場所を一意に識別するテキスト識別子。プレイス ID の詳細については、プレイス ID の概要をご覧ください。
-
フィールドリスト
場所をリクエストする際は、返す場所データを指定する必要があります。これを行うには、返されるデータを指定する
Place.Field
値のリストを渡します。レスポンスで返されるフィールドのデフォルト リストはありません。フィールドリストは、不要なデータをリクエストしないようにするための設計上のベスト プラクティスです。これにより、不要な処理時間と課金が発生するのを防ぐことができます。このリストは、各リクエストの費用に影響するため、重要な考慮事項です。詳細については、使用量と課金をご覧ください。
次のフィールドを 1 つ以上指定します。
次のフィールドは、Place Details(IDs Only)SKU をトリガーします。
Place.Field.DISPLAY_NAME
、Place.Field.ID
、Place.Field.PHOTO_METADATAS
、Place.Field.RESOURCE_NAME
、
次のフィールドは、Place Details (Location Only) SKU をトリガーします。
Place.Field.ADDRESS_COMPONENTS
、ADR_FORMAT_ADDRESS
、Place.Field.FORMATTED_ADDRESS
、Place.Field.LOCATION
、Place.Field.PLUS_CODE
、Place.Field.SHORT_FORMATTED_ADDRESS
、Place.Field.TYPES
、Place.Field.VIEWPORT
、
次のフィールドは、Place Details (Basic) SKU をトリガーします。
Place.Field.ACCESSIBILITY_OPTIONS
、Place.Field.BUSINESS_STATUS
、Place.Field.GOOGLE_MAPS_URI
、Place.Field.ICON_BACKGROUND_COLOR
、Place.Field.ICON_MASK_URL
、Place.Field.PRIMARY_TYPE
、Place.Field.PRIMARY_TYPE_DISPLAY_NAME
、Place.Field.SUB_DESTINATIONS
、Place.Field.UTC_OFFSET
、
次のフィールドは、Place Details (Advanced) SKU をトリガーします。
Place.Field.CURRENT_OPENING_HOURS
、Place.Field.CURRENT_SECONDARY_OPENING_HOURS
、Place.Field.INTERNATIONAL_PHONE_NUMBER
、Place.Field.NATIONAL_PHONE_NUMBER
、Place.Field.OPENING_HOURS
、Place.Field.PRICE_LEVEL
、Place.Field.RATING
、Place.Field.SECONDARY_OPENING_HOURS
、Place.Field.USER_RATING_COUNT
、Place.Field.WEBSITE_URI
、
次のフィールドは、Place Details (Preferred) SKU をトリガーします。
Place.Field.ALLOWS_DOGS
,Place.Field.CURBSIDE_PICKUP
,Place.Field.DELIVERY
,Place.Field.DINE_IN
,Place.Field.EDITORIAL_SUMMARY
,Place.Field.EV_CHARGE_OPTIONS
,Place.Field.FUEL_OPTIONS
,Place.Field.GOOD_FOR_CHILDREN
,Place.Field.GOOD_FOR_GROUPS
,Place.Field.GOOD_FOR_WATCHING_SPORTS
,Place.Field.LIVE_MUSIC
,Place.Field.MENU_FOR_CHILDREN
,Place.Field.OUTDOOR_SEATING
,Place.Field.PARKING_OPTIONS
,Place.Field.PAYMENT_OPTIONS
,Place.Field.RESERVABLE
,Place.Field.RESTROOM
,Place.Field.REVIEWS
,Place.Field.SERVES_BEER
,Place.Field.SERVES_BREAKFAST
,Place.Field.SERVES_BRUNCH
,Place.Field.SERVES_COCKTAILS
,Place.Field.SERVES_COFFEE
,Place.Field.SERVES_DESSERT
,Place.Field.SERVES_DINNER
,Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
オプション パラメータ
FetchPlaceRequest
のオプション パラメータは次のとおりです。
地域コード
レスポンスのフォーマットに使用される地域コード。 2 文字の CLDR コード値で指定します。デフォルト値はありません。
レスポンスの
Place.Field.FORMATTED_ADDRESS
フィールドの国名がregionCode
と一致する場合、Place.Field.FORMATTED_ADDRESS
から国コードが省略されます。ほとんどの CLDR コードは ISO 3166-1 コードと同一ですが、いくつか注意が必要な例外もあります。たとえば、英国の ccTLD は「uk」(.co.uk)ですが、ISO 3166-1 コードは「gb」です(技術的には「グレート ブリテンおよび北アイルランド連合王国」のエンティティ用)。このパラメータは、適用される法律に基づいて結果に影響する可能性があります。
地域コード パラメータを設定するには、
FetchPlaceRequest
オブジェクトを作成するときにsetRegionCode()
メソッドを呼び出します。-
セッション トークン
セッション トークンは、Autocomplete(新規)呼び出しを「セッション」として追跡するユーザー作成の文字列です。Autocomplete(新規)では、セッション トークンを使用して、ユーザーの Autocomplete 検索のクエリフェーズと場所選択フェーズを個別のセッションにグループ化し、課金の目的で使用します。セッション トークンは、Autocomplete(新規)呼び出しに続く Place Details(新規)呼び出しに渡されます。詳細については、セッション トークンをご覧ください。
セッション トークン パラメータを設定するには、
FetchPlaceRequest
オブジェクトを作成するときにsetSessionToken()
メソッドを呼び出します。
Place Details の例
次の例では、ニューヨーク市のエンパイア ステート ビルの ID
、DISPLAY_NAME
、FORMATTED_ADDRESS
フィールドをリクエストします。
// Define a place ID.
final String placeId = "ChIJaXQRs6lZwokRY6EFpJnhNNE";
// Specify the list of fields to return.
final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME, Place.Field.FORMATTED_ADDRESS);
// Construct a request object, passing the place ID and field list.
final FetchPlaceRequest request = FetchPlaceRequest.newInstance(placeId, placeFields);
// Pass the request object and make the request
Task<FetchPlaceResponse> placeTask = placesClient.fetchPlace(request);