BogaudioModules

BogaudioModules for VCV Rack
Log | Files | Refs | README | LICENSE

commit c449136e263438e6c3cdd63b4a4e5e1a6303e4d2
parent e056a905d8aea940f68f76d89e4a9af758db6aeb
Author: Matt Demanett <matt@demanett.net>
Date:   Thu, 15 Nov 2018 23:43:07 -0500

Blank panels.  With easter eggs.  #26

Diffstat:
Ares-src/Blank3-src.svg | 39+++++++++++++++++++++++++++++++++++++++
Ares-src/Blank6-src.svg | 39+++++++++++++++++++++++++++++++++++++++
Ares/Blank3.svg | 0
Ares/Blank6.svg | 0
Ares/fonts/audiowide.ttf | 0
Asrc/Blank3.cpp | 93+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Asrc/Blank3.hpp | 41+++++++++++++++++++++++++++++++++++++++++
Asrc/Blank6.cpp | 93+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Asrc/Blank6.hpp | 41+++++++++++++++++++++++++++++++++++++++++
Msrc/bogaudio.cpp | 7+++++++
Msrc/widgets.cpp | 6++++++
Msrc/widgets.hpp | 4++++
12 files changed, 363 insertions(+), 0 deletions(-)

diff --git a/res-src/Blank3-src.svg b/res-src/Blank3-src.svg @@ -0,0 +1,39 @@ +<svg + version="1.1" + xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" + width="45" + height="380" + viewBox="0 0 45 380" +> + <style> + text { + fill: #333; + font-family: 'Roboto', sans-serif; + font-weight: bold; + } + text.title { + font-family: 'Comfortaa', sans-serif; + font-weight: normal; + } + text.brand { + font-family: 'Audiowide', sans-serif; + font-weight: bold; + } + </style> + + <defs> + </defs> + + <rect width="100%" height="100%" fill="#ddd" /> + <polyline points="1,1 44,1 44,379 1,379 1,1" stroke="#e4e4e4" stroke-width="0.5" fill="none" /> + <polyline points="0.5,0.5 44.5,0.5 44.5,379.5 0.5,379.5 0.5,0.5" stroke="#ebebeb" stroke-width="0.8" fill="none" /> + <polyline points="0,0 45,0 45,380 0,380 0,0" stroke="#f2f2f2" stroke-width="1" fill="none" /> + + <!-- <rect width="45" height="380" fill="#0f0" /> --> + <!-- <rect width="35" height="130" fill="#ddd" transform="translate(5 125)" /> --> + <!-- <g transform="translate(6 122) scale(5.0) rotate(90)"> --> + <!-- <text class="brand" font-size="7pt" letter-spacing="2px">BGA</text> --> + <!-- <rect width="3.0" height="3" fill="#ddd" transform="translate(11.5 -5)" /> --> + <!-- </g> --> +</svg> diff --git a/res-src/Blank6-src.svg b/res-src/Blank6-src.svg @@ -0,0 +1,39 @@ +<svg + version="1.1" + xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" + width="90" + height="380" + viewBox="0 0 90 380" +> + <style> + text { + fill: #333; + font-family: 'Roboto', sans-serif; + font-weight: bold; + } + text.title { + font-family: 'Comfortaa', sans-serif; + font-weight: normal; + } + text.brand { + font-family: 'Audiowide', sans-serif; + font-weight: bold; + } + </style> + + <defs> + </defs> + + <rect width="100%" height="100%" fill="#ddd" /> + <polyline points="1,1 89,1 89,379 1,379 1,1" stroke="#e4e4e4" stroke-width="0.5" fill="none" /> + <polyline points="0.5,0.5 89.5,0.5 89.5,379.5 0.5,379.5 0.5,0.5" stroke="#ebebeb" stroke-width="0.8" fill="none" /> + <polyline points="0,0 90,0 90,380 0,380 0,0" stroke="#f2f2f2" stroke-width="1" fill="none" /> + + <!-- <rect width="90" height="380" fill="#0f0" /> --> + <!-- <rect width="30" height="316" fill="#ddd" transform="translate(30 32)" /> --> + <!-- <g transform="translate(30 31) scale(4.0) rotate(90)"> --> + <!-- <text class="brand" font-size="8pt" letter-spacing="2px">BOGAUDIO</text> --> + <!-- <rect width="3.0" height="3" fill="#ddd" transform="translate(24 -5)" /> --> + <!-- </g> --> +</svg> diff --git a/res/Blank3.svg b/res/Blank3.svg Binary files differ. diff --git a/res/Blank6.svg b/res/Blank6.svg Binary files differ. diff --git a/res/fonts/audiowide.ttf b/res/fonts/audiowide.ttf Binary files differ. diff --git a/src/Blank3.cpp b/src/Blank3.cpp @@ -0,0 +1,93 @@ + +#include "Blank3.hpp" + +void Blank3::onSampleRateChange() { + _rms.setSampleRate(engineGetSampleRate()); +} + +void Blank3::step() { + if (inputs[IN_INPUT].active) { + _level = _rms.next(inputs[IN_INPUT].value) / 5.0f; + _level *= 1.43f; + _level = clamp(_level, 0.0f, 1.0f); + } + else { + _level = 1.0f; + } +} + +struct Blank3Display : OpaqueWidget { + const NVGcolor textColor = nvgRGBA(0x33, 0x33, 0x33, 0xff); + const NVGcolor bgColor = nvgRGBA(0xdd, 0xdd, 0xdd, 0xff); + Blank3* _module; + const char* _text; + std::shared_ptr<Font> _font; + + Blank3Display(Blank3* module, const char* text) + : _module(module) + , _text(text) + , _font(Font::load(assetPlugin(plugin, "res/fonts/audiowide.ttf"))) + { + } + + void draw(NVGcontext* vg) override { + if (_module->_level < 0.001f) { + return; + } + + float offsetX = box.size.x / 2.0f; + float offsetY = box.size.y / 2.0f; + nvgSave(vg); + nvgTranslate(vg, offsetX, offsetY); + if (_module->_level < 1.0f) { + const float discretize = 100.0f; + float level = roundf(_module->_level * discretize) * (1.0f / discretize); + nvgScale(vg, level, level); + } + + nvgSave(vg); + nvgRotate(vg, M_PI/2.0f); + nvgTranslate(vg, -offsetY, offsetX); + nvgFontSize(vg, 54.0f); + nvgFontFaceId(vg, _font->handle); + nvgTextLetterSpacing(vg, 9.0f); + nvgFillColor(vg, textColor); + nvgText(vg, 0, 0, _text, NULL); + nvgBeginPath(vg); + nvgRect(vg, 55, -20, 10, 10); + nvgFillColor(vg, bgColor); + nvgFill(vg); + nvgRestore(vg); + + nvgRestore(vg); + } +}; + +struct Blank3Widget : ModuleWidget { + static constexpr int hp = 3; + + Blank3Widget(Blank3* module) : ModuleWidget(module) { + box.size = Vec(RACK_GRID_WIDTH * hp, RACK_GRID_HEIGHT); + + { + SVGPanel *panel = new SVGPanel(); + panel->box.size = box.size; + panel->setBackground(SVG::load(assetPlugin(plugin, "res/Blank3.svg"))); + addChild(panel); + } + + { + auto display = new Blank3Display(module, "BGA"); + display->box.pos = Vec(7.5, 125); + display->box.size = Vec(30, 130); + addChild(display); + } + + addChild(Widget::create<ScrewSilver>(Vec(0, 0))); + addChild(Widget::create<ScrewSilver>(Vec(box.size.x - 15, 365))); + + addInput(Port::create<BlankPort24>(Vec(10.5, 346), Port::INPUT, module, Blank3::IN_INPUT)); + } +}; + +Model* modelBlank3 = createModel<Blank3, Blank3Widget>("Bogaudio-Blank3", "Blank3", "blank panel", BLANK_TAG); diff --git a/src/Blank3.hpp b/src/Blank3.hpp @@ -0,0 +1,41 @@ +#pragma once + +#include "bogaudio.hpp" +#include "dsp/signal.hpp" + +using namespace bogaudio::dsp; + +extern Model* modelBlank3; + +namespace bogaudio { + +struct Blank3 : Module { + enum ParamsIds { + NUM_PARAMS + }; + + enum InputsIds { + IN_INPUT, + NUM_INPUTS + }; + + enum OutputsIds { + NUM_OUTPUTS + }; + + enum LightsIds { + NUM_LIGHTS + }; + + RootMeanSquare _rms; + float _level = 0.0f; + + Blank3() : Module(NUM_PARAMS, NUM_INPUTS, NUM_OUTPUTS, NUM_LIGHTS) { + onSampleRateChange(); + } + + void onSampleRateChange() override; + void step() override; +}; + +} // namespace bogaudio diff --git a/src/Blank6.cpp b/src/Blank6.cpp @@ -0,0 +1,93 @@ + +#include "Blank6.hpp" + +void Blank6::onSampleRateChange() { + _rms.setSampleRate(engineGetSampleRate()); +} + +void Blank6::step() { + if (inputs[IN_INPUT].active) { + _level = _rms.next(inputs[IN_INPUT].value) / 5.0f; + _level *= 1.43f; + _level = clamp(_level, 0.0f, 1.0f); + } + else { + _level = 1.0f; + } +} + +struct Blank6Display : OpaqueWidget { + const NVGcolor textColor = nvgRGBA(0x33, 0x33, 0x33, 0xff); + const NVGcolor bgColor = nvgRGBA(0xdd, 0xdd, 0xdd, 0xff); + Blank6* _module; + const char* _text; + std::shared_ptr<Font> _font; + + Blank6Display(Blank6* module, const char* text) + : _module(module) + , _text(text) + , _font(Font::load(assetPlugin(plugin, "res/fonts/audiowide.ttf"))) + { + } + + void draw(NVGcontext* vg) override { + if (_module->_level < 0.001f) { + return; + } + + float offsetX = box.size.x / 2.0f; + float offsetY = box.size.y / 2.0f; + nvgSave(vg); + nvgTranslate(vg, offsetX, offsetY); + if (_module->_level < 1.0f) { + const float discretize = 100.0f; + float level = roundf(_module->_level * discretize) * (1.0f / discretize); + nvgScale(vg, level, level); + } + + nvgSave(vg); + nvgRotate(vg, M_PI/2.0f); + nvgTranslate(vg, -offsetY, offsetX); + nvgFontSize(vg, 54.0f); + nvgFontFaceId(vg, _font->handle); + nvgTextLetterSpacing(vg, 9.0f); + nvgFillColor(vg, textColor); + nvgText(vg, 0, 0, _text, NULL); + nvgBeginPath(vg); + nvgRect(vg, 99, -20, 10, 10); + nvgFillColor(vg, bgColor); + nvgFill(vg); + nvgRestore(vg); + + nvgRestore(vg); + } +}; + +struct Blank6Widget : ModuleWidget { + static constexpr int hp = 6; + + Blank6Widget(Blank6* module) : ModuleWidget(module) { + box.size = Vec(RACK_GRID_WIDTH * hp, RACK_GRID_HEIGHT); + + { + SVGPanel *panel = new SVGPanel(); + panel->box.size = box.size; + panel->setBackground(SVG::load(assetPlugin(plugin, "res/Blank6.svg"))); + addChild(panel); + } + + { + auto display = new Blank6Display(module, "BOGAUDIO"); + display->box.pos = Vec(30, 32); + display->box.size = Vec(30, 316); + addChild(display); + } + + addChild(Widget::create<ScrewSilver>(Vec(0, 0))); + addChild(Widget::create<ScrewSilver>(Vec(box.size.x - 15, 365))); + + addInput(Port::create<BlankPort24>(Vec(33, 346), Port::INPUT, module, Blank6::IN_INPUT)); + } +}; + +Model* modelBlank6 = createModel<Blank6, Blank6Widget>("Bogaudio-Blank6", "Blank6", "blank panel", BLANK_TAG); diff --git a/src/Blank6.hpp b/src/Blank6.hpp @@ -0,0 +1,41 @@ +#pragma once + +#include "bogaudio.hpp" +#include "dsp/signal.hpp" + +using namespace bogaudio::dsp; + +extern Model* modelBlank6; + +namespace bogaudio { + +struct Blank6 : Module { + enum ParamsIds { + NUM_PARAMS + }; + + enum InputsIds { + IN_INPUT, + NUM_INPUTS + }; + + enum OutputsIds { + NUM_OUTPUTS + }; + + enum LightsIds { + NUM_LIGHTS + }; + + RootMeanSquare _rms; + float _level = 0.0f; + + Blank6() : Module(NUM_PARAMS, NUM_INPUTS, NUM_OUTPUTS, NUM_LIGHTS) { + onSampleRateChange(); + } + + void onSampleRateChange() override; + void step() override; +}; + +} // namespace bogaudio diff --git a/src/bogaudio.cpp b/src/bogaudio.cpp @@ -6,6 +6,8 @@ #include "Additator.hpp" #include "AMRM.hpp" #include "Analyzer.hpp" +#include "Blank3.hpp" +#include "Blank6.hpp" #include "Bool.hpp" #include "Clpr.hpp" #include "Cmp.hpp" @@ -120,6 +122,11 @@ void init(rack::Plugin *p) { p->addModel(modelSwitch); #ifdef EXPERIMENTAL + p->addModel(modelBlank3); + p->addModel(modelBlank6); +#endif + +#ifdef EXPERIMENTAL p->addModel(modelLag); p->addModel(modelMatrix88); #endif diff --git a/src/widgets.cpp b/src/widgets.cpp @@ -60,6 +60,12 @@ Port24::Port24() { } +BlankPort24::BlankPort24() { + setSVG(NULL); + box.size = Vec(24, 24); +} + + SliderSwitch::SliderSwitch() { shadow = new CircularShadow(); addChild(shadow); diff --git a/src/widgets.hpp b/src/widgets.hpp @@ -46,6 +46,10 @@ struct Port24 : SVGPort { Port24(); }; +struct BlankPort24 : Port24 { + BlankPort24(); +}; + struct SliderSwitch : SVGSwitch, ToggleSwitch { CircularShadow* shadow = NULL; SliderSwitch();