:mod:`audiomp3`
===============
.. py:module:: audiomp3
.. autoapi-nested-parse::
Support for MP3-compressed audio files
.. raw:: html
Available on these boards
ARAMCON Badge 2019
ARAMCON2 Badge
Adafruit CLUE nRF52840 Express
Adafruit Circuit Playground Bluefruit
Adafruit EdgeBadge
Adafruit Feather Bluefruit Sense
Adafruit Feather M4 CAN
Adafruit Feather M4 Express
Adafruit Feather RP2040
Adafruit Feather STM32F405 Express
Adafruit Feather nRF52840 Express
Adafruit Grand Central M4 Express
Adafruit Hallowing M4 Express
Adafruit ItsyBitsy M4 Express
Adafruit ItsyBitsy RP2040
Adafruit ItsyBitsy nRF52840 Express
Adafruit KB2040
Adafruit LED Glasses Driver nRF52840
Adafruit Macropad RP2040
Adafruit Matrix Portal M4
Adafruit Metro M4 Airlift Lite
Adafruit Metro M4 Express
Adafruit Metro nRF52840 Express
Adafruit Monster M4SK
Adafruit PyGamer
Adafruit PyPortal
Adafruit PyPortal Pynt
Adafruit PyPortal Titano
Adafruit Pybadge
Adafruit QT Py RP2040
Adafruit QT2040 Trinkey
Adafruit Trellis M4 Express
AloriumTech Evo M51
Arduino Nano 33 BLE
Arduino Nano RP2040 Connect
AtelierDuMaker nRF52840 Breakout
BDMICRO VINA-D51
BLE-SS dev board Multi Sensor
BastBLE
BlueMicro840
CP32-M4
Capable Robot Programmable USB Hub
Challenger NB RP2040 WiFi
Challenger RP2040 LTE
Challenger RP2040 WiFi
CircuitBrains Deluxe
Cytron Maker Nano RP2040
Cytron Maker Pi RP2040
DynOSSAT-EDU-OBC
Electronut Labs Blip
Electronut Labs Papyr
EncoderPad RP2040
HiiBot BlueFi
IkigaiSense Vita nRF52840
MDBT50Q-DB-40
MDBT50Q-RX Dongle
MEOWBIT
MakerDiary nRF52840 MDK
MakerDiary nRF52840 MDK USB Dongle
Makerdiary M60 Keyboard
Makerdiary Pitaya Go
Makerdiary nRF52840 M.2 Developer Kit
Melopero Shake RP2040
Mini SAM M4
Oak Dev Tech BREAD2040
Open Hardware Summit 2020 Badge
PCA10056 nRF52840-DK
PCA10059 nRF52840 Dongle
Particle Argon
Particle Boron
Particle Xenon
Pimoroni Interstate 75
Pimoroni Keybow 2040
Pimoroni PGA2040
Pimoroni Pico LiPo (16MB)
Pimoroni Pico LiPo (4MB)
Pimoroni PicoSystem
Pimoroni Plasma 2040
Pimoroni Tiny 2040
PyCubedv04
PyCubedv04-MRAM
PyCubedv05
PyCubedv05-MRAM
PyKey60
PyboardV1_1
RP2040 Stamp
Raspberry Pi Pico
Robo HAT MM1 M4
SAM E54 Xplained Pro
SAM32v26
STM32F412G_DISCO
STM32F4_DISCO
Seeeduino Wio Terminal
Silicognition LLC M4-Shim
SparkFun MicroMod RP2040 Processor
SparkFun MicroMod SAMD51 Processor
SparkFun MicroMod nRF52840 Processor
SparkFun Pro Micro RP2040
SparkFun Pro nRF52840 Mini
SparkFun STM32 MicroMod Processor
SparkFun Thing Plus - RP2040
SparkFun Thing Plus - SAMD51
Swan R5
TG-Boards' Datalore IP M4
TG-Watch
THUNDERPACK_v11
THUNDERPACK_v12
Teknikio Bluebird
The Open Book Feather
TinkeringTech ScoutMakes Azul
UARTLogger II
WarmBit BluePixel nRF52840
nice!nano
stm32f411ce-blackpill-with-flash
.. py:class:: MP3Decoder(file: BinaryIO, buffer: _typing.WriteableBuffer)
Load a mp3 file for audio playback
Load a .mp3 file for playback with `audioio.AudioOut` or `audiobusio.I2SOut`.
:param typing.BinaryIO file: Already opened mp3 file
:param ~_typing.WriteableBuffer buffer: Optional pre-allocated buffer, that will be split in half and used for double-buffering of the data. If not provided, two buffers are allocated internally. The specific buffer size required depends on the mp3 file.
Playing a mp3 file from flash::
import board
import audiomp3
import audioio
import digitalio
# Required for CircuitPlayground Express
speaker_enable = digitalio.DigitalInOut(board.SPEAKER_ENABLE)
speaker_enable.switch_to_output(value=True)
data = open("cplay-16bit-16khz-64kbps.mp3", "rb")
mp3 = audiomp3.MP3Decoder(data)
a = audioio.AudioOut(board.A0)
print("playing")
a.play(mp3)
while a.playing:
pass
print("stopped")
.. py:attribute:: file
:annotation: :BinaryIO
File to play back.
.. py:attribute:: sample_rate
:annotation: :int
32 bit value that dictates how quickly samples are loaded into the DAC
in Hertz (cycles per second). When the sample is looped, this can change
the pitch output without changing the underlying sample.
.. py:attribute:: bits_per_sample
:annotation: :int
Bits per sample. (read only)
.. py:attribute:: channel_count
:annotation: :int
Number of audio channels. (read only)
.. py:attribute:: rms_level
:annotation: :float
The RMS audio level of a recently played moment of audio. (read only)
.. py:method:: deinit() -> None
Deinitialises the MP3 and releases all memory resources for reuse.
.. py:method:: __enter__() -> MP3Decoder
No-op used by Context Managers.
.. py:method:: __exit__() -> None
Automatically deinitializes the hardware when exiting a context. See
:ref:`lifetime-and-contextmanagers` for more info.