startSimulation static method
- Route route, {
- void onTextToSpeechInstruction(- String textInstruction
 
- void onWaypointReached(- Landmark landmark
 
- void onDestinationReached(- Landmark landmark
 
- void onRouteUpdated(- Route route
 
- void onBetterRouteDetected()?,
- void onBetterRouteRejected(- GemError reason
 
- void onBetterRouteInvalidated()?,
- void onSkipNextIntermediateDestinationDetected()?,
- void onTurnAround()?,
- void onError(- GemError error
 
- void onNotifyStatusChange(- NavigationStatus status
 
- void onRouteCalculationStarted()?,
- void onRouteCalculationCompleted(- GemError error
 
- double speedMultiplier = 1.0,
Starts a new simulation session.
Parameters
- 
IN onNavigationInstruction Callback called when the navigation instruction is updated. This callback also sends turn update events. - instruction NavigationInstruction The updated navigation instruction
- events Set<NavigationInstructionUpdateEvents> The events that triggered the update
 
- 
IN onTextToSpeechInstruction Callback called when a sound needs to be played. - textInstruction String The instruction text to be spoken.
 
- 
IN onWaypointReached Callback called when a waypoint on the route has been reached. This callback is not called when the destination of the route has been reached. That is notified through onDestinationReachednotification.- landmark Landmark The landmark that was reached.
 
- 
IN onDestinationReached Callback called when the destination has been reached. This is the moment when the navigation request finished with success. - landmark Landmark The landmark that was reached.
 
- 
IN onRouteUpdated Callback called when route was updated. - route Route The updated route.
 
- 
IN onBetterRouteDetected Better route was detected. The previous better route ( if it exists ) must be considered automatically invalidated. This callback is called when a route is calculated with 'avoid traffic' flag set to 'true' (RoutePreferences.avoidTraffic) and the engine detects a better route. 
- 
IN onBetterRouteRejected Better route rejected with given error code ( debug purposes ) - errorCode GemError Rejection reason
 
- 
IN onBetterRouteInvalidated Previously detected better route became invalid. This callback is called when current position is no longer on the previously calculated better route 
- 
IN onError Callback called when an error occurs. - error GemError The error code.
 
- 
IN onNotifyStatusChange Callback to notify UI if the navigation status has changed. - status NavigationStatus The navigation status.
 
- 
IN onSkipNextIntermediateDestinationDetected Next intermediate destination skip intention detected. This notification is sent the navigation engine detects user intention to skip the next intermediate destination 
- 
IN onTurnAround Turn around callback. This callback is called after a navigation route recalculation, if the new route is heading on the opposite user travel direction 
- 
IN onNavigationStarted Navigation started callback. This callback is called when first valid position for navigation arrives 
- 
IN speedMultiplier Speed multiplier. The route simulation speed multiplier. Accepted values are in the interval simulationMinSpeedMultiplier - simulationMaxSpeedMultiplier. If set to 1.f the simulation speed is the speed limit of the traveled links 
- 
IN onRouteCalculationStarted Route calculation started callback. This callback is called when a route calculation is started. 
- 
IN onRouteCalculationCompleted Route calculation completed callback. This callback is called when a route calculation is completed. If the route calculation failed, the error code is provided. See the errors returned by RoutingService.calculateRoute for possible error codes. 
Implementation
static TaskHandler? startSimulation(
  final Route route, {
  final void Function(
    NavigationInstruction instruction,
    Set<NavigationInstructionUpdateEvents> events,
  )?
  onNavigationInstruction,
  final void Function()? onNavigationStarted,
  final void Function(String textInstruction)? onTextToSpeechInstruction,
  final void Function(Landmark landmark)? onWaypointReached,
  final void Function(Landmark landmark)? onDestinationReached,
  final void Function(Route route)? onRouteUpdated,
  final void Function(Route route, int travelTime, int delay, int timeGain)?
  onBetterRouteDetected,
  final void Function(GemError reason)? onBetterRouteRejected,
  final void Function()? onBetterRouteInvalidated,
  final void Function()? onSkipNextIntermediateDestinationDetected,
  final void Function()? onTurnAround,
  final void Function(GemError error)? onError,
  final void Function(NavigationStatus status)? onNotifyStatusChange,
  final void Function()? onRouteCalculationStarted,
  final void Function(GemError error)? onRouteCalculationCompleted,
  final double speedMultiplier = 1.0,
}) {
  final OperationResult result = staticMethod(
    'NavigationService',
    'startNavigation',
    args: <String, dynamic>{
      'route': route.pointerId,
      'simulation': true,
      'speedMultiplier': speedMultiplier,
    },
  );
  final int gemApiError = result['gemApiError'];
  if (GemErrorExtension.isErrorCode(gemApiError)) {
    final GemError errorCode = GemErrorExtension.fromCode(gemApiError);
    onError?.call(errorCode);
    return null;
  }
  final int listenerId = result['result'];
  final NavigationListener listener = NavigationListener.init(listenerId);
  listener.registerAll(
    onNavigationStarted: onNavigationStarted,
    onNavigationInstructionUpdated:
        (
          final NavigationInstruction instruction,
          final Set<NavigationInstructionUpdateEvents> events,
        ) {
          onNavigationInstruction?.call(instruction, events);
        },
    onWaypointReached: onWaypointReached,
    onDestinationReached: (final Landmark destination) {
      onDestinationReached?.call(destination);
    },
    onNavigationError: (final GemError error) {
      GemKitPlatform.instance.unregisterEventHandler(listener.id);
      onError?.call(error);
    },
    onRouteUpdated: onRouteUpdated,
    onNavigationSound: onTextToSpeechInstruction,
    onNotifyStatusChange: onNotifyStatusChange,
    onBetterRouteDetected: onBetterRouteDetected,
    onBetterRouteRejected: onBetterRouteRejected,
    onBetterRouteInvalidated: onBetterRouteInvalidated,
    onSkipNextIntermediateDestinationDetected:
        onSkipNextIntermediateDestinationDetected,
    onTurnAround: onTurnAround,
    onRouteCalculationStarted: onRouteCalculationStarted,
    onRouteCalculationCompleted: onRouteCalculationCompleted,
  );
  GemKitPlatform.instance.registerEventHandler(listener.id, listener);
  return TaskHandlerImpl(listener.id);
}