arduino-audio-tools
|
Some basic header-only C++ classes that can be used for Audio Processing provided as Arduino and cmake C++ Library:
This functionality provides the glue which makes different audio processing components and libraries work together.
We also provide plenty of examples that demonstrate how to implement the different scenarios. The design philosophy is based on the Arduino conventions: we use the begin()
and end()
methods to start and stop the processing and we propagate the use of Streams.
We all know the Arduino Print and Stream classes: We usually use them to write out print messages and sometimes we use them to read the output from Serial, Files, Ethernet, etc. The same thing applies to “Audio Streams”: You can read audio data from “Audio Sources” and you write them to “Audio Sinks”.
Here is an simple example which streams a file from the Flash Memory and writes it to I2S:
Each stream has it's own configuration object that should be passed to the begin method. The defaultConfig() method is providing a default proposal which will usually "just work". Please consult the class documentation for the available configuration parameters. You can also easily adapt any provided examples: If you e.g. replace the I2SStream with the AnalogAudioStream class, you will get analog instead of digital output.
I suggest you continue to read the more detailed introduction.
Further examples can be found in the Wiki.
Dependent on the example you might need to install some addional libaries
The library also provides a versatile AudioPlayer. Further information can be found in the Wiki
The application uses a built in logger: By default we use the log level warning and the logging output is going to Serial. You can change this in your sketch by calling e.g:
You can log to any object that is a subclass of Print and valid log level values are: Debug, Info, Warning, Error.
You can also deactivate the logging by changing USE_AUDIO_LOGGING to false in the AudioConfig.h to decrease the memory usage:
Get some inspiration from projects that were using this library or share your projects with the community.
Please use this before you raise any issue or start a discussion!
I spent a lot of time to provide a comprehensive and complete documentation. So please read the documentation first and check the issues and discussions before posting any new ones on Github.
Open issues only for bugs and if it is not a bug, use a discussion: Provide enough information about
to enable others to understand and reproduce your issue.
Finally, don't send me any e-mails or post questions on my personal website!
Please note that discussions and issues which have already been answered before or where the answer can be found in the documentation may get deleted w/o reply.
You can download the library as zip and call include Library -> zip library. Or you can git clone this project into the Arduino libraries folder e.g. with
I recommend to use git because you can easily update to the latest version just by executing the git pull
command in the project folder. If you want to use the library on other patforms, you can find further information in the Wiki.
This software is totally free, but you can make me happy by rewarding me with a treat