Getting the current value of a drone state or setting#

In this example, we will be using the get_state() method to query the current value of the “maximum tilt” drone’s setting.

When the maximum tilt drone setting is changed by the controller (Olympe) with the MaxTilt() command message the drone sends the MaxTiltChanged() event message in response. Changing a drone setting will be demonstrated in the following example. Here, we’re just interested in getting the current drone setting.

When Olympe connects to a drone it also asks the drone to send back all its states and settings event messages. Olympe can later provide you with this information through the olympe.Drone.get_state() method. So if Olympe is connected to a drone, olympe.Drone.get_state() always returns the current drone state associated to an event message.

In this case, we will be passing the MaxTiltChanged() message to the olympe.Drone.get_state() method. This will return a dictionary of the MaxTiltChanged() event message which provides the following parameters:

MaxTiltChanged Parameters:
  • current (float) – Current max tilt

  • min (float) – Range min of tilt

  • max (float) – Range max of tilt

Note: Don’t be confused here, the “min” and “max” parameters are actually the minimum and the maximum values for the “maximum tilt” setting. Here, we are only interested in the “current” value of this setting.

Let’s get down to some practice! First, reset the simulation (sphinx-cli action -m world fwman world_reset_all in a terminal).

Create the following Python script somewhere in your home directory:

 1import olympe
 2import os
 3from olympe.messages.ardrone3.PilotingSettingsState import MaxTiltChanged
 5DRONE_IP = os.environ.get("DRONE_IP", "")
 8def test_maxtiltget():
 9    drone = olympe.Drone(DRONE_IP)
10    drone.connect()
11    print("Drone MaxTilt = ", drone.get_state(MaxTiltChanged)["current"])
12    drone.disconnect()
15if __name__ == "__main__":
16    test_maxtiltget()

To execute this script and see your drone taking off, from the same shell/terminal you’ve just source’d the shell script:

$ python ./

This should print the current maximum tilt value in your terminal. The following sequence diagram illustrate what is happening in this simple example.

blockdiag Olympe Drone also send all event messages get_state(MaxTiltChanged) connect connected disconnect disconnected

Getting the drone MaxTilt#