Route - Post Snap To Roads
A API Snap to Roads aceita dados de pontos GPS, representados como coordenadas de longitude e latitude, e gera pontos que se alinham com as estradas existentes em um mapa. Este processo, conhecido como "encaixar em estradas", produz uma série de objetos que traçam um caminho seguindo de perto a rede rodoviária. Os dados resultantes incluem nomes de estradas e seus respetivos limites de velocidade, pertinentes aos segmentos percorridos.
Além disso, a API Snap to Roads oferece um recurso de interpolação, que refina os pontos GPS para criar uma rota mais suave que adere à geometria da estrada. Essa funcionalidade é especialmente benéfica para o rastreamento de ativos e para melhorar a visualização de dados em aplicativos de mapeamento.
Important
Os pontos GPS devem estar a menos de 6 km uns dos outros.
Para obter informações sobre a disponibilidade de roteamento em países/regiões, consulte cobertura de roteamento do Azure Maps.
POST https://atlas.microsoft.com/route/snapToRoads?api-version=2025-01-01
Parâmetros do URI
| Name | Em | Necessário | Tipo | Description |
|---|---|---|---|---|
|
api-version
|
query | True |
string |
Número da versão da API do Azure Maps. |
Cabeçalho do Pedido
Media Types: "application/geo+json"
| Name | Necessário | Tipo | Description |
|---|---|---|---|
| x-ms-client-id |
string |
Indica a conta destinada a ser usada com o modelo de segurança Microsoft Entra ID. Essa ID exclusiva para a conta do Azure Maps pode ser obtida na API de Conta do plano de gerenciamento do Azure Maps. Para obter mais informações sobre como usar a segurança do Microsoft Entra ID no Azure Maps, consulte Gerenciar autenticação no Azure Maps. |
|
| Accept-Language |
string |
Idioma em que os resultados de roteamento devem ser retornados. Para obter mais informações, consulte Suporte de localização no Azure Maps. |
Corpo do Pedido
Media Types: "application/geo+json"
| Name | Necessário | Tipo | Description |
|---|---|---|---|
| features | True |
Um conjunto de pontos para encaixar na rede rodoviária. Você pode ter um mínimo de 2 pontos e máximo de 5000 pontos e os dois pontos consecutivos devem estar dentro de 6 km um do outro e uma distância total da estrada de até 100 quilômetros. Consulte RFC 7946 para obter detalhes sobre o formato GeoJSON.
|
|
| type | True |
Especifica o tipo de |
|
| includeSpeedLimit |
boolean |
Especifica se as informações de limite de velocidade para os pontos ajustados devem ser incluídas na resposta. A unidade está em quilômetros por hora. |
|
| interpolate |
boolean |
Especifica se os pontos adicionais devem ser retornados entre os pontos ajustados para concluir o caminho de rota completo que segue suavemente a geometria da estrada. Os pontos interpolados terão |
|
| travelMode |
Especifica o perfil de roteamento para ajustar os pontos. Se não for especificado, o modo padrão é "condução", que otimiza os pontos ajustados para rotas de condução. |
Respostas
| Name | Tipo | Description |
|---|---|---|
| 200 OK |
OK Media Types: "application/geo+json", "application/json" |
|
| Other Status Codes |
Ocorreu um erro inesperado. Media Types: "application/geo+json", "application/json" Cabeçalhos x-ms-error-code: string |
Segurança
AADToken
Estes são os Microsoft Entra OAuth 2.0 Flows. Quando emparelhado com controle de de acesso baseado em função do Azure, ele pode ser usado para controlar o acesso às APIs REST do Azure Maps. Os controles de acesso baseados em função do Azure são usados para designar o acesso a uma ou mais contas de recursos ou subrecursos do Azure Maps. Qualquer usuário, grupo ou entidade de serviço pode receber acesso por meio de uma função interna ou uma função personalizada composta por uma ou mais permissões para APIs REST do Azure Maps.
Para implementar cenários, recomendamos a visualização conceitos de autenticação. Em resumo, essa definição de segurança fornece uma solução para modelar aplicativos(s) por meio de objetos capazes de controle de acesso em APIs e escopos específicos.
Note
- Essa definição de segurança requer o uso do cabeçalho
x-ms-client-idpara indicar a qual recurso do Azure Maps o aplicativo está solicitando acesso. Isso pode ser adquirido na API de gerenciamento do Maps. - O
Authorization URLé específico para a instância de nuvem pública do Azure. As nuvens soberanas têm URLs de autorização exclusivas e configurações de ID do Microsoft Entra. - O controle de acesso baseado em função do Azure é configurado a partir do plano de gerenciamento do Azure por meio do portal do Azure, PowerShell, CLI, SDKs do Azure ou APIs REST.
- O uso do SDK da Web do Azure Maps permite a configuração baseada em configuração de um aplicativo para vários casos de uso.
- Para obter mais informações sobre a plataforma de identidade da Microsoft, consulte visão geral da plataforma de identidade da Microsoft.
Tipo:
oauth2
Fluxo:
implicit
URL de Autorização:
https://login.microsoftonline.com/common/oauth2/authorize
Âmbitos
| Name | Description |
|---|---|
| https://atlas.microsoft.com/.default | https://atlas.microsoft.com/.default |
subscription-key
Essa é uma chave compartilhada que é provisionada ao criar um de recursos do
Com essa chave, qualquer aplicativo está autorizado a acessar todas as APIs REST. Por outras palavras, estas podem atualmente ser tratadas como chaves mestras para a conta para a qual foram emitidas.
Para aplicativos expostos publicamente, nossa recomendação é usar o acesso de servidor para servidor das APIs REST do Azure Maps onde essa chave pode ser armazenada com segurança.
Tipo:
apiKey
Em:
header
SAS Token
Este é um token de assinatura de acesso compartilhado criado a partir da operação Listar SAS no de recursos do
Com esse token, qualquer aplicativo é autorizado a acessar com controles de acesso baseados em função do Azure e controle de grão fino para a expiração, taxa e região(ões) de uso para o token específico. Em outras palavras, o Token SAS pode ser usado para permitir que os aplicativos controlem o acesso de forma mais segura do que a chave compartilhada.
Para aplicativos expostos publicamente, nossa recomendação é configurar uma lista específica de origens permitidas no de recursos da conta do
Tipo:
apiKey
Em:
header
Exemplos
Successfully retrieve snap to roads points with additional parameters in the body
Pedido de amostra
POST https://atlas.microsoft.com/route/snapToRoads?api-version=2025-01-01
{
"type": "FeatureCollection",
"features": [
{
"type": "Feature",
"geometry": {
"coordinates": [
-122.336729,
47.590868
],
"type": "Point"
},
"properties": {}
},
{
"type": "Feature",
"geometry": {
"coordinates": [
-122.336042,
47.601604
],
"type": "Point"
},
"properties": {}
}
],
"includeSpeedLimit": true,
"travelMode": "driving"
}
Resposta da amostra
{
"type": "FeatureCollection",
"features": [
{
"type": "Feature",
"geometry": {
"coordinates": [
-122.336769,
47.590885
],
"type": "Point"
},
"properties": {
"inputIndex": 0,
"isInterpolated": false,
"name": "State Rte-99 N",
"speedLimitInKilometersPerHour": 80
}
},
{
"type": "Feature",
"geometry": {
"coordinates": [
-122.336008,
47.601609
],
"type": "Point"
},
"properties": {
"inputIndex": 1,
"isInterpolated": false,
"name": "State Rte-99 N",
"speedLimitInKilometersPerHour": 80
}
}
]
}
Definições
| Name | Description |
|---|---|
|
Features |
Especifica o tipo de |
|
Feature |
Especifica o tipo de |
|
Geo |
Um tipo de geometria |
|
Input |
Especifica o ajuste de entrada aos pontos de estrada.
|
|
Maps |
O detalhe do erro. |
|
Maps |
Resposta de erro comum para APIs do Azure Maps para retornar detalhes de erro para operações com falha. |
|
Maps |
Um objeto que contém informações mais específicas do que o objeto atual sobre o erro. |
|
Point |
O ponto de origem passou como um objeto
|
|
Snap |
Objeto de recurso GeoJSON que contém o objeto Geometry e propriedades adicionais da rota. |
|
Snap |
Ajuste às propriedades de Estradas. |
|
Snap |
Este objeto é o corpo da solicitação. |
|
Snap |
Este objeto é retornado de uma chamada bem-sucedida. |
|
Snap |
Especifica o perfil de roteamento para ajustar os pontos. Se não for especificado, o modo padrão é "condução", que otimiza os pontos ajustados para rotas de condução. |
FeaturesItemTypeEnum
Especifica o tipo de GeoJSON. O único tipo de objeto suportado é Feature. Para obter mais informações, consulte RFC 7946.
| Valor | Description |
|---|---|
| Feature |
Especifica o tipo de objeto |
FeatureTypeEnum
Especifica o tipo de GeoJSON. O único tipo de objeto suportado é FeatureCollection. Para obter mais informações, consulte RFC 7946.
| Valor | Description |
|---|---|
| FeatureCollection |
Especifica o tipo de objeto |
GeoJsonPoint
Um tipo de geometria GeoJSON Point válido. Consulte RFC 7946 para obter detalhes.
InputSnapToRoadsFeaturesItem
Especifica o ajuste de entrada aos pontos de estrada.
GeoJSON objeto de recurso e propriedades adicionais. Consulte RFC 7946 para obter detalhes.
| Name | Tipo | Description |
|---|---|---|
| geometry | GeoJsonPoint: |
Um tipo de geometria |
| properties |
object |
O objeto properties é necessário em um GeoJSON válido, mas pode estar vazio, já que os metadados não são usados para ajustar à estrada. |
| type |
Especifica o tipo de |
MapsErrorDetail
O detalhe do erro.
| Name | Tipo | Description |
|---|---|---|
| code |
string |
Um de um conjunto de códigos de erro definido pelo servidor. |
| details |
Uma matriz de detalhes sobre erros específicos que levaram a esse erro relatado. |
|
| innererror |
Um objeto que contém informações mais específicas do que o objeto atual sobre o erro. |
|
| message |
string |
Uma representação legível por humanos do erro. |
| target |
string |
O alvo do erro. |
MapsErrorResponse
Resposta de erro comum para APIs do Azure Maps para retornar detalhes de erro para operações com falha.
| Name | Tipo | Description |
|---|---|---|
| error |
O detalhe do erro. |
MapsInnerError
Um objeto que contém informações mais específicas do que o objeto atual sobre o erro.
| Name | Tipo | Description |
|---|---|---|
| code |
string |
O código de erro. |
| innererror |
Um objeto que contém informações mais específicas do que o objeto atual sobre o erro. |
PointGeometry
O ponto de origem passou como um objeto GeoJSON Geometry válido, a partir do qual o polígono de intervalo deve ser calculado. Consulte RFC 7946 para obter detalhes.
Note: A API encaixará o ponto de origem solicitado na rede rodoviária mais próxima e o usará para o cálculo do alcance. Ele será retornado como um ponto center na resposta.
| Name | Tipo | Description |
|---|---|---|
| coordinates |
number[] (double) |
Um |
| type |
string:
Point |
Especifica o tipo de geometria para o objeto |
SnapToRoadFeaturesItem
Objeto de recurso GeoJSON que contém o objeto Geometry e propriedades adicionais da rota.
| Name | Tipo | Description |
|---|---|---|
| bbox |
number[] (double) |
Uma área retangular na Terra definida como um objeto de caixa delimitadora. Os lados dos retângulos são definidos por valores de latitude e longitude. Para obter mais informações, consulte RFC 7946, Seção 5. Exemplo: "bbox": [-10.0, -10.0, 10.0, 10.0] |
| geometry | GeoJsonPoint: |
Um tipo de geometria |
| properties |
Ajuste às propriedades de Estradas. |
|
| type |
Especifica o tipo de |
SnapToRoadsFeatureProperties
Ajuste às propriedades de Estradas.
| Name | Tipo | Description |
|---|---|---|
| inputIndex |
integer (int64) |
Identifique o índice correspondente na lista original de pontos para cada ponto ajustado. Apenas os pontos ajustados retornarão índices e podem ser usados para distingui-los dos pontos interpolados. |
| isInterpolated |
boolean |
Identifique se este é o ponto interpolado. |
| name |
string |
Nome da estrada à qual o ponto está encaixado. |
| speedLimitInKilometersPerHour |
number (double) |
Limite de velocidade em quilômetros por hora. |
SnapToRoadsRequest
Este objeto é o corpo da solicitação.
| Name | Tipo | Default value | Description |
|---|---|---|---|
| features |
Um conjunto de pontos para encaixar na rede rodoviária. Você pode ter um mínimo de 2 pontos e máximo de 5000 pontos e os dois pontos consecutivos devem estar dentro de 6 km um do outro e uma distância total da estrada de até 100 quilômetros. Consulte RFC 7946 para obter detalhes sobre o formato GeoJSON.
|
||
| includeSpeedLimit |
boolean |
False |
Especifica se as informações de limite de velocidade para os pontos ajustados devem ser incluídas na resposta. A unidade está em quilômetros por hora. |
| interpolate |
boolean |
False |
Especifica se os pontos adicionais devem ser retornados entre os pontos ajustados para concluir o caminho de rota completo que segue suavemente a geometria da estrada. Os pontos interpolados terão |
| travelMode | driving |
Especifica o perfil de roteamento para ajustar os pontos. Se não for especificado, o modo padrão é "condução", que otimiza os pontos ajustados para rotas de condução. |
|
| type |
Especifica o tipo de |
SnapToRoadsResponse
Este objeto é retornado de uma chamada bem-sucedida.
| Name | Tipo | Description |
|---|---|---|
| features |
|
|
| type |
Especifica o tipo de |
SnapToRoadsTravelModeEnum
Especifica o perfil de roteamento para ajustar os pontos. Se não for especificado, o modo padrão é "condução", que otimiza os pontos ajustados para rotas de condução.
| Valor | Description |
|---|---|
| driving |
Os pontos são encaixados na estrada adequada para carros. |
| truck |
Os pontos são encaixados na estrada adequada para caminhão. |