Basic starter project for developing FastLED applications in PlatformIO. It's also backward compatible with Arduino IDE.
- Install free VSCode. Add the free PlatformIO extension
- Download this repo: https://github.com/FastLED/PlatformIO-Starter/archive/refs/heads/main.zip
- Open it up with VSCode
- Click the platformio compile + upload button (see below)
- Did it work? Great, now copy in your sketch files to
src/
until it's your project. - That's it!
Typically FastLED users will start out with the Arduino IDE then graduate to PlatformIO and never look back. You'll use VScode with the platformio extension. This gives you copilot and other AI tools. Yes, there is a command tool too platformio
, and we use it to compile all of FastLEDs compile targets.
PlatformIO has a better package manager than the one ArduinoIDE uses primarily because your dependencies are defined with the project repo instead of globally. This means you can hand off your code repo to someone else and they can just fire it up in VSCode and all dependencies will auto-magically be installed and they can start running your project.
Everything you'd want to do in Arduino IDE can be done with VSCode + PlatformIO. Keep that in mind. If you don't like platformIO you can still use the ArduinoIDE. This repo has been designed to allow both.
- Download and install VSCode
- Open up VSCode and install the platformio extension
-
Download
-
-or-
git clone
itgit clone https://github.com/FastLED/PlatformIO-Starter
-
Now open up the repo directory in
VSCode
. -
Now all the dependencies will be automatically installed and you can hit the compile or upload button
- Compile: Looks like a "checkmark" icon at the bottom toolbar of VSCode.
- Compile and Upload: Looks like a "right arrow" at the bottom toolbar of VSCode, right to the right of the "compile" button.
- Example:
- The "Serial Monitor" (so you can see Serial.print) is located with this button at the very right:
-
Looking to go even further? Checkout the full platformio tutorial here: https://docs.platformio.org/en/latest/integration/ide/vscode.html#quick-start
- Open up platformio.ini at the root of this repo.
- Modify the
board = uno
part with your board. - Everything will auto magically update and you can compile/upload and it should just work.
You can also look at the platforms/ folder here for platformio ini files that you can use to get the main sketch running for your specific board type.
It's worth noting that the LLM Chatbots have all been trained on platformio's platformio.ini
file. Simply copy and paste your platformio.ini
file into one of the chat bots then ask it to make modifications to run your board and it will probably work the first time.
As far as we are aware, all the packages that work for ArduinoIDE also work for platformio. Just grab the name of the package you are interested (for example, FastLED) and put it at the lib_deps
section of the platformio.in file.
Example:
lib_deps =
FastLED
Yes. This repo has been specially constructed to be backwards compatible with the Arduino IDE. Just open up the repo with Arduino IDE and hit compile (after selecting the proper global packages and board type)
Make sure the sketch file is named the same as it's parent directory. For example the parent directory in this repo is PlatformIO-Starter
and therefore the ino file is also called PlatformIO-Starter.ino
.
In a nutshell you will write code 10x faster with platformio because of VSCode's advanced coding tools. Once you get one project in PlatformIO you'll never want to go back to the Arduino IDE.
PlatformIO relies on VSCode which has far more advanced
auto-completion tools for writing code. For example you
can jump to a function definition with a right click. This works not only for your own code but the libraries that you use. For example you can jump to FastLED's implementation of FastLED.show()
with a right click and
see what's going on.
CoPilot is an amazing tool that will 10x your coding. No JOKE! Since VSCode as first class support of CoPilot, you can now use this in your Arduino Projects here.
Arduino IDE wants you to select the port. PlatformIO uses magic to find this for you.
With Arduino IDE you have to set your board information. If you hand off your sketch to someone else then you have to include instructions on which board they need to use within the Arduino IDE. With platformIO you can set the board for your project. You can also highly customize things like the uploader or monitoring speed at the project level.
Got a problem with a library package? Right click one of the symbols and VSCode will open the file that contains that symbol. Arduino IDE makes you discover where this file is manually.
In the Arduino IDE you install dependencies (like FastLED) at the Global level. If you downgrade one of your dependencies then EVERY sketch also get's downgraded. You simply cannot have local packages unless you copy and paste the entire code base into your sketches src/ directory.
However, platformio takes a different approach, every dependency is local to your sketch folder in the .pio directory.
This means that all project dependencies for a specific sketch repo will stay with that sketch and won't affect anything else.
A real world example of how useful it is can be illustrated with the recent Arduino 2.3.1 upgrade, which forced the esp32 idf 5.1 library onto all Arduino users. This broke every single FastLED user in the Arduino IDE universe that was compiling FastLED for one of the esp32-s3 flavors of boards. To fix this you had to downgrade the package dependency at the global level. However with platform io you can happily pin your dependencies to versions you know works. If you give your repo to someone else, then you can be pretty certain it will work for them to.