目前位置

選取平台: Android iOS

使用 Places SDK for Android,您可以在裝置目前回報的位置探索地點。地點包括當地商家、搜尋點和地理位置。

權限

如要使用程式庫,您不需要在應用程式資訊清單中宣告任何其他權限,因為程式庫會在資訊清單中宣告其使用的所有權限。不過,如果您的應用程式使用 PlacesClient.findCurrentPlace(),您必須在執行階段要求位置存取權

如果您的應用程式未使用 PlacesClient.findCurrentPlace(),請在資訊清單中新增以下內容,明確移除程式庫導入的 ACCESS_FINE_LOCATIONACCESS_COARSE_LOCATION 權限:

<manifest ... xmlns:tools="http://schemas.android.com/tools">
    ...
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" tools:node="remove"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" tools:node="remove"/>
    ...
</manifest>

進一步瞭解 權限,並考慮使用 EasyPermissions 開始使用。

取得目前位置

如要尋找裝置目前所在的當地商家或其他地點,請按照下列步驟操作:

  1. 呼叫 ContextCompat.checkSelfPermission 檢查使用者是否已授予裝置位置資訊的存取權。應用程式也必須加入程式碼,提示使用者授予權限及處理結果。詳情請參閱「要求應用程式權限」。
  2. 建立 FindCurrentPlaceRequest,傳遞 Place.FieldList,指定應用程式應要求的地點資料類型。
  3. 呼叫 PlacesClient.findCurrentPlace(),並傳遞您在上一個步驟中建立的 FindCurrentPlaceRequest
  4. FindCurrentPlaceResponse 取得 PlaceLikelihood 清單。

欄位會與 Place Search 結果相對應,並分為三種計費類別:「Basic」、「Contact」和「Atmosphere」。「Basic」欄位以基本費率計費,不會產生額外費用。「Contact」和「Atmosphere」欄位會以較高的費率計費。如要進一步瞭解地點資料要求的計費方式,請參閱「用量與計費」一文。

API 會在 Task 中傳回 FindCurrentPlaceResponseFindCurrentPlaceResponse 包含 PlaceLikelihood 物件清單,代表裝置可能的所在位置。每個地點的結果都包含正確資訊,可指出該地點是否位於正確位置。如果沒有與指定裝置位置相對應的已知地點,這份清單可能會顯示為空白。

您可以呼叫 PlaceLikelihood.getPlace() 擷取 Place 物件,呼叫 PlaceLikelihood.getLikelihood() 即可取得地點的可能性評分。值越大,代表地點比對成功的機率越高。

下列程式碼範例會擷取裝置最有可能的位置清單,並記錄每個地點的名稱和可能性。

Kotlin



// Use fields to define the data types to return.
val placeFields: List<Place.Field> = listOf(Place.Field.NAME)

// Use the builder to create a FindCurrentPlaceRequest.
val request: FindCurrentPlaceRequest = FindCurrentPlaceRequest.newInstance(placeFields)

// Call findCurrentPlace and handle the response (first check that the user has granted permission).
if (ContextCompat.checkSelfPermission(this, permission.ACCESS_FINE_LOCATION) ==
    PackageManager.PERMISSION_GRANTED) {

    val placeResponse = placesClient.findCurrentPlace(request)
    placeResponse.addOnCompleteListener { task ->
        if (task.isSuccessful) {
            val response = task.result
            for (placeLikelihood: PlaceLikelihood in response?.placeLikelihoods ?: emptyList()) {
                Log.i(
                    TAG,
                    "Place '${placeLikelihood.place.name}' has likelihood: ${placeLikelihood.likelihood}"
                )
            }
        } else {
            val exception = task.exception
            if (exception is ApiException) {
                Log.e(TAG, "Place not found: ${exception.statusCode}")
            }
        }
    }
} else {
    // A local method to request required permissions;
    // See https://developer.android.com/training/permissions/requesting
    getLocationPermission()
}

      

Java


// Use fields to define the data types to return.
List<Place.Field> placeFields = Collections.singletonList(Place.Field.NAME);

// Use the builder to create a FindCurrentPlaceRequest.
FindCurrentPlaceRequest request = FindCurrentPlaceRequest.newInstance(placeFields);

// Call findCurrentPlace and handle the response (first check that the user has granted permission).
if (ContextCompat.checkSelfPermission(this, ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
    Task<FindCurrentPlaceResponse> placeResponse = placesClient.findCurrentPlace(request);
    placeResponse.addOnCompleteListener(task -> {
        if (task.isSuccessful()){
            FindCurrentPlaceResponse response = task.getResult();
            for (PlaceLikelihood placeLikelihood : response.getPlaceLikelihoods()) {
                Log.i(TAG, String.format("Place '%s' has likelihood: %f",
                    placeLikelihood.getPlace().getName(),
                    placeLikelihood.getLikelihood()));
            }
        } else {
            Exception exception = task.getException();
            if (exception instanceof ApiException) {
                ApiException apiException = (ApiException) exception;
                Log.e(TAG, "Place not found: " + apiException.getStatusCode());
            }
        }
    });
} else {
    // A local method to request required permissions;
    // See https://developer.android.com/training/permissions/requesting
    getLocationPermission();
}

      

可能值相關注意事項:

  • 可能性是指針對單一要求,在傳回的地點清單中為地點最相符的結果,提供相對機率。您無法比較不同要求的可能性。
  • 可能性值介於 0.0 和 1.0 之間。

舉例來說,如要表示正確地點為地點 A 的可能性 55%,以及地點 B 的機率為 35%,則回應會有兩個成員,其中地點 A 的可能性是 0.55,而地點 B 的可能性是 0.35。

在應用程式中顯示歸因資訊

當應用程式顯示從 PlacesClient.findCurrentPlace() 取得的資訊時,應用程式也必須顯示作者資訊。請參閱作者資訊說明文件。