Giter Site home page Giter Site logo

kevontheweb / fire Goto Github PK

View Code? Open in Web Editor NEW

This project forked from jerryuhoo/fire

0.0 0.0 0.0 15.36 MB

This is a distortion plugin developed by Wings!

License: GNU Affero General Public License v3.0

C++ 91.79% C 5.47% R 0.08% Objective-C++ 0.80% CMake 1.86%

fire's Introduction

Fire (Version 0.9.8) Codacy BadgeCMake Build Matrix

Alt text

Alt text

1. Introduce

This is a multi-band distortion plugin 『Fire』. It can be used in DAWs which supports AU and Vst3 plugins such as Ableton Live, Fl Studio, etc.

Demo video:

(YouTube) https://youtu.be/sccW_8W_0o4

(Bilibili) https://www.bilibili.com/video/BV17f4y1M7Hm

🎵 Home Page for Wings Music: Wings Music

Hope you like it!

2. How to install

Download from Release Page

Download here

Build by JUCE

Open .jucer file by Projucer then select your IDE to build 『Fire』. If you don't have projucer, you can go to JUCE/extras/Projucer/Builds/... and build it, or download from the latest JUCE release

Note: You should choose Release mode rather than Debug mode(or disable Debug mode) in .fire Exporters page. Build with debug mode will cause high CPU usage.

3. User Manual

『Fire』has a top panel, a spectrogram, four graph visualizers, band effect, and global effect.

3.1. Top panel

  • HQ: 4x oversampling for high quality audio.
  • A/B: switch between A/B to compare.
  • Copy: copy current preset parameters to another(A/B) panel.
  • Preset bar: choose your current preset.
  • Save: save your preset to user folder.
  • Menu: other settings including init, open preset folder, rescan preset folder, open GitHub page, check for new version.

3.2. Spectrogram

  • You can split up frequency to four bands for multiband distortion.

3.3. Graph Visualizer

  • There are four graph visualizers. You can click on each graph to zoom in or zoom out.
  • Top left is oscilloscope.
  • Top right is distortion graph.
  • Buttom Left is VU meters.
  • Buttom right is Width graph.

3.4. Band Effect

  • You can click four switches on the right side of graphs.

  • Drive:『Fire』 has several distortion functions. There are two buttons "L" and "S" related to drive knob, and each means "Link" and "Safe". "Link" means when your turn up drive knob, the output knob value will automatically reduce. "Safe" means if your drive knob pushes your volume too loud, it will automatically reduce your drive value. It also shows reduced value on drive knob.

  • Retification and bias: Change your distortion shape.

  • Compressor: you can change threshold and ratio for each band.

  • Width: change audio width.

  • Output and mix: for band control.

3.5. Global Effect

  • Filter: you can set lowcut, highcut, and peak. Lowcut and highcut each has four slopes (12, 24, 36, 48) you can choose.

  • Downsample: downsample your audio.

  • Output and mix: for global control.

4. Support the author

我也是一个音乐制作人,欢迎关注网易云音乐:羽翼深蓝Wings

I am also a music producer. Netease channel: 羽翼深蓝Wings SoundCloud: Wings

5. References

5.1. A great example of using XML by johnflynnjohnflynn to save presets to file example. I changed the code to save presets as mutiple files.

5.2. Diode Clipping algorithm from JUCE forum

5.3. Spectrum Analyser by adriannaziel

5.4. SimpleEQ by matkatmusic

6. Update Notes

2022-6-29 (version 0.9.8)

  1. Fix phasing issue in HQ mode.
  2. Fix low frequency drop in HQ mode. [v0.9.3 - v0.9.7 has those bugs]

2022-6-22 (version 0.9.7)

  1. Fix HQ not working bug in v0.9.6.
  2. Add fade in/out of frequency text labels.

2022-5-28 (version 0.9.6)

  1. Fix a crash when turn on HQ mode in mono channel mode in Logic Pro.
  2. Improve graphs in mono channel mode.
  3. Fix an issue where graphs are not refreshed before playing in Logic Pro.

2022-2-5 (version 0.9.5)

  1. Smoothed the graph of spectrogram.
  2. Fix Logic Pro crash.
  3. Add GitHub CI.
  4. Fix vst3 bug.
  5. Fix A/B mode bug.

2021-11-18 (version 0.9.4)

Warning: Previous presets won't work, you have to resave your preset!

  1. For VU meters and width graph, each represents to each band instead of global.
  2. Add more details to VU meters.
  3. Add "solo" buttons, change "enable" buttons to "bypass" buttons.
  4. Remove "None" option in the distortion functions, because it causes bug(in version 0.9.3) and you can bypass the band now.
  5. Add bypass buttons for compressor, width, filter, downsample.
  6. Add 4 new distortion functions.

2021-10-2 (version 0.9.3)

Warning: Previous presets won't work, you have to resave your preset!

  1. Redesign GUI.
  2. Fix multiple bugs of multiband control(enable buttons, focus band, vertical lines, etc.), redesigned the code structure.
  3. Add new filter control and filter graph.
  4. Fix other bugs such as preset box selection, A/B mode, bypass repaint issue, etc.
  5. Now you can click graph to zoom in and out.

2021-9-7 (version 0.9.2)

  1. GUI improvement.
  2. Add shape, width, and compressor groups.
  3. Spectrogram display bug fixed.
  4. Add VU meter and width graph.
  5. Add frequency label, and frequency automation bug fixed.

2021-1-24 (version 0.9.1)

  1. Drive knob reduction and GUI improvement Fix a bug that in global mode menu won't change when selecting different bands.

2021-1-23 (version 0.9.0)

  1. First Beta release.

7. License

From v.0.9.4, I changed the license to AGPL-3.0.

What can you do with the source

  • Currently, up to version 0.9.4 is free for music producers, audio programmers who start to learn JUCE. You can fork, modify my code, but projects that used my code must be open-source.

Things you can't do with this source

  • Do not create an app and distribute it on the iOS app store.

  • Do not use the name "Fire", "Wings", or "羽翼深蓝Wings" for marketing or to name any distribution of binaries built with this source. This source code does not give you rights to infringe on trademarks. If you wanna use it for commercial, please send me an email. Otherwise, your software has to be open-source.

fire's People

Contributors

jerryuhoo avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.