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
:
Elemento | Cor |
---|---|
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 { ... }