Partilhar via


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

InputSnapToRoadsFeaturesItem[]

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.

Note: A API não retornará um objeto de ponto na resposta para o ponto GPS que não pode ser ajustado a uma rede rodoviária.

type True

FeatureTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é FeatureCollection. Para obter mais informações, consulte RFC 7946.

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 isInterpolate:true na resposta que podem ser usados para identificar os pontos encaixados a partir de pontos interpolados.

travelMode

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.

Respostas

Name Tipo Description
200 OK

SnapToRoadsResponse

OK

Media Types: "application/geo+json", "application/json"

Other Status Codes

MapsErrorResponse

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-id para 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 Azure Maps por meio do plano de gerenciamento do Azure por meio do portal do Azure, PowerShell, CLI, SDKs do Azure ou APIs REST.

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 Azure Maps por meio do plano de gerenciamento do Azure por meio do portal do Azure, PowerShell, CLI, SDKs do Azure ou APIs REST.

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 Map para limitar o abuso de renderização e renovar regularmente o Token SAS.

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
FeaturesItemTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é Feature. Para obter mais informações, consulte RFC 7946.

FeatureTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é FeatureCollection. Para obter mais informações, consulte RFC 7946.

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.

MapsErrorDetail

O detalhe do erro.

MapsErrorResponse

Resposta de erro comum para APIs do Azure Maps para retornar detalhes de erro para operações com falha.

MapsInnerError

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.

SnapToRoadFeaturesItem

Objeto de recurso GeoJSON que contém o objeto Geometry e propriedades adicionais da rota.

SnapToRoadsFeatureProperties

Ajuste às propriedades de Estradas.

SnapToRoadsRequest

Este objeto é o corpo da solicitação.

SnapToRoadsResponse

Este objeto é retornado de uma chamada bem-sucedida.

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.

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 GeoJSON Feature.

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 GeoJSONFeatureCollection.

GeoJsonPoint

Um tipo de geometria GeoJSON Point válido. Consulte RFC 7946 para obter detalhes.

Name Tipo Description
coordinates

number[] (double)

Um Position é uma matriz de números com dois ou mais elementos. Os dois primeiros elementos são longitude e latitude, precisamente nesta ordem. de Altitude/Elevação é um terceiro elemento opcional. Consulte RFC 7946 para obter detalhes.

type string:

Point

Especifica o tipo de GeoJSON. Deve ser um dos nove tipos de objeto GeoJSON válidos - Point, MultiPoint, LineString, MultiLineString, Polygon, MultiPolygon, GeometryCollection, Feature e FeatureCollection.

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:

PointGeometry

Um tipo de geometria GeoJSON Point válido. Consulte RFC 7946 para obter detalhes.

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

FeaturesItemTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é Feature. Para obter mais informações, consulte RFC 7946.

MapsErrorDetail

O detalhe do erro.

Name Tipo Description
code

string

Um de um conjunto de códigos de erro definido pelo servidor.

details

MapsErrorDetail[]

Uma matriz de detalhes sobre erros específicos que levaram a esse erro relatado.

innererror

MapsInnerError

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

MapsErrorDetail

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

MapsInnerError

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 Position é uma matriz de números com dois ou mais elementos. Os dois primeiros elementos são longitude e latitude, precisamente nesta ordem. de Altitude/Elevação é um terceiro elemento opcional. Consulte RFC 7946 para obter detalhes.

type string:

Point

Especifica o tipo de geometria para o objeto GeoJSON Geometry. Para obter mais informações, consulte RFC 7946.

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:

PointGeometry

Um tipo de geometria GeoJSON Point válido. Consulte RFC 7946 para obter detalhes.

properties

SnapToRoadsFeatureProperties

Ajuste às propriedades de Estradas.

type

FeaturesItemTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é Feature. Para obter mais informações, consulte RFC 7946.

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

InputSnapToRoadsFeaturesItem[]

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.

Note: A API não retornará um objeto de ponto na resposta para o ponto GPS que não pode ser ajustado a uma rede rodoviária.

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 isInterpolate:true na resposta que podem ser usados para identificar os pontos encaixados a partir de pontos interpolados.

travelMode

SnapToRoadsTravelModeEnum

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

FeatureTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é FeatureCollection. Para obter mais informações, consulte RFC 7946.

SnapToRoadsResponse

Este objeto é retornado de uma chamada bem-sucedida.

Name Tipo Description
features

SnapToRoadFeaturesItem[]

GeoJSON objeto de recurso que contém o objeto Geometry e propriedades adicionais. Consulte RFC 7946, Seção 3.2 para obter detalhes.

type

FeatureTypeEnum

Especifica o tipo de GeoJSON. O único tipo de objeto suportado é FeatureCollection. Para obter mais informações, consulte RFC 7946.

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.