DroneCtrl is a Python program for controlling and programming autonomous drones. It is designed to be easy to use and to work with almost all FPV drones.
It is built to work with ELRS Joystic Control, an awesome project that allows you to control your ELRS FPV drone from your computer using a joystick. In order for the two programs to communicate, I have modified ELRS Joystick Control, and you can get my fork here.
This program is still experimental! Currently, there is only support for linux and the drone must be a quadcopter running Betaflight and using ELRS. Also, the conversion functions that calculate the thrust, RPM, throttle, etc. are specific to my drone. You will most likely need to adjust them to work with your drone.
To run the program, you need to have Python 3 installed on your computer. Also, you need to install the following libraries:
cv2
numpy
nptyping
posix_ipc
Which can be installed using pip:
pip install opencv-python numpy nptyping posix_ipc
Additionally, you need to have the ELRS Joystick Control program running on your computer. You can get it here, where you can also find instructions on how to install it.
To run the program, simply run the main.py
file.
python3 main.py
Or you can run python3 main.py -v
to log debug messages.
IMPORTANT! For the program to work without any modifications, the drone needs to be in ANGLE mode. You can change that in Betaflight. Also, you need to make sure that the PID tuning is correct - that is make the throttle, yaw, pitch and roll curves linear. Without doing the above, the program will not work correctly and the drone will probably crash.
Additionally, you need to change some variables in the config.py
script. Look for the section "USER EDITABLE VARIABLES". There, you must at least change the constant MASS
to the mass of your drone in kilograms.
Currently, few things work. All you can do is:
- Automatic takeoff
- Automatic landing
- Controlling the drone with easy-to-use functions: Instead of manually setting the yaw, pitch, roll and throttle, you will just set the forward and vertical acceleration, and a helper function will do all of the conversions.
Features which have been implemented and are currently being tested. Most likely there will be improvements.
- Object tracking
- Stabilized hover
Features that are currently being implemented. If there are features for testing, they will be tested before implementing new ones.
- Passing through hoops
Features that are planned to be implemented:
- Path planning