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:
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();