/projectm

projectM - Cross-platform Music Visualization Library. Open-source and Milkdrop-compatible.

Primary LanguageC++GNU Lesser General Public License v2.1LGPL-2.1

Build Status Discord Shield Chat with us on Discord

Logo

projectM - The most advanced open-source music visualizer

Experience psychedelic and mesmerizing visuals by transforming music into equations that render into a limitless array of user-contributed visualizations.

projectM is an open-source project that reimplements the esteemed Winamp Milkdrop by Geiss in a more modern, cross-platform reusable library.

Its purpose in life is to read an audio input and to produce mesmerizing visuals, detecting tempo, and rendering advanced equations into a limitless array of user-contributed visualizations.

Important: This repository only contains libprojectM for use in application development!

This repository now only contains the projectM shared/static library. All frontends, plug-ins and other tools were outsourced into separate repositories. If you're not a developer and just look for a download to run projectM visuals on your machine or device, please use one of the links listed below. The releases section in this repository only contains source-code and binary releases of the projectM development libraries and headers, which aren't useful for end users.

End-User Applications

Important: projectM is currently undergoing heavy development, so the available end-user frontends are either outdated or unavailable. We've released a few development previews, which are not feature-complete and may have bugs. As soon as we've finished the current modernization of libprojectM, we'll release new and tested versions of most of the frontends listed below, while we may remove or replace some of those which are no longer maintained by their original developers.

Windows

macOS

Linux

  • Standalone (currently only available as a development preview for Ubuntu 22.04 and compatible distributions)
  • Steam (Same as standalone development preview)

Or check your distribution's package manager for a binary release. If it is outdated, please contact the package maintainer, as the projectM development team does not maintain any of the distribution-specific packages.

Android

Note: Both the free and paid apps plus the Android TV app are not created or supported by the projectM developers! If you have technical troubles or other inquiries, please contact the app author via the means provided in the Play Store. Any bug reports in the projectM issue tracker regarding the apps will be closed immediately.

Xbox / Windows Phone

Other

Source code and other resources, mostly aimed at developers.

Discord chat

Chat with us on Discord!

Demo Video

Presets

The preset files define the visualizations via pixel shaders and Milkdrop-style equations and parameters.

The projectM library does not ship with any presets. The frontends come with varying preset packs which can be found in separate repositories in the projectM repository list:

Included with projectM are the bltc201, Milkdrop 1 and 2, projectM, tryptonaut and yin collections. You can grab these presets here.

You can also download an enormous 41,000 preset pack of presets here (123MB zipped).

Also Featured In

Kodi Kodi (formerly XBMC)

Helix Helix

Silverjuke Silverjuke (FOSS Jukebox)

VLC Media Player VLC Media Player (AKA VideoLAN Client)

Reminder: These are all third-party integrations of libprojectM and not developed or supported by the projectM development team. Please report bugs in those applications to their respective developers.


Screenshots

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot

Screenshot


Architecture

Building from source

See BUILDING.md and the developer documentation in the wiki.

Using the library

At its core projectM is a library, libprojectM. This library is responsible for parsing presets, analyzing audio PCM data with beat detection and FFT, applying the preset to the audio feature data and rendering the resulting output with OpenGL. It can render to a dedicated OpenGL context or a texture.

To get started using projectM in your own projects, please go to the wiki and read the developer documentation available there.

There are some open-source applications that make use of libprojectM which can be found in the projectM organization's repositories and elsewhere.


Todo

  • Improve projectM using the recently-released Milkdrop source (WIP).
  • Update the various implementations using libprojectM.
  • Update downstream projects with new versions.

Help

Report issues on GitHub in the respective repositories:

If unsure, post your issue in the main libprojectM issue tracker. Please always check any existing issues if your problem has already been posted by another user. If so, add your logs and findings to the existing issue instead of opening a new ticket.

Get in contact with us

Chat with us on Discord.

Contribute to projectM

If you would like to help improve this project, either with documentation, code, porting, hardware or anything else please let us know! We gladly accept pull requests and issues.

Before starting to write code, please take your time to read the contribution guidelines in our wiki.

Package Maintainers

If you maintain packages of libprojectM, we are happy to work with you! Please note well:

  • The main focus of this project is libprojectM. It's a library that only really depends on OpenGL. The other applications are more like examples and demos.
  • Many of the frontend applications are likely outdated and of less utility than the core library. If you desire to use them or depend on them, please file an issue in the respective repository so we can help update them.
  • The "canonical" application for actually viewing the visualizations is now projectM-SDL, based on libSDL2 because it supports audio input and is completely cross-platform.
  • This is an open source project! If you don't like something, feel free to contribute improvements!
  • Yes, you are looking at the official version. This is not a fork.

Authors

Authors

License

The core projectM library is released under the GNU Lesser General Public License 2.1 to keep any changes open-sourced, but also enable the use of libprojectM in closed-source applications (as a shared library) as long as the license terms are adhered to. The up- and downstream projects may use different licenses - please check all parts of the software to be compatible with your specific project if you plan an integration.

Wiki

More information for developers is available from the projectM Wiki.