esp-idf/examples/bluetooth/a2dp_sink
2018-01-15 19:47:23 +08:00
..
main Component/bt: modify license 2018-01-15 19:47:23 +08:00
Makefile component/bt: implement classic Bluetooth profiles A2DP(sink) and AVRCP(controller) 2017-04-12 16:42:14 +08:00
README.md component/bt: implement A2DP source 2018-01-09 20:20:52 +08:00
sdkconfig.defaults component/bt: implement A2DP source 2018-01-09 20:20:52 +08:00

ESP-IDF A2DP-SINK demo

Demo of A2DP audio sink role

This is the demo for user to use ESP_APIs to use Advanced Audio Distribution Profile in receiving audio stream

Options choose step: 1. make menuconfig. 2. enter menuconfig "Component config", choose "Bluetooth" 3. enter menu Bluetooth, choose "Bluedroid Enable" 4. enter menu Bluedroid Enable, choose "Classic Bluetooth" 5. select "A2DP" and choose "SINK"

For the I2S codec, pick whatever chip or board works for you; this code was written using a PCM5102 chip, but other I2S boards and chips will probably work as well. The default I2S connections are shown below, but these can be changed in menuconfig:

+-----------+--------------+ | ESP pin | I2S signal | +===========+==============+ | GPIO22 | LRCK | +-----------+--------------+ | GPIO25 | DATA | +-----------+--------------+ | GPIO26 | BCK | +-----------+--------------+

If the internal DAC is selected, analog audio will be available on GPIO25 and GPIO26. The output resolution on these pins will always be limited to 8 bit because of the internal structure of the DACs.

After the program started, other bluetooth devices such as smart phones can discover this device named "ESP_SPEAKER", and after connection is established, audio data can be transmitted and there will occur a count of audio data packets printed.