Mercurial > hg > svgui
diff widgets/UnitConverter.cpp @ 892:af63372e9002
Start connecting up tempo bits
author | Chris Cannam |
---|---|
date | Tue, 09 Dec 2014 13:53:44 +0000 |
parents | 09b2940f483a |
children | 78ae34f388f6 |
line wrap: on
line diff
--- a/widgets/UnitConverter.cpp Tue Dec 09 12:17:04 2014 +0000 +++ b/widgets/UnitConverter.cpp Tue Dec 09 13:53:44 2014 +0000 @@ -90,17 +90,14 @@ m_cents->setMaximum(50); connect(m_cents, SIGNAL(valueChanged(double)), this, SLOT(centsChanged(double))); - - m_piano = new QSpinBox; - //!!! int row = 1; - grid->addWidget(m_freq, row, 0, 2, 1); - grid->addWidget(new QLabel(tr("=")), row, 1, 2, 1); + grid->addWidget(m_freq, row, 0, 2, 1, Qt::AlignRight | Qt::AlignVCenter); + grid->addWidget(new QLabel(tr("=")), row, 1, 2, 1, Qt::AlignHCenter | Qt::AlignVCenter); - grid->addWidget(new QLabel(tr("+")), row, 7, 2, 1); - grid->addWidget(m_cents, row, 8, 2, 1); + grid->addWidget(new QLabel(tr("+")), row, 7, 2, 1, Qt::AlignHCenter | Qt::AlignVCenter); + grid->addWidget(m_cents, row, 8, 2, 1, Qt::AlignLeft | Qt::AlignVCenter); grid->addWidget(new QLabel(tr("Piano note")), row, 2, 1, 2); grid->addWidget(m_note, row, 4); @@ -132,10 +129,78 @@ grid = new QGridLayout; frame->setLayout(grid); + m_samples = new QDoubleSpinBox; + m_samples->setSuffix(QString(" samples")); + m_samples->setDecimals(3); + m_samples->setMinimum(2); + m_samples->setMaximum(1e10); + m_samples->setValue(22050); + connect(m_samples, SIGNAL(valueChanged(double)), + this, SLOT(samplesChanged(double))); + + m_period = new QDoubleSpinBox; + m_period->setSuffix(QString(" ms")); + m_period->setDecimals(4); + m_period->setMinimum(1e-10); + m_period->setMaximum(1000); + m_period->setValue(500); + connect(m_period, SIGNAL(valueChanged(double)), + this, SLOT(periodChanged(double))); + + m_bpm = new QDoubleSpinBox; + m_bpm->setSuffix(QString(" bpm")); + m_bpm->setDecimals(4); + m_bpm->setMinimum(0.1); + m_bpm->setMaximum(1e6); + m_bpm->setValue(120); + connect(m_bpm, SIGNAL(valueChanged(double)), + this, SLOT(bpmChanged(double))); + + m_tempofreq = new QDoubleSpinBox; + m_tempofreq->setSuffix(QString(" beats/sec")); + m_tempofreq->setDecimals(4); + m_tempofreq->setMinimum(1e-4); + m_tempofreq->setMaximum(1e6); + m_tempofreq->setValue(0.5); + connect(m_tempofreq, SIGNAL(valueChanged(double)), + this, SLOT(tempofreqChanged(double))); + + m_samplerate = new QComboBox; + QList<int> rates; + rates << 8000; + for (int i = 1; i <= 16; i *= 2) { + rates << 11025 * i << 12000 * i; + } + foreach (int r, rates) { + m_samplerate->addItem(QString("%1 Hz").arg(r)); + } + connect(m_samplerate, SIGNAL(currentItemChanged(QString)), + this, SLOT(samplerateChanged(QString))); + m_samplerate->setCurrentText("44100 Hz"); + connect(Preferences::getInstance(), SIGNAL(propertyChanged(PropertyContainer::PropertyName)), this, SLOT(preferenceChanged(PropertyContainer::PropertyName))); + + row = 1; + + grid->addWidget(new QLabel(tr("Beat period")), row, 0); + grid->addWidget(m_samples, row, 1); + grid->addWidget(new QLabel(tr("=")), row, 2); + + grid->addWidget(new QLabel(tr("at sample rate")), row, 4); + grid->addWidget(m_samplerate, row, 5); + + grid->addWidget(m_bpm, row, 3); + + ++row; + grid->addWidget(m_period, row, 3); + + ++row; + + grid->addWidget(m_tempofreq, row, 3); + updatePitchesFromFreq(); updatePitchPrefsLabel(); updateTempiFromSamples(); @@ -211,15 +276,9 @@ } void -UnitConverter::pianoChanged(int piano) -{ - cerr << "pianoChanged: " << piano << endl; -} - -void UnitConverter::updatePitchesFromFreq() { - float cents = 0; + double cents = 0; int pitch = Pitch::getPitchForFrequency(m_freq->value(), ¢s); int note, octave; Pitch::getNoteAndOctaveForPitch(pitch, note, octave); @@ -243,8 +302,72 @@ } void +UnitConverter::samplesChanged(double) +{ + updateTempiFromSamples(); +} + +void +UnitConverter::periodChanged(double) +{ + double rate = getSampleRate(); + double sec = m_period->value() / 1000.0; + double samples = rate * sec; + m_samples->setValue(samples); +} + +void +UnitConverter::bpmChanged(double) +{ + double rate = getSampleRate(); + double sec = 60.0 / m_bpm->value(); + double samples = rate * sec; + m_samples->setValue(samples); +} + +void +UnitConverter::tempofreqChanged(double) +{ + double rate = getSampleRate(); + double samples = rate / m_tempofreq->value(); + m_samples->setValue(samples); +} + +void +UnitConverter::samplerateChanged(QString) +{ + updateTempiFromSamples(); +} + +double +UnitConverter::getSampleRate() +{ + return double(atoi(m_samplerate->currentText().toLocal8Bit().data())); +} + +void UnitConverter::updateTempiFromSamples() { + double samples = m_samples->value(); + double rate = getSampleRate(); + + cerr << samples << " samples at rate " << rate << endl; + + double sec = samples / rate; + double hz = rate / samples; + double bpm = 60.0 / sec; + + m_bpm->blockSignals(true); + m_period->blockSignals(true); + m_tempofreq->blockSignals(true); + + m_bpm->setValue(bpm); + m_period->setValue(sec * 1000.0); + m_tempofreq->setValue(hz); + + m_bpm->blockSignals(false); + m_period->blockSignals(false); + m_tempofreq->blockSignals(false); }