Mercurial > hg > svgui
diff widgets/UnitConverter.cpp @ 888:cb3a3e20634d
Fixes to limits etc in unit converter
author | Chris Cannam |
---|---|
date | Mon, 08 Dec 2014 15:37:49 +0000 |
parents | 139aad8bb445 |
children | cd59f6e1aa26 |
line wrap: on
line diff
--- a/widgets/UnitConverter.cpp Tue Dec 02 17:53:17 2014 +0000 +++ b/widgets/UnitConverter.cpp Mon Dec 08 15:37:49 2014 +0000 @@ -23,6 +23,7 @@ #include "base/Debug.h" #include "base/Pitch.h" +#include "base/Preferences.h" using namespace std; @@ -40,15 +41,18 @@ m_hz = new QDoubleSpinBox; m_hz->setSuffix(QString(" Hz")); m_hz->setDecimals(6); - m_hz->setMinimum(1e-6); + m_hz->setMinimum(1e-3); m_hz->setMaximum(1e6); m_hz->setValue(440); connect(m_hz, SIGNAL(valueChanged(double)), this, SLOT(hzChanged(double))); + // The min and max range values for all the remaining controls are + // determined by the min and max Hz above + m_midi = new QSpinBox; - m_midi->setMinimum(0); - m_midi->setMaximum(127); + m_midi->setMinimum(-156); + m_midi->setMaximum(203); connect(m_midi, SIGNAL(valueChanged(int)), this, SLOT(midiChanged(int))); @@ -60,8 +64,8 @@ this, SLOT(noteChanged(int))); m_octave = new QSpinBox; - m_octave->setMinimum(-4); - m_octave->setMaximum(12); + m_octave->setMinimum(-14); + m_octave->setMaximum(15); connect(m_octave, SIGNAL(valueChanged(int)), this, SLOT(octaveChanged(int))); @@ -91,11 +95,28 @@ ++row; - grid->addWidget(new QLabel(tr("MIDI note")), row, 2, 1, 2); + grid->addWidget(new QLabel(tr("MIDI pitch")), row, 2, 1, 2); grid->addWidget(m_midi, row, 4); ++row; + grid->addWidget + (new QLabel(tr("With concert A tuning frequency at %1 Hz, and " + "middle C residing in octave %2.\n" + "(These can be changed in the application preferences.)") + .arg(Preferences::getInstance()->getTuningFrequency()) + .arg(Preferences::getInstance()->getOctaveOfMiddleC())), + row, 0, 1, 9); + + ++row; + + grid->addWidget + (new QLabel(tr("Note that only pitches in the range 0 to 127 are valid " + "in the MIDI protocol.")), + row, 0, 1, 9); + + ++row; + QDialogButtonBox *bb = new QDialogButtonBox(QDialogButtonBox::Close); grid->addWidget(bb, row, 0, 1, 9); connect(bb, SIGNAL(rejected()), this, SLOT(close())); @@ -118,8 +139,9 @@ UnitConverter::midiChanged(int midi) { cerr << "midiChanged: " << midi << endl; - m_hz->setValue(Pitch::getFrequencyForPitch(m_midi->value(), m_cents->value())); - updateAllFromHz(); + double hz = Pitch::getFrequencyForPitch(m_midi->value(), m_cents->value()); + cerr << "hz -> " << hz << endl; + m_hz->setValue(hz); } void @@ -128,21 +150,29 @@ cerr << "noteChanged: " << note << endl; int pitch = Pitch::getPitchForNoteAndOctave(m_note->currentIndex(), m_octave->value()); - m_hz->setValue(Pitch::getFrequencyForPitch(pitch, m_cents->value())); + double hz = Pitch::getFrequencyForPitch(pitch, m_cents->value()); + cerr << "hz -> " << hz << endl; + m_hz->setValue(hz); } void UnitConverter::octaveChanged(int oct) { cerr << "octaveChanged: " << oct << endl; + int pitch = Pitch::getPitchForNoteAndOctave(m_note->currentIndex(), + m_octave->value()); + double hz = Pitch::getFrequencyForPitch(pitch, m_cents->value()); + cerr << "hz -> " << hz << endl; + m_hz->setValue(hz); } void UnitConverter::centsChanged(double cents) { cerr << "centsChanged: " << cents << endl; - m_hz->setValue(Pitch::getFrequencyForPitch(m_midi->value(), m_cents->value())); - updateAllFromHz(); + double hz = Pitch::getFrequencyForPitch(m_midi->value(), m_cents->value()); + cerr << "hz -> " << hz << endl; + m_hz->setValue(hz); } void @@ -159,6 +189,8 @@ int note, octave; Pitch::getNoteAndOctaveForPitch(pitch, note, octave); + cerr << "pitch " << pitch << " note " << note << " octave " << octave << " cents " << cents << endl; + m_midi->blockSignals(true); m_cents->blockSignals(true); m_note->blockSignals(true);