Personalizar polilinhas do trajeto

Selecione a plataforma: Android iOS JavaScript

Você pode personalizar as polilinhas do trajeto usando o ConsumerMapStyle.setPolylineStyleOptions. Se você definir uma polilinha personalizada elas substituem os valores padrão fornecidos pelo SDK do consumidor.

Para restaurar os valores padrão, chame setPolylineStyleOptions com null para o parâmetro PolylineOptions.

Para extrair o PolylineOptions ativo, use getPolylineStyleOptions.

Para saber mais, consulte ConsumerMapStyle.setPolylineStyleOptions.

Tipos de polilinha de trajeto

Você pode personalizar os seguintes tipos de polilinha de trajeto:

  • ACTIVE_ROUTE
  • REMAINING_ROUTE

ACTIVE_ROUTE e REMAINING_ROUTE são exibidos durante o compartilhamento da viagem e representar o trajeto do veículo.

Propriedades da polilinha do trajeto

O Google Maps fornece propriedades personalizáveis disponíveis para cada polilinha em PolylineOptions:

  • Para criar PolylineOptions, use o construtor.

  • Para especificar propriedades personalizadas, use "Setter" métodos de estilo. Como o método fornecer valores padrão para cada propriedade, você só precisará para especificar valores personalizados.

  • Para desativar a polilinha, defina visible como false.

Para mais detalhes, consulte PolylineOptions na documentação do desenvolvedor Android.

Exemplo

Java

// Initializing polyline style options.
consumerController
    .getConsumerMapStyle()
    .addOnSuccessListener(
        consumerMapStyle -> {
          consumerMapStyle.setPolylineStyleOptions(
              PolylineType.ACTIVE_ROUTE,
              new PolylineOptions()
                  .visible(false));
        });

// Reset polyline options to default values.
consumerMapStyle.setPolylineStyleOptions(PolylineType.ACTIVE_ROUTE, null);

Kotlin

// Initializing polyline options.
consumerController
  .getConsumerMapStyle()
  .addOnSuccessListener({ consumerMapStyle ->
    consumerMapStyle.setPolylineStyleOptions(
      PolylineType.ACTIVE_ROUTE,
      PolylineOptions().visible(false)
    )
  })

// Reset polyline options to default values.
consumerMapStyle.setPolylineStyleOptions(PolylineType.ACTIVE_ROUTE, null)

Trajeto ativo e restante

Com o compartilhamento da jornada ativado, seu aplicativo pode personalizar o do usuário usando polilinhas para mostrar o ativo e o restante trajeto para seu veículo.

  • O trajeto ativo é o caminho que o veículo percorre no momento o próximo ponto de referência na viagem ativa do consumidor.

  • O trajeto restante é o caminho que o veículo ainda precisa percorrer a rota ativa. Quando o waypoint da rota ativa é o último waypoint da viagem, a rota restante não existe.

Você pode personalizar e controlar a visibilidade das polilinhas ativas e restantes no seu app. Por padrão, a rota ativa fica visível, e o restante não está visível.

Exemplo

Java

// Initializing polyline options.
consumerController
    .getConsumerMapStyle()
    .addOnSuccessListener(
        consumerMapStyle -> {
          consumerMapStyle.setPolylineStyleOptions(
              PolylineType.ACTIVE_ROUTE,
              new PolylineOptions()
                  .color(Color.BLUE));
          consumerMapStyle.setPolylineStyleOptions(
              PolylineType.REMAINING_ROUTE,
              new PolylineOptions()
                  .color(Color.BLACK)
                  .width(5)
                  .visible(true));
        });

// Reset polyline options to default values.
consumerMapStyle.setPolylineStyleOptions(PolylineType.ACTIVE_ROUTE, null);
consumerMapStyle.setPolylineStyleOptions(PolylineType.REMAINING_ROUTE, null);

Kotlin

// Initializing polyline options.
consumerController
  .getConsumerMapStyle()
  .addOnSuccessListener({ consumerMapStyle ->
    {
      consumerMapStyle.setPolylineStyleOptions(
        PolylineType.ACTIVE_ROUTE,
        PolylineOptions().color(Color.BLUE)
      )

      consumerMapStyle.setPolylineStyleOptions(
        PolylineType.REMAINING_ROUTE,
        PolylineOptions().color(Color.BLACK).width(5).visible(true)
      )
    }
  })

// Reset polyline options to default values.
consumerMapStyle.setPolylineStyleOptions(PolylineType.ACTIVE_ROUTE, null)

consumerMapStyle.setPolylineStyleOptions(PolylineType.REMAINING_ROUTE, null)

Polilinhas com reconhecimento de tráfego

A camada de trânsito da polilinha fica desativada por padrão. Ao ativá-lo, o renderizador desenha segmentos acima da polilinha do trajeto que representam trechos de tráfego fora do normal. Ele inclui uma compensação dependendo da condição de tráfego. Consulte a documentação do desenvolvedor Android sobre polilinha para mais informações.

Os mapas do Google representam as condições de trânsito quatro tipos de velocidade. Você pode personalizar a cor de cada tipo de velocidade.

Para ativar polilinhas com reconhecimento de tráfego, crie um objeto TrafficStyle e, em seguida, transmita-o para ConsumerMapStyle chamando setPolylineTrafficStyle().

Exemplo

Java

// TrafficStyle is part of the Consumer SDK.
TrafficStyle trafficStyle = TrafficStyle.builder()
  .setTrafficVisibility(true)
  .setTrafficColor(SpeedType.NO_DATA, Color.GREY)
  .setTrafficColor(SpeedType.NORMAL_VALUE, Color.BLUE)
  .setTrafficColor(SpeedType.SLOW_VALUE, Color.ORANGE)
  .setTrafficColor(SpeedType.TRAFFIC_JAM, Color.RED)
  .build();

consumerMapStyle.setPolylineTrafficStyle(PolylineType.ACTIVE_ROUTE, trafficStyle);

Kotlin

// TrafficStyle is part of the Consumer SDK.
val trafficStyle =
  TrafficStyle.builder()
    .setTrafficVisibility(true)
    .setTrafficColor(SpeedType.NO_DATA, Color.GREY)
    .setTrafficColor(SpeedType.NORMAL_VALUE, Color.BLUE)
    .setTrafficColor(SpeedType.SLOW_VALUE, Color.ORANGE)
    .setTrafficColor(SpeedType.TRAFFIC_JAM, Color.RED)
    .build()

consumerMapStyle.setPolylineTrafficStyle(PolylineType.ACTIVE_ROUTE, trafficStyle)