Creating a robot application

1. Creating a project

To create a robot application, we first create a standard Android project, then we will convert it to a robot application.

Step Action

From Android Studio, choose: File > New > New Project

Give a name to your application.

When prompted by the wizard, choose the Phone and Tablet option, and make sure Android 6.0 (Marshmallow) is selected as Minimum SDK.

Finish the wizard selecting the default choices for all remaining steps.

2. Creating a robot application

Now that you have created the Android project, let’s convert it into a robot application:

Step Action

Once the project is created, choose File > New > Robot Application.

Select the minimum Robot SDK version and the module to robotify. Then click OK.


Your project is now a robot application!

As a result, you should see the following changes:

  • The robotsdk.xml file has been added to the assets/robot directory.

    It contains the minimum Robot SDK version for your project (the one you have selected).

  • New tools are available in Tools > Pepper SDK and also in the toolbar: emulator Emulator and connect Connect.

    Use emulator to start a new robot emulator and connect to connect to a real robot.

  • The QiSDK dependency has been added to your module’s build.gradle file.

    It provides you all the functionalities to interact with Pepper.

  • A uses-feature tag has been added to your AndroidManifest.xml.

    It states that your application uses Pepper and will only be available for the robot tablet.

3. Implementing QiSDK & the Robot Life Cycle

We have configured a robot application, now it is time to let our code take the control of Pepper’s body.

Step Action

Register the MainActivity to the QiSDK, let say in the onCreate method:

protected void onCreate(Bundle savedInstanceState) {
    // Register the RobotLifecycleCallbacks to this Activity.
    QiSDK.register(this, this);

And then unregister it in the onDestroy method:

protected void onDestroy() {
    // Unregister the RobotLifecycleCallbacks for this Activity.
    QiSDK.unregister(this, this);

Tip: You could also use QiSDK.unregister(this) to unregister all the RobotLifecycleCallbacks for this Activity, just be careful not to inadvertently remove a callback that should stay registered.


In this first example, we recommend to register and unregister in the onCreate and onDestroy methods. It is not the only option we have.

For further details, see: Mastering Focus & Robot lifecycle.

Make your MainActivity class extends RobotActivity:

public class MainActivity extends RobotActivity

Why? This activity brings visual feedbacks such as a SpeechBar when a communication is running.

For further details, see: Mastering Focus & Robot lifecycle.

Make your MainActivity class implement the RobotLifecycleCallbacks interface:

public class MainActivity extends RobotActivity implements RobotLifecycleCallbacks

Why? This interface allows the RobotLifecycleCallbacks to know when the Activity to which it has registered, gains or loses the robot focus.

For further details, see: Mastering Focus & Robot lifecycle.

Override the onRobotFocusGained, onRobotFocusLost and onRobotFocusRefused methods:

public void onRobotFocusGained(QiContext qiContext) {
    // The robot focus is gained.

public void onRobotFocusLost() {
    // The robot focus is lost.

public void onRobotFocusRefused(String reason) {
    // The robot focus is refused.

Why? The onRobotFocusGained method is called when the related Activity gains the robot focus. When the focus is gained, we can, for instance, run various actions on the robot.

When the onRobotFocusLost method is called, the related Activity lost the focus and actions cannot be run on Pepper.


The onRobotFocusGained and onRobotFocusLost methods are executed on a background thread, so the UI thread will not be blocked when we will use the QiSDK synchronously.


That’s it! You have created your first robot application.

See now the next step: Running an application.