Skip to main content

A MusicPlayer which can be controlled by different controllers

Project description

# Python Music Player [![GitHub license](https://img.shields.io/github/license/MelleDijkstra/PythonMusicPlayer.svg)](https://github.com/MelleDijkstra/PythonMusicPlayer/blob/master/LICENSE) [![PyPI version](https://badge.fury.io/py/melon-music-player.svg)](https://badge.fury.io/py/melon-music-player) [![Documentation Status](https://readthedocs.org/projects/pythonmusicplayer/badge/?version=latest)](http://pythonmusicplayer.readthedocs.io/en/latest/?badge=latest)

[![Twitter](https://img.shields.io/twitter/url/https/github.com/MelleDijkstra/PythonMusicPlayer.svg?style=social)](https://twitter.com/intent/tweet?text=MelonMusicPlayer:&url=https%3A%2F%2Fgithub.com%2FMelleDijkstra%2FPythonMusicPlayer)

## Introduction

This repository contains a python music player which acts as a server. It uses the vlc python bindings to play the music and socket communication to communicate with the Android Application which can be found [here](https://github.com/MelleDijkstra/AndroidMusicPlayerClient)

## Installation

### Windows

Download executable from here [Download link]()

__*! I experienced a bug with the windows executable, you sometimes need to press enter to activate the server again !*__

Besides that, it should work fine ;)

### Linux (Debian | Raspberry Pi)

(coming soon, on my todo list) I published a PyPi package, but I haven’t tested it yet. To install run the following command: pip install melon-music-player

### From source

If you want to install/run the MelonMusicPlayer from source, or if you want to develop on the current code base (please feel free) run the following instructions:

  • Make sure you have installed python 3.5 or higher. [Python Download](https://www.python.org/downloads/)

  • The actual VLC program which can be found here ([VLC Download](http://www.videolan.org/vlc/)).

    Windows: For windows you can just install the executable

    Linux: For linux system it should be as easy as running $ sudo apt-get install vlc.

    !Although, check their site for correct installation!

  • Clone the project if you haven’t already $ git clone https://github.com/MelleDijkstra/PythonMusicPlayer

  • Go to cloned folder $ cd PythonMusicPlayer

  • Then run $ pip install -r requirements.txt to install the packages needed

    (If you are installing the MelonMusicPlayer server on raspberry pi this process can take some time. The reason is because the server runs on gRPC which has to compile when installing for raspbian. This will hopefully be changed in the future (Please be patient!))

  • Change any settings needed in config.ini. This is the configuration file for the server

  • Start the music server by running $ python main.py.

    Then use a client/controller to connect to the server. if you downloaded the source, there should be a client.py. Run this in another terminal/process to test the server. The client has quite some functionality but I will not be maintaining them. For full experience use one of the controllers like the [Android App](https://github.com/MelleDijkstra/AndroidMusicPlayerClient).

### TODO (only server related tasks)

  • [ ] Able to send an MRL link to server to download

  • [ ] Handle all MediaDownloader RPC calls

  • [ ] Create distributions for:
    • [x] Windows

    • [ ] Debian

    • [ ] Ubuntu

    • [ ] Mac OS

  • [ ] Write good tests ;)

  • [ ] Retrieve album covers from media files and send them

  • [ ] Able to sync media files with clients/controllers

  • [ ] SoundCloud support

  • [ ] Store radio station urls in file and be able to stream them

  • [x] gRPC implementation

  • [x] Handle all MusicPlayer RPC calls (play, pause, …)

  • [x] Retrieve album & song list

  • [x] Volume control

  • [x] Queue music (next & previous song selection)

  • [x] Write tests

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

melon_music_player-3.0.0a0-py3-none-any.whl (25.3 kB view details)

Uploaded Python 3

File details

Details for the file melon_music_player-3.0.0a0-py3-none-any.whl.

File metadata

File hashes

Hashes for melon_music_player-3.0.0a0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d3355a1e5eb336767731c002d55776314ea844dffdffe8e38f8af4a2feb596e
MD5 f02b8bcdf0e0a1b9c29fdc31b2803ea3
BLAKE2b-256 4db2380961081c66320f0dcbe4593f95b47318dd3e3448f23f9bf24616b0ae4d

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