Skip to main content

Asyncio-based control library for the Tello drone

Project description

tello-asyncio

A library for controlling and interacting with the Tello EDU drone using modern asynchronous Python. All operations are implemented as awaitable coroutines, completed when the drone sends acknowledgment of the command message.

Package tello-asyncio on PyPi.

$ pip3 install tello-asyncio
import asyncio
from tello_asyncio import Tello

async def main():
    drone = Tello()
    try:
        await drone.connect()
        await drone.takeoff()
        await drone.turn_clockwise(360)
        await drone.land()
    finally:
        await drone.disconnect()

asyncio.run(main())

See the examples directory for more usage example scripts.

Requires Python 3.6+. Developed and tested with Python 3.9.4 in Mac OS and 3.6.9 in Ubuntu 18.04 on a Jetson Nano. The tello_asyncio package has no other dependencies (and never will have any), but some examples need other things to be installed to work.

Full documentation is available on Read the docs

(If Rust is more your thing, there is also an equivalent aynchronous Rust library tello-edu)

Tello SDK Support

  • Tello SDK 2.0 (Tello EDU) - complete support
  • Tello SDK 3.0 (RoboMaster TT) - complete support, but EXT commands for controlling LEDs etc must be formatted by the user

A Note on Awaiting

The Tello SDK command/response model is a natural fit for the asynchronous python awaitable idea, but the drone will get confused if commands are sent before it's had a chance to respond. Each command should be awaited before sending the next.

It works best sequentially like this...

await drone.takeoff()
await drone.land()

...but not concurrently (which will not work as expected)

await asyncio.gather(
    drone.takeoff(), 
    drone.land()
)

Version History

1.0.0

Basic drone control

  • UDP connection for sending commands and receiving responses (default AP mode only - you must join the drone's own WiFi network)
  • take off and land
  • rotate clockwise and counter-clockwise
  • move up, down, left, right, forward and back

1.1.0

Drone state

  • listens for and parses UDP state messages (not yet including the mission pad related values)
  • access via the read only state object attribute, or via shortcuts like height, temperature etc
  • constructor takes an optional on_state callback argument for notification of new state
  • or use the asynchronous generator state_stream for an infinite stream of updates

1.2.0

Advanced drone control

  • flips
  • go/curve to relative position
  • emergency stop

Video

  • start/stop video stream
  • video url

Error handling

  • handles error command responses from drone

1.3.0

Complete SDK

  • mission pads
  • wifi
  • remote control

Video

  • raw video frame data via callback or async generator

Error handling

  • detects command/response mismatch

1.3.1

  • Documentation

1.3.2

1.4.0

  • Video frame data reassembled properly from UDP packet chunks
  • Working video frame decoding example

1.4.1

  • Video in OpenCV example

1.5.0

  • Python 3.6 support

1.6.0

  • Drone instance passed to state and video callbacks
  • Wait for WiFi network (Linux only)

2.0.0

  • Tello SDK 3.0 support

2.1.0

  • Wait for Wifi network implemented for macOS as well as Linux
  • Mission pad fixes & example improvement (thanks @jsolderitsch!)

2.1.1

  • Examples ask the user for the WiFi name prefix

2.1.2

  • Don't wait for a response from remote control (rc x x x x) commands

2.1.3

  • Various SDK 3.0 fixes (thanks @jdelfino!)
  • Handle "forced stop" message which arrives out of sequence

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tello_asyncio-2.1.3.tar.gz (23.0 kB view details)

Uploaded Source

Built Distribution

tello_asyncio-2.1.3-py3-none-any.whl (22.8 kB view details)

Uploaded Python 3

File details

Details for the file tello_asyncio-2.1.3.tar.gz.

File metadata

  • Download URL: tello_asyncio-2.1.3.tar.gz
  • Upload date:
  • Size: 23.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for tello_asyncio-2.1.3.tar.gz
Algorithm Hash digest
SHA256 3f4329a4c68023fd72785a50003b0c2251eece345190240205d1a96f37df0581
MD5 bed24841724676762fcbbc6b1517e4e0
BLAKE2b-256 eebb8cc68c0df4fc0b4b38c245992f7fc9fa889090dab4e80f6dce8cc89b71aa

See more details on using hashes here.

File details

Details for the file tello_asyncio-2.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for tello_asyncio-2.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 1262381a57d7e2d7bcec2b5e24ed6da830d6ae49e13a8a8f21937cb94cbedf9c
MD5 2c0044c4c9c631edabc6fac7ff74750f
BLAKE2b-256 836b218752be7d4013c87857e9fba241bf526336690bb08b6b43350573538039

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page