Place Autocomplete (新版)

Autocomplete (新版) 服務是 iOS API, 會傳回地點建議以回應要求。在要求中指定 文字搜尋字串和控制搜尋區域的地理邊界。

自動完成 (新版) 服務可完全比對 輸入的字詞和子字串,解析地點名稱、地址和 + 代碼。因此,應用程式能以使用者的身分傳送查詢 以便即時提供地點建議。

地點建議是指地點,例如商家、地址和搜尋點。 興趣 (以指定輸入文字字串和搜尋區域為準)。

舉例來說,您可以使用輸入字串來呼叫 API,該字串包含部分 使用者輸入的字詞「Spagh」,並將搜尋區域限定為紐約市。 回應隨後會包含符合搜尋條件的地點建議清單 字串和搜尋區域,例如名為「巴西義大利麵」的餐廳 以及該地點的詳細資訊。

傳回的地點建議是為了呈現給使用者, 讓他們選取想去的地點您可以製作 Place Details (新增) 要求更多 任何傳回地點建議的相關資訊。

自動完成 (新版) 要求

呼叫 上的方法,建立 Autocomplete 要求 GMSPlaceClient。 您可以在 GMSAutocompleteRequest敬上 物件。回應會在 GMSAutocompletePlaceSuggestion敬上 物件。

必須提供 API 金鑰和 query 參數。您也可以加入 GMSAutocompleteSessionToken敬上 將要求與帳單工作階段建立關聯 GMSAutocompleteFilter 才能套用到結果

如要進一步瞭解必要和選用參數,請參閱本文件的參數一節

Swift

let token = GMSAutocompleteSessionToken()

let northWestBounds = CLLocationCoordinate2DMake(40.921628, -73.700051)
let southEastBounds = CLLocationCoordinate2DMake(40.477398, -74.259087)

let filter = GMSAutocompleteFilter()
filter.types = [kGMSPlaceTypeRestaurant]
filter.locationBias = GMSPlaceRectangularLocationOption(northWestBounds, southEastBounds)
    
let request = GMSAutocompleteRequest(query:"Spagh")
request.filter = filter
request.sessionToken = token

GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in
      if let error = error {
        print("Autocomplete error: \(error)")
        return
      }
      if let autocompleteResults = results {
        for result in autocompleteResults {
          print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))")
        }
      }
    })

Objective-C

CLLocationCoordinate2D northEast = CLLocationCoordinate2DMake(37.388162, -122.088137);
CLLocationCoordinate2D southWest = CLLocationCoordinate2DMake(37.395804, -122.077023);

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.types = @[ kGMSPlaceTypeRestaurant ];
filter.locationBias = GMSPlaceRectangularLocationOption(northEast, southWest);
GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"];
request.sessionToken = token;
request.filter = filter;

[[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){
  // Handle response
  for (GMSAutocompleteSuggestion *suggestion in results) {
    if (suggestion.placeSuggestion) {
      // Show place suggestion data.
    }
  }
}];

GooglePlacesSwift

let center = (37.3913916, -122.0879074)
let northEast = (37.388162, -122.088137)
let southWest = (37.395804, -122.077023)

let bias = RectangularCoordinateRegion(northEast: northEast, southWest: southWest)
let filter = AutocompleteFilter(types: [ .restaurant ], origin: center, coordinateRegionBias: bias)

let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", filter: filter)
switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) {
case .success(let autocompleteSuggestions):
  // Handle suggestions.
case .failure(let placesError):
  // Handle error.
}

自動完成 (新版) 回應

自動完成功能會傳回最多 5 個陣列 GMSAutocompleteSuggestion 執行個體。陣列包含:

  • placeID
  • types:此地點適用的類型。
  • distanceMeters:與起點的距離。
  • attributedFullText:使用者可理解的建議文字全文。
  • attributedPrimaryText:使用者可理解的建議主要文字。
  • attributedSecondaryText:使用者可理解的建議次要文字。
  • structuredFormat:特定名稱及能夠清楚辨識的文字,例如城市或 區域。

必要參數

查詢

要搜尋的文字字串。指定完整字詞和子字串,地點 名稱、地址和 Plus Codes。 自動完成 (新版) 服務會傳回候選相符項目 然後根據感知的關聯性排列結果。

選用參數

類型

地點只能包含「表格」類型的單一主要類型 A表格 B。 舉例來說,主要類型可能是 mexican_restaurantsteak_house

根據預設,API 會根據 input 參數傳回所有地點。 不論地點的主要類型值為何。限制結果 可轉換成主要類型或主要類型,方法是將 types 參數。

使用這個參數從 Table 表指定最多五個類型值 A表格 B:地點必須相符 要包含在回應中的其中一個指定主要類型值。

如有下列情況,要求遭到拒絕,並顯示 INVALID_REQUEST 錯誤:

  • 指定超過五個類型。
  • 指定了任何無法辨識的類型。

國家/地區

只加入指定區域清單中的結果,以陣列的形式指定 最多 15 個 ccTLD (「頂層」 網域」) 兩個字元的值如果省略,則系統不會對回應套用任何限制。 舉例來說,如要將區域範圍限制在德國和法國,請按照下列步驟操作:

Swift

let filter = GMSAutocompleteFilter()
filter.countries = ["DE", "FR"]

Objective-C

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.countries = @[ @"DE", @"FR" ];

GooglePlacesSwift

let filter = AutocompleteFilter(countries: ["DE", "FR"])
  

如果同時指定 locationRestrictioncountries,結果會是 找到這兩項設定的交集區域

inputOffset

以零為基礎的 Unicode 字元偏移值,指出遊標位置 input。遊標位置會影響傳回的預測查詢字串。如果 空白,預設為 input 的長度。

locationBias 或 locationRestriction

您可以指定 locationBiaslocationRestriction,但不能同時指定兩者 搜尋區域您可以將 locationRestriction 想成是指定 結果必須在範圍內,locationBias 則指定 結果必須位於該區域的附近。

  • locationBias 會指定要搜尋的區域。這個位置只是偏見 也就是說,系統會傳回指定位置附近的結果,包括 結果。

  • locationRestriction 會指定要搜尋的區域。不在 內的結果 不會傳回指定區域。

locationBiaslocationRestriction 區域指定為矩形 或以圓形顯示檔案

圓形是由中心點和半徑 (以公尺為單位) 所定義。半徑必須為 介於 0.0 到 50000.0 (含) 之間。預設值為 0.0。適用對象 locationRestriction,您必須將半徑設為大於 0.0 的值。 否則,要求不會傳回任何結果。

例如:

Swift

let center = CLLocationCoordinate2DMake(40.730610, -73.935242)
let radius = 1000.0

filter.locationBias = GMSPlaceCircularLocationOption(center, radius)

Objective-C

CLLocationCoordinate2D center = CLLocationCoordinate2DMake(40.730610, -73.935242);
radius = 1000.0;

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.locationBias = GMSPlaceCircularLocationOption(center, radius);

GooglePlacesSwift

let center = CLLocationCoordinate2DMake(40.477398, -74.259087)

let bias = CircularCoordinateRegion(center: center, radius: 1000.0)

let filter = AutocompleteFilter(coordinateRegionBias: bias)      
  

矩形是經緯度可視區域,以兩對角線表示 lowhigh 點對面。可視區域視為封閉區域 因此包含其邊界緯度範圍必須介於 -90 到 90 度 (含首尾),且經度邊界必須介於 -180 到 180 之間 度數 (含首尾):

  • 如果 low = high,可視區域是由該單點組成。
  • 如果 low.longitude >high.longitude,經度範圍會反轉 ( 可視區域會跨越 180 度經度線)。
  • 如果 low.longitude = -180 度,high.longitude= 180 度,則 可視區域包含所有經度。
  • 如果 low.longitude = 180 度,high.longitude = -180 度,則 經度範圍空白。

lowhigh 都必須填入,且代表方塊不得 並將空無一物。空白的可視區域會導致錯誤。

舉例來說,這個可視區域會完整涵蓋紐約市:

Swift

let high = CLLocationCoordinate2DMake(40.921628, -73.700051)
let low = CLLocationCoordinate2DMake(40.477398, -74.259087)

let filter = GMSAutocompleteFilter()
filter.locationBias = GMSPlaceRectangularLocationOption(high, low)

Objective-C

CLLocationCoordinate2D high = CLLocationCoordinate2DMake(40.477398, -74.259087);
CLLocationCoordinate2D low = CLLocationCoordinate2DMake(440.921628, -73.700051);

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.locationBias = GMSPlaceRectangularLocationOption(high, low);

GooglePlacesSwift

let northEast = CLLocationCoordinate2DMake(40.477398, -74.259087)
let southWest = CLLocationCoordinate2DMake(40.921628, -73.700051)

let filter = AutocompleteFilter(coordinateRegionBias: bias)
  

起源

計算與起點之間的直線距離 目的地 (傳回 distanceMeters)。省略這個值時 不會傳回直線距離。指定為緯度和 經度座標:

Swift

let filter = GMSAutocompleteFilter()
filter.origin =  CLLocation(latitude: 37.395804, longitude: -122.077023)
 

Objective-C

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];

filter.origin = [[CLLocation alloc] initWithLatitude:37.395804 longitude: -122.077023];

GooglePlacesSwift

let filter = AutocompleteFilter(origin: CLLocation(latitude: 37.395804, longitude: -122.077023))
  

regionCode

用於設定回應格式的區碼,以 ccTLD (「頂層」) 網域」) 兩個字元的值多數 ccTLD 代碼與 ISO 3166-1 代碼相同, 一些特殊的例外狀況舉例來說,英國的 ccTLD 是「uk」 (.co.uk),但 ISO 3166-1 代碼卻是「gb」(技術上來說,「 大不列顛暨北愛爾蘭聯合王國」)。

如果指定的區碼無效,API 就會傳回 INVALID_ARGUMENT 錯誤。這個參數會根據適用法律影響結果。

sessionToken

工作階段符記是使用者產生的字串,可追蹤 自動完成 (新) 呼叫做為「工作階段」。 自動完成 (新版) 會使用工作階段符記,將 查詢和選取階段,將使用者自動完成搜尋劃分為獨立的工作階段 做為帳單用途詳情請參閱工作階段 符記

自動完成 (新版) 範例

使用 locationRestriction 和 locationBias

自動完成功能 (新版) 預設採用 IP 自訂調整為 用於控制搜尋區域透過 IP 自訂調整,API 會使用 調整結果。您可以選擇使用 locationRestrictionlocationBias (非兩者) 可指定 搜尋區域

地點限制可用來指定要搜尋的區域。指定範圍以外的結果 。下例示範如何使用位置限制 請求請求以半徑為 5000 公尺的圓形地點限制 在舊金山:

Swift

let token = GMSAutocompleteSessionToken()

let center = CLLocationCoordinate2DMake(37.775061, -122.419400)
let radius = 5000.0

let filter = GMSAutocompleteFilter()
filter.locationRestriction = GMSPlaceCircularLocationOption(center, radius)
    
let request = GMSAutocompleteRequest(query:"Piz")
request.filter = filter
request.sessionToken = token

GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in
      if let error = error {
        print("Autocomplete error: \(error)")
        return
      }
      if let autocompleteResults = results {
        for result in autocompleteResults {
          print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))")
        }
      }
    })

Objective-C

CLLocationCoordinate2D center = CLLocationCoordinate2DMake(37.775061, -122.419400);
radius = 5000.0;

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.locationRestriction = GMSPlaceCircularLocationOption(center, radius);
GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"];
request.sessionToken = token;
request.filter = filter;

[[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArrayG<MSAutocompleteSuggestion * >* results, NSError * error){
  // Handle response
  for (GMSAutocompleteSuggestion *suggestion in results) {
    if (suggestion.placeSuggestion) {
      // Show place suggestion data.
    }
  }
}];

GooglePlacesSwift

let center = (37.775061, -122.419400)
let radius = 5000.0
let restriction = CircularCoordinateRegion(center: center, radius: radius)
let filter = AutocompleteFilter(coordinateRegionRestriction: restriction)
let token = AutocompleteSessionToken()

let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", sessionToken: token, filter: filter)
switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) {
case .success(let autocompleteSuggestions):
  for suggestion in autocompleteSuggestions {
    switch suggestion {
    case .place:
      // Show place suggestion data.
    }
  }
case .failure(let placesError):
  // Handle error.
}
  

使用位置自訂調整功能時,此位置會呈現偏誤。 可能會傳回指定位置,包括指定位置以外的結果 下一個範例將先前的要求變更為使用位置自訂調整的要求:

Swift

let token = GMSAutocompleteSessionToken()

let center = CLLocationCoordinate2DMake(37.775061, -122.419400)
let radius = 5000.0

let filter = GMSAutocompleteFilter()
filter.locationBias = GMSPlaceCircularLocationOption(center, radius)
    
let request = GMSAutocompleteRequest(query:"Piz")
request.filter = filter
request.sessionToken = token

GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in
      if let error = error {
        print("Autocomplete error: \(error)")
        return
      }
      if let autocompleteResults = results {
        for result in autocompleteResults {
          print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))")
        }
      }
    })

Objective-C

CLLocationCoordinate2D center = CLLocationCoordinate2DMake(37.775061, -122.419400);
radius = 5000.0;

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.locationBias = GMSPlaceCircularLocationOption(center, radius);
GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Sicilian piz"];
request.sessionToken = token;
request.filter = filter;

[[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){
  // Handle response
  for (GMSAutocompleteSuggestion *suggestion in results) {
    if (suggestion.placeSuggestion) {
      // Show place suggestion data.
    }
  }
}];

GooglePlacesSwift

let center = (37.775061, -122.419400)
let radius = 5000.0
let bias = CircularCoordinateRegion(center: center, radius: radius)
let filter = AutocompleteFilter(coordinateRegionBias: bias)
let token = AutocompleteSessionToken()

let autocompleteRequest = AutocompleteRequest(query: "Sicilian piz", sessionToken: token, filter: filter)
switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) {
case .success(let autocompleteSuggestions):
  for suggestion in autocompleteSuggestions {
    switch suggestion {
    case .place:
      // Show place suggestion data.
    }
  }
case .failure(let placesError):
  // Handle error.
}
  

使用類型

使用 types 參數,將要求的結果限制為 類型,如表格所示 A表格 B:您可以指定 最多包含五個值的陣列。如果省略,系統會傳回所有類型。

以下範例會指定「足球」這個查詢字串並使用類型 參數,將結果限制為類型建築物的結果 "sporting_goods_store":

Swift

let token = GMSAutocompleteSessionToken()

let filter = GMSAutocompleteFilter()
filter.types = ["sporting_goods_store"]
    
let request = GMSAutocompleteRequest(query:"Soccer")
request.filter = filter
request.sessionToken = token

GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in
      if let error = error {
        print("Autocomplete error: \(error)")
        return
      }
      if let autocompleteResults = results {
        for result in autocompleteResults {
          print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText))")
        }
      }
    })

Objective-C

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.types = @[ "sporting_goods_store" ];
GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Soccer"];
request.sessionToken = token;
request.filter = filter;

[[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArray<GMSAutocompleteSuggestion *> * results, NSError * error){
  // Handle response
  for (GMSAutocompleteSuggestion *suggestion in results) {
    if (suggestion.placeSuggestion) {
      // Show place suggestion data.
    }
  }
}];

GooglePlacesSwift

let filter = AutocompleteFilter(types: [ PlaceType(rawValue: "sporting_goods_store") ])
let token = AutocompleteSessionToken()

let autocompleteRequest = AutocompleteRequest(query: "Soccer", sessionToken: token, filter: filter)
switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) {
case .success(let autocompleteSuggestions):
  for suggestion in autocompleteSuggestions {
    switch suggestion {
    case .place:
      // Show place suggestion data.
    }
  }
case .failure(let placesError):
  // Handle error.
}
    

使用來源

在要求中加入 origin 參數時,指定 經緯度座標,API 會包含直線距離 傳送至回應中的目的地。回應會傳回 距離 distanceMeters

以下範例將起點設為舊金山的中心:

Swift

let token = GMSAutocompleteSessionToken()

let origin = CLLocation(latitude: 37.7749, longitude: -122.4194)

let filter = GMSAutocompleteFilter()

filter.origin =  origin
    
let request = GMSAutocompleteRequest(query:"Amoeba")
request.filter = filter
request.sessionToken = token

GMSPlacesClient.shared().fetchAutocompleteSuggestions(from: request, callback: { ( results, error ) in
      if let error = error {
        print("Autocomplete error: \(error)")
        return
      }
      if let autocompleteResults = results {
        for result in autocompleteResults {
          print("Result \(String(describing: result.placeSuggestion?.placeID)) with \(String(describing: result.placeSuggestion?.attributedFullText)) and distance: \(String(describing: result.placeSuggestion?.distanceMeters))")
        }
      }
    })

Objective-C

GMSAutocompleteFilter *filter = [[GMSAutocompleteFilter alloc] init];
filter.origin = [[CLLocation alloc] initWithLatitude:37.395804 longitude:-122.077023];
GMSAutocompleteRequest *request = [[GMSAutocompleteRequest alloc] initWithQuery:@"Amoeba"];
request.sessionToken = token;
request.filter = filter;

[[GMSPlacesClient sharedClient] fetchAutocompleteSuggestionsFromRequest:request callback:^(NSArrayG<MSAutocompleteSuggestion * >* results, NSError * error){
  // Handle response
  for (GMSAutocompleteSuggestion *suggestion in results) {
    if (suggestion.placeSuggestion) {
      // Show place suggestion data.
      }
    }
}];

GooglePlacesSwift

let filter = AutocompleteFilter(origin: CLLocation(latitude: 37.7749, longitude: -122.4194))
let token = AutocompleteSessionToken()

let autocompleteRequest = AutocompleteRequest(query: "Amoeba", sessionToken: token, filter: filter)
switch await placesClient.fetchAutocompleteSuggestions(with: autocompleteRequest) {
case .success(let autocompleteSuggestions):
  for suggestion in autocompleteSuggestions {
    switch suggestion {
    case .place:
      // Show place suggestion data.
    }
  }
case .failure(let placesError):
  // Handle error.
}
  

歸因

即使沒有 地圖。如要顯示地圖,則必須使用 Google 地圖。螢幕分享 來自 Autocomplete (新版) 服務的建議 不含地圖時,您必須加入顯示在搜尋結果旁的 Google 標誌 欄位/results。詳情請參閱顯示 Google 標誌及 出處