The Mobile API allows third party applications to obtain images produced by a Clarius Ultrasound Scanner in real time. It also supports sending user commands such as changing the imaging depth or taking a capture.
- Clarius Ultrasound Scanner
- Clarius App for Android
- A valid Mobile API license (managed per scanner)
Note: Virtual scanners are supported without a license since version 8.0.1.
https://clariusdev.github.io/mobileapi/reference/10.3.0
Starting with Clarius App version 9.4.0, the Mobile API is distributed as an Android package. The package is hosted in the GitHub Gradle registry which requires authentication (a GitHub account is needed).
-
Generate a GitHub Personal Access Token (PAT) with the
read:packages
scope. Refer to the GitHub documentation for instructions to generate tokens. -
Create a file
secrets.properties
in the project's root folder (which will be read by the Gradle build script) with the following content:// file /secrets.properties // do not put quotes (') around the values gpr.user=your_user_name gpr.token=personal_access_token_with_read_packages_scope
-
Alternatively, if the secrets file is missing, the build script will attempt to read the environment variables
GITHUB_ACTOR
andGITHUB_TOKEN
.
-
On your Android device, start the Clarius App and connect to your scanner.
-
Open this project in Android Studio and run the example application on your Android device.
-
Optional: run both applications in split screen, otherwise let the Clarius App run in the background.
-
In the example application, select Menu
⋮
>connect
to start receiving images.
Usage:
-
Function menu
∑
: configure imaging like depth, gain or ultrasound mode. -
Menu
⋮
>Ask *
: obtain imaging information, like the current depth or gain. -
Menu
⋮
>settings
: configure the image rendered by the Clarius App and sent over the API.
The Mobile API communicates with the Clarius App instead of the ultrasound scanner directly (as is the case when using the Cast API). Therefore, the Clarius App must be installed and running on the same Android device. The Clarius App takes care of connecting to the probe and pre-processing the images before serving them through the API.
flowchart LR
prb[Probe]
subgraph dev[Android Device]
3p[3rd Party App]
subgraph app[Clarius App]
api[Mobile API]
end
api-- Images -->3p
3p-- Commands -->api
end
prb-- Images/Wi-Fi -->app
On Android, the Mobile API is implemented as an Android Bound Service running in the Clarius App itself. Refer to the Android developer guide for details about bound services.
The interface to the bound service is provided by an Android Messenger.
Android Messengers allow interprocess communications (IPC) by exchanging Message
objects containing an action code and a payload.
The sequence of messages and their content constitute the communication protocol which is described below.
- The client binds to the service by calling
Context.bindService()
and receives the server'sIBinder
. ThisIBinder
is used to create a Messenger that can send messages to the server. - The client sends its own Messenger to the server in the
replyTo
field of aMessage
object with codeMSG_REGISTER_CLIENT
. This Messenger is used by the server to send messages to the client. - The client sends the image configuration to the server (
MSG_CONFIGURE_IMAGE
). - During operation, the server will send the image data to the client (
MSG_NEW_PROCESSED_IMAGE
) and other notable events such as button presses, freeze state, etc. - The client can request the execution of predefined functions such as "increase depth" or "capture image" (
MSG_USER_FN
).
All messages and their associated payload are described in the https://clariusdev.github.io/mobileapi repository.
The service operates only when the Clarius App is connected to a scanner with the appropriate license. Contact Clarius for licensing options: https://clarius.com/contact/.
However, the service accepts binding requests from clients even when no proper license is active to accommodate workflows where the license is removed for legitimate reasons, for example when a probe is disconnected to save battery. In this case, the service enters a restricted mode where it stops handling requests and sending updates, but will resume normal operation as soon as a licensed scanner is connected again.
The license check workflow is as follows:
- The client binds to the service
- The service starts and accepts the bind request, regardless of the license status
- Depending on the current license status:
- if active, the service operates normally: all client requests are handled and all updates are sent to the clients
- if inactive, the service enters restricted mode: no update is sent (except
MSG_LICENSE_UPDATE
) and no client request is handled (exceptMSG_REGISTER_CLIENT
andMSG_UNREGISTER_CLIENT
). The service will replyMSG_NO_LICENSE
to any other request
- If the license status changes during operation, the service sends
MSG_LICENSE_UPDATE
and changes its mode of operation:- if the license becomes inactive: the service clears the image configuration and enter restricted mode
- if the license becomes active: the service resumes normal operations, but the client must re-send the image configuration
Workflow to obtain raw data:
- Activate raw data acquisition on the probe, see https://github.com/clariusdev/raw for instructions
- Make a capture from the Clarius App or with
MSG_USER_FN
, this will trigger the following actions:- download the raw data and store it in the examination data
- clear the probe's buffer
- notify the client with
MSG_RAW_DATA_AVAILABLE
- In the client, send
MSG_COPY_RAW_DATA
to request a copy, include the following data:- the capture's identifier and
- and a writable URI where the archive will be written, refer to the Android developer guide for details about file sharing
- In the client, wait for the reply in message
MSG_RAW_DATA_COPIED