Expand Minimize Picture-in-picture Power Device Status Voice Recognition Skip Back Skip Forward Minus Plus Play Search
Internet Explorer alert
This browser is not recommended for use with smartdevicelink.com, and may not function properly. Upgrade to a different browser to guarantee support of all features.
close alert
To Top Created with Sketch. To Top
To Bottom Created with Sketch. To Bottom
HMI Documentation
Getting Started

Getting Started

Component Readiness Confirmation

The HMI must register each component which can communicate with SDL using the following format

var JSONMessage = {
            "jsonrpc": "2.0",
            "id": -1,
            "method": "MB.registerComponent",
            "params": {
                "componentName": "UI"
            }
        };

The possible componentNames are UI, Buttons, BasicCommunication, VR, TTS, Navigation, and VehicleInfo

Once the components are registered, the HMI must notify sdl that it is ready to begin further communication using the BasicCommunication.OnReady notification.

Upon receipt of the OnReady notification, SDL will begin checking the availablility of the different HMI components via a chain a requests:

  • UI.IsReady - The display availability
  • VR.IsReady - The voice recognition module availability
  • TTS.IsReady - The Text-To-Speech module availability
  • Navigation.IsReady - Navigation engine availability
  • VehicleInfo.IsReady - Indicates whether vehicle information can be collected and provided.

Registering for Notifications

The HMI must also register for notifications individually using the following RPC format

var obj = {
            "jsonrpc": "2.0",
            "id": -1,
            "method": "MB.subscribeTo",
            "params": {
                "propertyName": notificationName
            }
        }

Where propertyName is the name of the notification, such as Buttons.OnButtonSubscription

Must

The HMI must register its components, send the OnReady notification, respond to each of the IsReady RPCs, and register for the notifications it would like to receive.

Note

If the response to any of the component IsReady requests contains {"available": false}, SDL will no longer communicate with that component.

IsReady Sequence Diagram

Note

In the case of a WebSocket connection, the RPCs to each of the components is sent within each separate WebSocket connection.

View on GitHub.com
Previous Section Next Section