Events 
The player instance emits events based on changes in playback state and progress. These events can be subscribed to using the on method of PlayerHandle.
Event Types (PlayerEvent) 
A type for the available event names.
typescript
type PlayerEvent =
  | "start"
  | "frame"
  | "pause"
  | "seek"
  | "finish"
  | "error";Event Payloads (PlayerEventMap) 
Type definitions for the callback function and its payload (arguments) corresponding to each event.
typescript
interface PlayerEventMap {
  start: () => void;
  frame: (payload: {
    trackId: string | number;
    pos: google.maps.LatLngLiteral;
    heading?: number;
    progress: number;
  }) => void;
  pause: () => void;
  seek: (payload: { timeMs: number }) => void;
  finish: () => void;
  error: (payload: { error: Error }) => void;
}Event Descriptions 
- start: Emitted when playback starts (when- playis called and playback actually begins).
- frame: Emitted just before each animation frame is drawn. The payload includes the current track ID, position, heading (if available), and overall progress.
- pause: Emitted when playback is paused (when- pauseis called).
- seek: Emitted when the playback position changes (when- seekis called). The payload includes the target time (milliseconds from the route start).
- finish: Emitted when playback completes to the end of the route.
- error: Emitted when an error occurs during processing. The payload includes the error object.
Event Subscription Example 
typescript
const player = createPlayer(options);
player.on('start', () => {
  console.log('Playback started');
});
player.on('frame', ({ trackId, pos, progress }) => {
  document.getElementById('progressBar').style.width = `${progress * 100}%`;
  console.log(`Track ${trackId} is at ${pos.lat}, ${pos.lng}`);
});
player.on('finish', () => {
  console.log('Playback finished');
});
player.on('error', ({ error }) => {
  console.error('Player error:', error);
});