Configurar alertas do velocímetro

Quando a navegação está ativada e o modo de viagem está definido como carro, o SDK de navegação para iOS mostra um controle de limite de velocidade no canto inferior esquerdo do mapa que mostra o limite de velocidade atual. Se um motorista exceder o limite de velocidade, o controle se expande para mostrar um velocímetro ao lado da tela do limite de velocidade e aciona alertas quando a velocidade atinge um determinado limite.

Por padrão, o SDK do Navigation aciona um alerta de velocidade leve quando o motorista excede o limite em 5 mph (10 km/h) e muda a cor do texto do velocímetro para vermelho. Ele aciona um alerta de velocidade importante quando o motorista ultrapassa o limite em 10 km/h (ou 20 km/h) e muda a cor de fundo do velocímetro para vermelho.

É possível personalizar o limite para acionar os alertas e as cores de texto e de segundo plano exibidas no velocímetro. Você também pode usar o SDK do Navigation para disponibilizar as informações de velocidade do motorista. Por exemplo, você pode disponibilizar informações de velocidade aos operadores de transporte por aplicativo para ajudá-los a incentivar os motoristas a seguir o limite de velocidade e melhorar a segurança.

Como personalizar limites para alertas de velocidade

É possível personalizar o limite para alertas de velocidade secundários e principais como uma porcentagem acima do limite de velocidade atual. Também é possível especificar por quanto tempo o limite é excedido para que o mapa mostre o alerta.

O exemplo de código a seguir define o limite de um alerta de velocidade secundário como 5% acima do limite de velocidade e o limite de um alerta de velocidade principal como 10% acima do limite. Ela especifica que o mapa mostra um alerta depois que um limite é excedido por cinco segundos.

Swift

let minorSpeedAlertThresholdPercentage: CGFloat = 0.05 let
majorSpeedAlertThresholdPercentage: CGFloat = 0.1 let
severityUpgradeDurationSeconds: TimeInterval = 5

// Configure SpeedAlertOptions let mutableSpeedAlertOptions:
GMSNavigationMutableSpeedAlertOptions = GMSNavigationMutableSpeedAlertOptions()
 mutableSpeedAlertOptions.setSpeedAlertThresholdPercentage(minorSpeedAlertThresholdPercentage,
for: .minor)
mutableSpeedAlertOptions.setSpeedAlertThresholdPercentage(majorSpeedAlertThresholdPercentage,
for: .major) mutableSpeedAlertOptions.severityUpgradeDurationSeconds =
severityUpgradeDurationSeconds

// Set SpeedAlertOptions to Navigator. mapView.navigator?.speedAlertOptions =
mutableSpeedAlertOptions; mapView.navigator?.add(self); // Only needed if
listening to the delegate events.

Objective-C

static const CGFloat minorSpeedAlertThresholdPercentage = 0.05; static const
CGFloat majorSpeedAlertThresholdPercentage = 0.1; static const NSTimeInterval
severityUpgradeDurationSeconds = 5;

// Configure SpeedAlertOptions GMSNavigationMutableSpeedAlertOptions
*mutableSpeedAlertOptions = [[GMSNavigationMutableSpeedAlertOptions alloc]
init]; [mutableSpeedAlertOptions setSpeedAlertThresholdPercentage:
minorSpeedAlertThresholdPercentage
forSpeedAlertSeverity:GMSNavigationSpeedAlertSeverityMinor];
[mutableSpeedAlertOptions
setSpeedAlertThresholdPercentage:majorSpeedAlertThresholdPercentage
forSpeedAlertSeverity:GMSNavigationSpeedAlertSeverityMajor];
[mutableSpeedAlertOptions
setSeverityUpgradeDurationSeconds:severityUpgradeDurationSeconds];

// Set SpeedAlertOptions to Navigator. mapView.navigator.speedAlertOptions =
mutableSpeedAlertOptions; [mapView.navigator addListener:self]; // Only needed
if listening to the delegate events.

Personalizar a exibição dos alertas de velocidade do velocímetro

Você pode personalizar as cores da tela do velocímetro para cada nível de alerta.

A tabela abaixo mostra as cores padrão para alertas de velocidade na classe GMSNavigationSpeedometerUIOptions:

ElementoCor
MinorSpeedAlertBackgroundColorDayMode 0xffffff(branco)
MinorSpeedAlertBackgroundColorNightMode 0x000000
MinorSpeedAlertTextColorDayMode 0xd93025
MinorSpeedAlertTextColorNightMode 0xd93025
MajorSpeedAlertBackgroundColorDayMode 0xd93025
MajorSpeedAlertBackgroundColorNightMode 0xd93025
MajorSpeedAlertTextColorDayMode 0xffffff(branco)
MajorSpeedAlertTextColorNightMode 0xffffff(branco)

Você pode especificar a cor do texto e do plano de fundo do velocímetro para alertas de velocidade secundária e principal:

Swift

let mutableSpeedometerUIOptions: GMSNavigationMutableSpeedometerUIOptions =
GMSNavigationMutableSpeedometerUIOptions()
mutableSpeedometerUIOptions.setTextColor(minorSpeedAlertTextColor, for: .minor,
lightingMode: .normal)
mutableSpeedometerUIOptions.setTextColor(majorSpeedAlertTextColor, for: .major,
lightingMode: .normal)
mutableSpeedometerUIOptions.setBackgroundColor(minorSpeedAlertNightModeBackgroundColor,
for: .minor, lightingMode: .lowLight)
mutableSpeedometerUIOptions.setBackgroundColor(majorSpeedAlertDayModeBackgroundColor,
for: .major, lightingMode: .normal)

mapView.settings.speedometerUIOptions = mutableSpeedometerUIOptions

Objective-C

GMSNavigationMutableSpeedometerUIOptions *mutableSpeedometerUIOptions =
[[GMSNavigationMutableSpeedometerUIOptions alloc] init];
[mutableSpeedometerUIOptions setTextColor: minorSpeedAlertTextColor
forSpeedAlertSeverity: GMSNavigationSpeedAlertSeverityMinor lightingMode:
GMSNavigationLightingModeNormal]; [mutableSpeedometerUIOptions setTextColor:
majorSpeedAlertTextColor forSpeedAlertSeverity:
GMSNavigationSpeedAlertSeverityMajor lightingMode:
GMSNavigationLightingModeNormal]; [mutableSpeedometerUIOptions
setBackgroundColor: minorSpeedAlertNightModeBackgroundColor
forSpeedAlertSeverity: GMSNavigationSpeedAlertSeverityMinor lightingMode:
GMSNavigationLightingModeLowLight]; [mutableSpeedometerUIOptions
setBackgroundColor: majorSpeedAlertDayModeBackgroundColor forSpeedAlertSeverity:
GMSNavigationSpeedAlertSeverityMajor
lightingMode:GMSNavigationLightingModeNormal];

mapView.settings.speedometerUIOptions = mutableSpeedometerUIOptions;

Recebimento de informações de velocidade dos motoristas

Se o aplicativo exigir o compartilhamento de informações sobre a velocidade do motorista, você também poderá usar o SDK do Navigation para disponibilizar essas informações. Isso pode ser útil para aplicativos de transporte por aplicativo em que um operador queira monitorar o excesso de velocidade dos motoristas para melhorar a segurança.

Por exemplo, o exemplo abaixo compartilha informações de velocidade quando ela é uma porcentagem especificada acima do limite de velocidade:

Swift

// Listener method for sharing speed information when the speed exceeds the
speed limit by a specified percentage. #pragma mark GMSNavigatorListener func
navigator(_ navigator : GMSNavigator, didUpdateSpeedingPercentage
percentageAboveLimit : Float) { ... }

Objective-C

// Listener method listening to speeding feed. #pragma mark
GMSNavigatorListener - (void)navigator:(GMSNavigator *)navigator
didUpdateSpeedingPercentage:(float)percentageAboveLimit { ... }