68 lines
3.0 KiB
Markdown
68 lines
3.0 KiB
Markdown
# A Simple SdFat Audio Player
|
|
|
|
It was pretty simple to build a simple audio player with the help of the Stream API. A SD file is a sublass of an Arduino Stream, so all you need to do is to copy from the file to the desired output strem. Finally you need to add some logic which handles the end of file to automatically process the next file and maybe a status flag to halt and contine the processing. In addition it adds only a little bit of additional complexity to add volume control and meta data support.
|
|
|
|
In order to simplify things, I decided to provide this functionality as well and to prove the point: The AudioPlayer class took only 120 lines of code to implement!
|
|
|
|
The AudioPlayer supports
|
|
|
|
- __multiple processor architectures__
|
|
- __multiple audio data sources__ (SD, URL, callbacks)
|
|
- __different Output__ Scenarios (I2S, PWM, A2DP etc). Just pass the desired output stream object to the constructor.
|
|
- __different Decoders__ for MP3, AAC, WAV. Just pass the desired decoder object to the constructor.
|
|
- __Volume Control__ (by calling player.setVolume())
|
|
- __Stopping and Resuming__ the processing (by calling player.stop() and player.play())
|
|
- You can __move to the next file__ by calling player.next();
|
|
- support for __Metadata__
|
|
|
|
The example demonstrates how to implement an __MP3 Player__: which provides the data from a SD drive and sends the audio via I2S to an __external DAC__: The __AudioSourceSdFat class__ builds on the [SdFat Library](https://github.com/greiman/SdFat) from Bill Greiman which provides FAT16/FAT32 and exFAT support.
|
|
|
|
## SD Card
|
|
|
|
Here is the information how to wire the SD card to the ESP32
|
|
|
|
| SD | ESP32
|
|
|-------|-----------------------
|
|
| CS | VSPI-CS0 (GPIO 05)
|
|
| SCK | VSPI-CLK (GPIO 18)
|
|
| MOSI | VSPI-MOSI (GPIO 23)
|
|
| MISO | VSPI-MISO (GPIO 19)
|
|
| VCC | VIN (5V)
|
|
| GND | GND
|
|
|
|

|
|
|
|
### External DAC:
|
|
|
|
For my tests I am using the 24-bit PCM5102 PCM5102A Stereo DAC Digital-to-analog Converter PLL Voice Module pHAT
|
|
|
|

|
|
|
|
I am just using the default pins defined by the framework. However I could change them with the help of the config object. The mute pin can be defined in the constructor of the I2SStream - by not defining anything we use the default which is GPIO23
|
|
|
|
|
|
DAC | ESP32
|
|
-----|----------------
|
|
VCC | 5V
|
|
GND | GND
|
|
BCK | BCK (GPIO14)
|
|
DIN | OUT (GPIO22)
|
|
LCK | BCK (GPIO15)
|
|
FMT | GND
|
|
XMT | 3V (or another GPIO PIN which is set to high)
|
|
|
|
- DMP - De-emphasis control for 44.1kHz sampling rate(1): Off (Low) / On (High)
|
|
- FLT - Filter select : Normal latency (Low) / Low latency (High)
|
|
- SCL - System clock input (probably SCL on your board).
|
|
- FMT - Audio format selection : I2S (Low) / Left justified (High)
|
|
- XMT - Soft mute control(1): Soft mute (Low) / soft un-mute (High)
|
|
|
|
|
|
|
|
|
|
## Dependencies
|
|
|
|
- https://github.com/pschatzmann/arduino-audio-tools
|
|
- https://github.com/pschatzmann/arduino-libhelix
|
|
- https://github.com/greiman/SdFat
|