Skip to main content

audioplayer is a cross platform Python 3 module for playing sounds (mp3, wav, ...)

Project description

AudioPlayer

audioplayer is a cross platform Python 3 package for playing sounds (mp3, wav, ...). It provides the key features of an audio player, such as opening a media file, playing (loop/block), pausing, resuming, stopping, and setting the playback volume.

I created this package to provide sound functionality to my game library game2dboard, but I decided to publish it separately.

Suported systems (see full list):

  • GNU/Linux (PC, Raspberry Pi, ...)
  • Windows
  • macOS

Inspired by (and with a few lines of codes from) the playsound module.

Install

Prerequisites

GNU/Linux

In Linux, you need to install PyGObject and others dependencies.

Ubuntu/Debian/Raspberry Pi OS:

sudo apt-get install python-gst-1.0 \ 
                     gir1.2-gstreamer-1.0 \ 
                     gstreamer1.0-tools \
                     gir1.2-gst-plugins-base-1.0 
                     gstreamer1.0-plugins-good \
                     gstreamer1.0-plugins-ugly                     

Redhat/Centos/Fedora:

sudo yum install -y python-gstreamer1 \ 
                    gstreamer1-plugins-good \
                    gstreamer1-plugins-ugly

macOS

In macOS, you need to install PyObjC bridge.

pip3 install PyObjC --user

Install

The recommended way to install audioplayer is using the Python pip (or pip3) installer.

pip3 install audioplayer

If you don't have administrator privileges, install in your home folder.

pip3 install audioplayer --user

You can install the latest release by cloning this repository.

git clone https://github.com/mjbrusso/audioplayer.git 
cd audioplayer
python3 setup.py install --user

Usage

The API is documented bellow and within the docstrings.

After install, you can use this code to test (replace "path/to/somemusic.mp3"):

from audioplayer import AudioPlayer

# Playback stops when the object is destroyed (GC'ed), so save a reference to the object for non-blocking playback.
AudioPlayer("path/to/somemusic.mp3").play(block=True)

API

Creation

  • audioplayer.AudioPlayer(filename)
    Creates the player.

    • filename : str – The file name with extension (.mp3, .wav, ...)

    Raise: FileNotFoundError() : The file does not exist.

Properties

  • filename : str (readonly)
    The file name as provided in the constructor.

  • fullfilename : str (readonly)
    The file name with full path.

  • volume : int
    Gets or sets the current volume (in %) of the audio (0 — 100)

Methods

  • play(loop=False, block=False)
    Starts audio playback.

    • loop (bool) – Sets whether to repeat the track automatically when finished.
    • block (bool) – If true, blocks the thread until playback ends.

    Raise: AudioPlayerError(): Failed to play.

  • pause()
    Pauses audio playback.

  • resume()
    Resumes audio playback.

  • stop()
    Stops audio playback. Can play again.

  • close()
    Closes device, releasing resources. Can't play again.

Suported Systems

audioPlayer has been tested on the following platforms:

OS Details mp3 wav ogg mid
GNU/Linux Mint 19 (Cinnamon)
GNU/Linux Xubuntu 20.04
GNU/Linux Raspberry Pi OS
Windows Windows 10 x64
macOS Catalina (Python 3.8)

?: Not yet tested

Let me know if you are using on another system/distro/version!

What's in the roadmap?

  • .seek(position) : Moves playback to the specified position.
  • .state : Current state (playing, stopped, paused, ...)
  • .speed = value : Gets/sets playback speed.
  • Callbacks: when state changed, when position changed by a delta, ...

How to Contribute

Submitting an issue

Use the issue tracker to submit bug reports and features or enhancements requests.

Translating

You can contribute by translating this document into other languages ​​(except en and pt_br).

Submitting a pull request

If you can improve anything in this project, feel free to add a pull request.

License

audioplayer is under MIT license. It can be reused within proprietary software provided that all copies of the licensed software include a copy of the MIT License terms and the copyright notice.

Project details


Release history Release notifications | RSS feed

This version

0.6

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

audioplayer-0.6.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

audioplayer-0.6-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file audioplayer-0.6.tar.gz.

File metadata

  • Download URL: audioplayer-0.6.tar.gz
  • Upload date:
  • Size: 6.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.9

File hashes

Hashes for audioplayer-0.6.tar.gz
Algorithm Hash digest
SHA256 94b18dcd7a8067546f8483fc7e69a58d1e603588ab1752c743ff6e0ff8cb2be6
MD5 7bda820d29dbbd204cc9b268ad13079c
BLAKE2b-256 fa5d2a25f076c7f921ea9aceec368d315708f5cfe629ce33cb57a3a37fc577b6

See more details on using hashes here.

File details

Details for the file audioplayer-0.6-py3-none-any.whl.

File metadata

  • Download URL: audioplayer-0.6-py3-none-any.whl
  • Upload date:
  • Size: 8.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/47.3.1 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.9

File hashes

Hashes for audioplayer-0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 2a90da014d3519e7c2319c4ee4969cb4d30741b34ef0877b3314d5b7143a52d3
MD5 feb4709ccbc6416c6f849cda60e4806c
BLAKE2b-256 40243e4f66bde68aee74193aca6bb8a8e325f8728d03e0bd629795b17409b885

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page