BogaudioModules

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

commit 5f3bee001c92d6b07e927d10fe642c7bd443e472
parent 5f196540eb2d64eb3386400faa9fe3834b183d53
Author: Matt Demanett <matt@demanett.net>
Date:   Wed,  3 Jan 2018 01:48:14 -0500

Reftone: knob guides, etc.

Diffstat:
Mres-src/Reftone-src.svg | 123++++++++++++++++++++++++++++++++++++++++++++++++++++++-------------------------
Mres/Reftone.svg | 0
Msrc/Reftone.cpp | 45+++++++++++++++++++++++++++++++--------------
3 files changed, 115 insertions(+), 53 deletions(-)

diff --git a/res-src/Reftone-src.svg b/res-src/Reftone-src.svg @@ -24,64 +24,108 @@ <defs> <symbol id="display" viewBox="0 0 45px 34px"> - <rect width="38" height="34" fill="#222" transform="translate(3.5 0)" /> + <rect width="38" height="48" fill="#222" transform="translate(3.5 0)" /> </symbol> <symbol id="knob" viewBox="0 0 45px 45px"> <g transform="translate(22.5 22.5)"> <polyline points="-5,0 5,0" stroke-width="1" stroke="#00f" /> <polyline points="0,-5 0,5" stroke-width="1" stroke="#00f" /> - <circle cx="0" cy="0" r="14.5" stroke-width="1" stroke="#00f" fill="none" /> + <circle r="12.5" stroke-width="1" stroke="#00f" fill="none" /> </g> </symbol> - <symbol id="knobguide" viewBox="0 0 45px 45px"> + <symbol id="knobguide-pitch" viewBox="0 0 45px 45px"> <g transform="translate(22.5 22.5)"> - <g transform="rotate(-240) translate(17 0)"> - <g transform="translate(3 0) rotate(240)"> - <text font-size="6.5pt" transform="translate(-2.8 3.3)">0</text> - </g> + <g transform="rotate(-240) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(240) translate(-2.2 2.2)">C</text> </g> - <g transform="rotate(-172.92) translate(17 0)"> - <polyline points="0,0 1.5,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-212.73) translate(15 0)"> + <polyline points="0,0 2.5,0" stroke-width="0.3" stroke="#333" /> </g> - <g transform="rotate(-145.13) translate(17 0)"> - <g transform="translate(3 0) rotate(145.13)"> - <text font-size="6.5pt" transform="translate(-2.8 3.3)">1</text> - </g> + <g transform="rotate(-185.45) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(185.45) translate(-2.2 2.2)">D</text> </g> - <g transform="rotate(-105.84) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-158.18) translate(15 0)"> + <polyline points="0,0 2.5,0" stroke-width="0.3" stroke="#333" /> </g> - <g transform="rotate(-75.68) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-130.91) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(130.91) translate(-2.2 2.2)">E</text> </g> - <g transform="rotate(-50.26) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-103.64) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(103.64) translate(-2.2 2.2)">F</text> </g> - <g transform="rotate(-27.87) translate(17 0)"> - <g transform="translate(3 0) rotate(27.87)"> - <text font-size="6.5pt" transform="translate(-2.8 3.3)">5</text> - </g> + <g transform="rotate(-76.36) translate(15 0)"> + <polyline points="0,0 2.5,0" stroke-width="0.3" stroke="#333" /> </g> - <g transform="rotate(-7.62) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-49.09) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(49.09) translate(-2.2 2.2)">G</text> </g> - <g transform="rotate(11) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(-21.82) translate(15 0)"> + <polyline points="0,0 2.5,0" stroke-width="0.3" stroke="#333" /> </g> - <g transform="rotate(28.33) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(5.45) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(-5.45) translate(-2.2 2.2)">A</text> </g> - <g transform="rotate(44.6) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(32.73) translate(15 0)"> + <polyline points="0,0 2.5,0" stroke-width="0.3" stroke="#333" /> </g> - <g transform="rotate(60) translate(17 0)"> - <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> + <g transform="rotate(60) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(-60) translate(-2.2 2.2)">B</text> </g> </g> </symbol> + <symbol id="knobguide-octave" viewBox="0 0 45px 45px"> + <g transform="translate(22.5 22.5)"> + <g transform="rotate(-240) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(240) translate(-2.2 2.2)">1</text> + </g> + <g transform="rotate(-197.14) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(197.14) translate(-2.2 2.2)">2</text> + </g> + <g transform="rotate(-154.29) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(154.29) translate(-2.2 2.2)">3</text> + </g> + <g transform="rotate(-111.43) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(111.43) translate(-2.2 2.2)">4</text> + </g> + <g transform="rotate(-68.57) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(68.57) translate(-2.2 2.2)">5</text> + </g> + <g transform="rotate(-25.71) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(25.71) translate(-2.2 2.2)">6</text> + </g> + <g transform="rotate(17.14) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(-17.14) translate(-2.2 2.2)">7</text> + </g> + <g transform="rotate(60) translate(15 0)"> + <text font-size="5.0pt" transform="translate(2 0) rotate(-60) translate(-2.2 2.2)">8</text> + </g> + </g> + </symbol> + + <symbol id="knobguide-fine" viewBox="0 0 45px 45px"> + <g transform="translate(22.5 22.5)"> + <g transform="rotate(-240) translate(15 0)"> + <!-- <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> --> + <text font-size="5.0pt" transform="translate(2.5 0) rotate(240) translate(-1.5 2.2)">-</text> + </g> + <g transform="rotate(-90) translate(15 0)"> + <!-- <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> --> + <text font-size="5.0pt" transform="translate(2 0) rotate(90) translate(-1.9 2.2)">0</text> + </g> + <g transform="rotate(60) translate(15 0)"> + <!-- <polyline points="0,0 3,0" stroke-width="0.3" stroke="#333" /> --> + <text font-size="5.0pt" transform="translate(2.5 0) rotate(-60) translate(-1.9 2.2)">+</text> + </g> + <path d="M 0 -17.5 A 17.5 17.5 0 0 1 17.5 0" stroke="#333" stroke-width="0.5" stroke-linecap="round" fill="none" transform="rotate(20)" /> + <path d="M 0 -17.5 A 17.5 17.5 0 0 1 17.5 0" stroke="#333" stroke-width="0.5" stroke-linecap="round" fill="none" transform="rotate(43)" /> + <path d="M 0 -17.5 A 17.5 17.5 0 0 0 -17.5 0" stroke="#333" stroke-width="0.5" stroke-linecap="round" fill="none" transform="rotate(-20)" /> + <path d="M 0 -17.5 A 17.5 17.5 0 0 0 -17.5 0" stroke="#333" stroke-width="0.5" stroke-linecap="round" fill="none" transform="rotate(-43)" /> + </g> + </symbol> + <symbol id="output" viewBox="0 0 24px 24px"> <g transform="translate(12 12)"> <circle cx="0" cy="0" r="5" stroke-width="1" stroke="#f00" fill="#f00" /> @@ -111,27 +155,28 @@ <g transform="translate(0 18)"> <use id="DISPLAY_WIDGET" xlink:href="#display" /> - <g transform="translate(0 47)"> + <g transform="translate(0 62)"> <g transform="translate(0 0)"> <text font-size="6pt" letter-spacing="2px" transform="translate(7 0)">PITCH</text> <use id="PITCH_PARAM" xlink:href="#knob" transform="translate(0 0)" /> - <!-- <use xlink:href="#knobguide" transform="translate(0 0)" /> --> </g> - <g transform="translate(0 59)"> + <g transform="translate(0 55)"> <text font-size="6pt" letter-spacing="2px" transform="translate(2.5 0)">OCTAVE</text> <use id="OCTAVE_PARAM" xlink:href="#knob" transform="translate(0 0)" /> - <!-- <use xlink:href="#knobguide" transform="translate(0 0)" /> --> </g> - <g transform="translate(0 118)"> + <g transform="translate(0 108)"> <text font-size="6pt" letter-spacing="2px" transform="translate(11 0)">FINE</text> <use id="FINE_PARAM" xlink:href="#knob" transform="translate(0 0)" /> - <!-- <use xlink:href="#knobguide" transform="translate(0 0)" /> --> </g> </g> </g> + <use xlink:href="#knobguide-pitch" transform="translate(0 80)" /> + <use xlink:href="#knobguide-octave" transform="translate(0 135)" /> + <use xlink:href="#knobguide-fine" transform="translate(0 188)" /> + <g transform="translate(0 235)"> <g transform="translate(0 0)"> <rect width="34" height="75" rx="5" fill="#bbb" transform="translate(5.5 0)" /> diff --git a/res/Reftone.svg b/res/Reftone.svg Binary files differ. diff --git a/src/Reftone.cpp b/src/Reftone.cpp @@ -56,7 +56,7 @@ void Reftone::step() { struct ReftoneDisplay : TransparentWidget { - const NVGcolor _textColor = nvgRGBA(0x00, 0xff, 0x00, 0xf0); + const NVGcolor _textColor = nvgRGBA(0x00, 0xff, 0x00, 0xff); Reftone* _module; const Vec _size; @@ -81,8 +81,12 @@ void ReftoneDisplay::draw(NVGcontext* vg) { char octave[2]; snprintf(octave, 2, "%d", _module->_octave); - char fine[6]; - snprintf(fine, 6, "%+0.2f", _module->_fine); + char fine[4]; + fine[0] = _module->_fine < 0.0 ? '-' : '+'; + snprintf(fine + 1, 3, "%02d", abs((int)(_module->_fine * 100))); + + char frequency[20]; + snprintf(frequency, 20, "%0.0fhz", _module->_frequency); const char* pitch = NULL; const char* sharpFlat = NULL; @@ -143,12 +147,25 @@ void ReftoneDisplay::draw(NVGcontext* vg) { } drawBackground(vg); - drawText(vg, pitch, 2, 17, 23); if (sharpFlat) { - drawText(vg, sharpFlat, 13, 12, 18); + drawText(vg, pitch, 2, 17, 23); + drawText(vg, sharpFlat, 13, 13, 18); + drawText(vg, octave, 21, 17, 23); + } + else { + drawText(vg, pitch, 5, 17, 23); + drawText(vg, octave, 18, 17, 23); + } + drawText(vg, fine, 8, 30, 12); + + int x = 2; + if (strlen(frequency) < 5) { + x += 4; + } + else if (strlen(frequency) < 6) { + x += 2; } - drawText(vg, octave, 21, 17, 23); - drawText(vg, fine, 3, 30, 12); + drawText(vg, frequency, x, 42, 10); } void ReftoneDisplay::drawBackground(NVGcontext* vg) { @@ -185,7 +202,7 @@ ReftoneWidget::ReftoneWidget() { { auto inset = Vec(5.5, 18); - auto size = Vec(34, 34); + auto size = Vec(34, 48); auto display = new ReftoneDisplay(module, size); display->box.pos = inset; display->box.size = size; @@ -196,25 +213,25 @@ ReftoneWidget::ReftoneWidget() { addChild(createScrew<ScrewSilver>(Vec(box.size.x - 15, 365))); // generated by svg_widgets.rb - auto pitchParamPosition = Vec(7.5, 71.5); - auto octaveParamPosition = Vec(7.5, 130.5); - auto fineParamPosition = Vec(7.5, 189.5); + auto pitchParamPosition = Vec(9.5, 89.5); + auto octaveParamPosition = Vec(9.5, 144.5); + auto fineParamPosition = Vec(9.5, 197.5); auto cvOutputPosition = Vec(10.5, 239.0); auto outOutputPosition = Vec(10.5, 274.0); // end generated by svg_widgets.rb { - auto w = createParam<Knob29>(pitchParamPosition, module, Reftone::PITCH_PARAM, 0.0, 11.0, 9.0); + auto w = createParam<Knob26>(pitchParamPosition, module, Reftone::PITCH_PARAM, 0.0, 11.0, 9.0); dynamic_cast<Knob*>(w)->snap = true; addParam(w); } { - auto w = createParam<Knob29>(octaveParamPosition, module, Reftone::OCTAVE_PARAM, 1.0, 8.0, 4.0); + auto w = createParam<Knob26>(octaveParamPosition, module, Reftone::OCTAVE_PARAM, 1.0, 8.0, 4.0); dynamic_cast<Knob*>(w)->snap = true; addParam(w); } - addParam(createParam<Knob29>(fineParamPosition, module, Reftone::FINE_PARAM, -0.99, 0.99, 0.0)); + addParam(createParam<Knob26>(fineParamPosition, module, Reftone::FINE_PARAM, -0.99, 0.99, 0.0)); addOutput(createOutput<Port24>(cvOutputPosition, module, Reftone::CV_OUTPUT)); addOutput(createOutput<Port24>(outOutputPosition, module, Reftone::OUT_OUTPUT));