Escolher os campos a serem retornados
Ao solicitar uma rota ou matriz de rotas, use uma máscara de campo para especificar quais informações a resposta deve retornar. Não há uma lista padrão de campos retornados. Se você não especificar uma máscara de campo, os métodos vão retornar um erro.
O uso de uma máscara de campo também garante que você não solicite dados desnecessários, o que ajuda com a latência de resposta e evita cobranças desnecessárias por informações que seu sistema não precisa.
Você especifica a lista dos campos necessários em uma máscara de campo de resposta. Em seguida, transmita
a máscara de campo de resposta para qualquer método usando o parâmetro de URL $fields
ou
fields
ou usando o cabeçalho HTTP ou gRPC X-Goog-FieldMask
.
Para mais informações sobre os parâmetros de URL, consulte Parâmetros do sistema.
Definir uma máscara de campo de resposta
A máscara de campo de resposta é uma lista de caminhos separados por vírgulas, em que cada caminho especifica um campo exclusivo na mensagem de resposta. O caminho começa na mensagem de resposta de nível superior e usa um caminho separado por ponto para o campo especificado.
Crie e especifique um caminho de campo da seguinte maneira:
- Encontre os campos que contêm as informações necessárias na API Routes. Para mais detalhes, consulte Referências de campo.
- Determine os caminhos dos campos necessários e crie as máscaras de campo para eles: para saber mais, consulte Determinar qual máscara de campo você quer usar.
Combine as máscaras de campo de todos os campos necessários, separando-as com vírgulas. Por exemplo, para solicitar o
distanceMeters
do trecho da rota e a duração de cada etapa do trecho, insira ambos, separados por vírgula, sem espaços:routes.legs.distanceMeters,routes.legs.steps.duration
Envie a máscara de campo com sua solicitação de API. Por exemplo, em uma solicitação cURL, você especificaria a máscara de campo com
-H
eX-Goog-FieldMask
:-H X-Goog-FieldMask: routes.legs.distanceMeters,routes.legs.steps.duration
Referências de campo
Para conferir os campos que podem ser solicitados em uma resposta usando máscaras de campo, consulte as referências da API Routes vinculadas na lista a seguir. Especifique os campos em letras maiúsculas e minúsculas, conforme mostrado na referência. Por exemplo, routePreference
.
Essas referências incluem os campos disponíveis. No entanto, você precisa consultar a hierarquia dos campos para determinar o caminho completo da máscara de campo. Para saber como acessar a hierarquia dos campos, consulte Determinar qual máscara de campo você quer usar.
- Máscara de campo de rota de computação
- Compute as máscaras de campo da matriz de rotas
- REST: especifica os campos do corpo da resposta a serem retornados.
- gRPC: especifica os campos do objeto RouteMatrixElement na resposta a ser retornada.
Determinar quais máscaras de campo usar
Veja como determinar quais campos você quer usar e criar as máscaras de campo para eles:
- Solicitar todos os campos usando uma máscara de campo de
*
. - Analise a hierarquia dos campos na resposta para encontrar os campos que você quer.
Crie as máscaras de campo usando a hierarquia dos campos mostrados na etapa anterior, usando este formato:
topLevelField[.secondLevelField][.thirdLevelField][...]
Por exemplo, para esta resposta parcial de uma rota:
"routes": [ { "legs": [ { "steps": [ {"distanceMeters": 119}, {"distanceMeters": 41} ] } ], "distanceMeters": 160 } ]
Se você quiser retornar apenas o campo distanceMeters
para o trecho da rota, ou seja, o último distanceMeters
no exemplo anterior, a máscara de campo será a seguinte:
routes.legs.distanceMeters
Se você quiser retornar o campo distanceMeters
para cada etapa do trecho do trajeto, ou seja, o distanceMeters
em steps
no exemplo anterior, a máscara de campo será a seguinte:
routes.legs.steps.distanceMeters
Se você quiser retornar os dois, com o resultado acima, a máscara de campo será a seguinte:
routes.legs.distanceMeters,routes.legs.steps.distanceMeters
Exemplos de caminhos de máscara de campo
Esta seção contém mais exemplos sobre como especificar um caminho de campo como parte de uma máscara de campo de resposta em chamadas REST e gRPC.
Chamada REST para computeRoutes
No primeiro exemplo, você usa uma chamada REST para o método
computeRoutes
para calcular
uma rota. Neste exemplo, no cabeçalho, você especifica máscaras de campo para retornar os campos distanceMeters
e duration
da rota na resposta. Adicione o prefixo routes
ao nome do campo.
X-Goog-FieldMask: routes.distanceMeters,routes.duration
Chamada REST para computeRouteMatrix
Para o método REST computeRouteMatrix
usado para calcular uma matriz de rotas, no cabeçalho, especifique para retornar
originIndex
, destinationIndex
e duration
para cada combinação de origem
e destino:
X-Goog-FieldMask: originIndex,destinationIndex,duration
Chamada gRPC
Para gRPC, defina uma variável que contenha a máscara de campo de resposta. Em seguida, é possível transmitir essa variável para a solicitação.
const ( fieldMask = "routes.distanceMeters,routes.duration,routes.polyline.encodedPolyline" )
Considerações sobre o caminho do campo
Inclua apenas os campos necessários na resposta para retornar apenas os campos necessários:
- Diminui os tempos de processamento, para que os resultados sejam retornados com uma latência menor.
- Garante um desempenho de latência estável. Se você selecionar todos os campos ou todos os campos no nível superior, poderá haver uma degradação no desempenho quando novos campos forem adicionados e incluídos automaticamente na resposta.
- Resulta em um tamanho de resposta menor, o que se traduz em maior capacidade de processamento da rede.
- Garante que você não solicite dados desnecessários, o que ajuda a evitar tempo de processamento e cobranças desnecessários.
Para mais detalhes sobre como criar uma máscara de campo, consulte o field_mask.proto.