Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FEATURE] Implement a postprocessing middleware library for scaling, filtering etc. #845

Open
kblaschke opened this issue Sep 27, 2024 · 0 comments

Comments

@kblaschke
Copy link
Member

kblaschke commented Sep 27, 2024

Is Your Enhancement Related to a Problem?

Currently, libprojectM always renders to the current viewport at [0,0] with the set resolution. There is no way of performing up- or downscaling to a different canvas size. There are also no ways of applaying additional filters like blur, sharpen, hue shifts etc. without adding another (complex) rendering step in the embedding application.

Your Suggested Enhancement

Add a new repository which willl contain a separate library which can act as a middleware between libprojectM and the application. This library would provide a set of filters and effects to be applied to the projectM rendering output, returning a texture (or drawing onto a native surface, e.g. FBO 0) with the configured filters applied.

Having this as a separate library has many advantages over adding this functionality directly into libprojectM:

  1. The library can be licensed under a more permissive license like MIT to allow static linking or fully embedding into closed-source applications.
  2. The libprojectM API will stay as simple as possible.
  3. The release cycle of this filtering library would be decoupled from libprojectM, making it easier to quickly add new features.
  4. The middleware would be compatible with a range of libprojectM versions, e.g. any version from 4.2 onwards (as this version will introduce FBO rendering support). This would enable backwards compatibility as well, as long as libprojectM supports the required API calls.
  5. Putting the code into a separate library will keep the projectM core codebase cleaner and thus reduces the potential for bugs. Application developers can then opt-in to use the additional dependency if needd.

The new library should provide a similar C API as libprojectM to make it useable in a wider range of programming languages. The implementation itself could be done in different languages like C, C++ or Rust. It should compile on the same platforms as libprojectM.

Some potential effects that could be implemented include:

  • Upscaling filter: render at a lower resolution, then scale the result to the output screen size. Useful for less powerful devices such as the Raspberry Pi.
  • Downscaling filter: render as a higher resolution, then scale down to the output size using bilinear or bicubic filtering. Adds anti-aliasing to the output, but will darken or black out some presets due to lines always being drawn at a 1px fixed width.
  • Blur: Parameterized gaussian/radial blur applied to the whole image.
  • Chromatic abberation: A lens distortion effect that separates certain colors close to the screen edges.
  • Hue shift/mapping: Either shift colors in hue or map the whole output to a specific color.
  • Color reduction: Reduce the number of color steps, creating a cartoonish or art-like appearance.
  • Bloom: Add a glow effect to bright colors.

There are many more possible filters that could be added. Configuring them could be done by building a filter chain, as filter order is important.

Alternative Solutions

No response

Additional Context

Originally suggested in PR #844

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant