-
Notifications
You must be signed in to change notification settings - Fork 30
Getting Started
This guide will walk you through downloading CRSF for Arduino and adding it to your local Arduino libraries.
For PlatformIO users, the process is simpler and more straightforward.
For Arduino IDE users, the process is a bit more "hands-on".
In either case, both methods assume you have a basic knowledge of the development environment you are working with, and have installed the required development board support packages for your chosen target. Keep in mind that the majority of STM32 targets are only available via stm32duino, which is not available to PlatformIO.
Note
CRSF for Arduino is not yet supported in the Arduino Library Manager.
At this time, you are REQUIRED
to install it manually.
- In my Releases section, Download the
Source Code (ZIP)
in theAssets
section, and save to a convenient space on your hard drive. - In the Arduino IDE, go to
Sketch
->Include Library
->Add .ZIP Library...
- Click
CRSFforArduino-1.0.4
and Arduino IDE will automatically install it for you. - Build-test one of the examples. preferably the
rc_channels
example byFile
->Examples
->CRSFforArduino
->rc_channels
. - Click
Verify
and the build should pass.
If you see an error flag what tells you that the library already exists (EG you're updating from an older version), delete the version of CRSF for Arduino that is currently there, then follow the above steps from 2 onwards.
Note
CRSF for Arduino is not yet available in the PlatformIO Registry.
There are a few ways to install CRSF for Arduino in your project with PlatformIO.
The most straightforward method is the method described in the Library Dependency section.
The second method is through the Command Line.
In either case, you are REQUIRED
to pay close attention to the Semantic Version tag. IE the hash tag representing the specified version of CRSF for Arduino you want to use.
A valid version tag looks like this: #vMAJOR.MINOR.PATCH
.
Where, MAJOR
is a representation of the Major release, MINOR
is a representation of the Minor release, and PATCH
is a representation of releases containing bug fixes.
EG: #v1.0.4
represents Version 1.0.4 of CRSF for Arduino.
Simply copy the following link to your lib_deps
section of your platformio.ini
file:
https://github.com/ZZ-Cat/CRSFforArduino.git#MAJOR.MINOR.PATCH
Simply replace the MAJOR.MINOR.PATCH
with the desired Version of CRSF for Arduino you want to use.
If this is your first time installing CRSF for Arduino, you only need to type one command into your terminal and hit enter:
pio pkg install -l https://github.com/ZZ-Cat/CRSFforArduino.git#MAJOR.MINOR.PATCH
Simply replace the MAJOR.MINOR.PATCH
with the desired Version of CRSF for Arduino you want to use.
This method is a little bit more involved, because you are currently REQUIRED
to "manually" delete your existing version of CRSF for Arduino.
First off, delete your existing version with:
pio pkg uninstall -l https://github.com/ZZ-Cat/CRSFforArduino.git#MAJOR.MINOR.PATCH
In this case, MAJOR
, MINOR,
and PATCH
represent your current version of CRSF for Arduino.
If you're unsure of what version you have, you can view CRSF for Arduino's boiler plate by defining and setting CRSF_DEBUG_ENABLED
to 1
in CFA_Config.hpp
, then run your sketch as normal...
#include "Arduino.h"
#include "CRSFforArduino.hpp"
CRSFforArduino *crsf = nullptr;
void setup()
{
// Wait for Serial Monitor to open.
while (!Serial)
{
delay(100);
}
/* ... */
// Initialise CRSF for Arduino.
crsf = new CRSFforArduino();
if (!crsf->begin())
{
delete crsf;
crsf = nullptr;
Serial.println("CRSF for Arduino could not initialise.");
Serial.flush();
}
/* ... */
}
void loop()
{
/* ... */
}
Next up, install the latest version with the following command:
pio pkg uninstall -l https://github.com/ZZ-Cat/CRSFforArduino.git#MAJOR.MINOR.PATCH
In this case, MAJOR.MINOR.PATCH
represents the latest version number of CRSF for Arduino. EG #v1.0.4
represents Version 1.0.4.