--- qsampler/trunk/src/qsamplerDevice.cpp 2005/03/09 17:23:57 434 +++ qsampler/trunk/src/qsamplerDevice.cpp 2005/03/13 22:06:59 452 @@ -21,6 +21,9 @@ #include "qsamplerDevice.h" +#include +#include + #include "qsamplerMainForm.h" #include "qsamplerDeviceForm.h" @@ -132,7 +135,7 @@ m_sDeviceType = QObject::tr("MIDI"); pDeviceInfo = ::lscp_get_midi_device_info(pClient, iDeviceID); break; - default: + case qsamplerDevice::None: m_sDeviceType = QString::null; break; } @@ -140,7 +143,7 @@ // If we're bogus, bail out... if (pDeviceInfo == NULL) { m_sDriverName = QString::null; - m_sDeviceName = QObject::tr("New device"); + m_sDeviceName = QObject::tr("New %1 device").arg(m_sDeviceType); return; } @@ -163,10 +166,13 @@ pParamInfo = ::lscp_get_midi_driver_param_info(pClient, m_sDriverName.latin1(), pszParam, NULL); break; + case qsamplerDevice::None: + break; } - if (pParamInfo) + if (pParamInfo) { m_params[pszParam] = qsamplerDeviceParam(pParamInfo, pDeviceInfo->params[i].value); + } } } @@ -190,6 +196,8 @@ pDriverInfo = ::lscp_get_midi_driver_info(pClient, sDriverName.latin1()); break; + case qsamplerDevice::None: + break; } // If we're bogus, bail out... @@ -213,8 +221,11 @@ pParamInfo = ::lscp_get_midi_driver_param_info(pClient, sDriverName.latin1(), pszParam, NULL); break; + case qsamplerDevice::None: + break; } - m_params[pszParam] = qsamplerDeviceParam(pParamInfo, pParamInfo->defaultv); + if (pParamInfo) + m_params[pszParam] = qsamplerDeviceParam(pParamInfo, pParamInfo->defaultv); } } @@ -269,6 +280,8 @@ case qsamplerDevice::Midi: piDeviceIDs = ::lscp_list_midi_devices(pClient); break; + case qsamplerDevice::None: + break; } return piDeviceIDs; } @@ -288,6 +301,8 @@ case qsamplerDevice::Midi: ppszDrivers = ::lscp_get_available_midi_drivers(pClient); break; + case qsamplerDevice::None: + break; } for (int iDriver = 0; ppszDrivers[iDriver]; iDriver++) @@ -315,6 +330,8 @@ QListViewItem::setPixmap(0, QPixmap::fromMimeSource("midi1.png")); QListViewItem::setText(0, QObject::tr("MIDI devices")); break; + case qsamplerDevice::None: + break; } } @@ -330,6 +347,8 @@ case qsamplerDevice::Midi: QListViewItem::setPixmap(0, QPixmap::fromMimeSource("midi2.png")); break; + case qsamplerDevice::None: + break; } QListViewItem::setText(0, m_device.deviceName()); @@ -374,14 +393,14 @@ QTable::setLeftMargin(0); // Initialize the fixed table column headings. QHeader *pHeader = QTable::horizontalHeader(); - pHeader->setLabel(0, tr("Description")); - pHeader->setLabel(1, tr("Value")); - pHeader->setLabel(2, tr("Parameter")); + pHeader->setLabel(0, tr("Parameter")); + pHeader->setLabel(1, tr("Description")); + pHeader->setLabel(2, tr("Value")); // Set read-onlyness of each column QTable::setColumnReadOnly(0, true); -// QTable::setColumnReadOnly(1, true); -- of course not. - QTable::setColumnReadOnly(2, true); - QTable::setColumnStretchable(0, true); + QTable::setColumnReadOnly(1, true); +// QTable::setColumnReadOnly(2, true); -- of course not. + QTable::setColumnStretchable(1, true); } // Default destructor. @@ -404,39 +423,134 @@ qsamplerDeviceParamMap::ConstIterator iter; for (iter = params.begin(); iter != params.end(); ++iter) { const qsamplerDeviceParam& param = iter.data(); - bool fEnabled = (device.deviceID() < 0 || !param.fix); - QTable::setText(iRow, 0, param.description); - if (param.type == LSCP_TYPE_BOOL) { + bool bEnabled = (device.deviceID() < 0 || !param.fix); + QTable::setText(iRow, 0, iter.key()); + QTable::setText(iRow, 1, param.description); + if (param.type == LSCP_TYPE_BOOL && bEnabled) { QStringList opts; opts.append(tr("false")); opts.append(tr("true")); QComboTableItem *pComboItem = new QComboTableItem(this, opts); - pComboItem->setCurrentItem(param.value.lower() == "true" ? 1 : 0); - pComboItem->setEnabled(fEnabled); - QTable::setItem(iRow, 1, pComboItem); - } else if (param.possibilities.count() > 0 && !param.multiplicity) { + pComboItem->setCurrentItem(param.value.lower() == "true" ? 1 : 0); + pComboItem->setEnabled(bEnabled); + QTable::setItem(iRow, 2, pComboItem); + } else if (param.possibilities.count() > 0 && bEnabled) { QComboTableItem *pComboItem = new QComboTableItem(this, param.possibilities); - pComboItem->setCurrentItem(param.value); - pComboItem->setEnabled(fEnabled); - QTable::setItem(iRow, 1, pComboItem); + pComboItem->setCurrentItem(param.value); + pComboItem->setEnabled(bEnabled); + pComboItem->setEditable(bEnabled && param.multiplicity); + QTable::setItem(iRow, 2, pComboItem); + } else if (param.type == LSCP_TYPE_INT && bEnabled + && !param.range_min.isEmpty() + && !param.range_max.isEmpty()) { + qsamplerDeviceParamTableSpinBox *pSpinItem = + new qsamplerDeviceParamTableSpinBox(this, + bEnabled ? QTableItem::OnTyping : QTableItem::Never, + param.value); + pSpinItem->setMinValue(param.range_min.toInt()); + pSpinItem->setMaxValue(param.range_max.toInt()); + QTable::setItem(iRow, 2, pSpinItem); } else { - QTableItem* pTableItem = new QTableItem(this, - fEnabled ? QTableItem::Never : QTableItem::OnTyping, - param.value); - QTable::setItem(iRow, 1, pTableItem); + qsamplerDeviceParamTableEditBox *pEditItem = + new qsamplerDeviceParamTableEditBox(this, + bEnabled ? QTableItem::OnTyping : QTableItem::Never, + param.value); + QTable::setItem(iRow, 2, pEditItem); } - QTable::setText(iRow, 2, iter.key()); ++iRow; } // Adjust optimal column widths. - QTable::adjustColumn(1); + QTable::adjustColumn(0); QTable::adjustColumn(2); - + QTable::setUpdatesEnabled(true); QTable::updateContents(); } +//------------------------------------------------------------------------- +// qsamplerDeviceParamTableSpinBox - Custom spin box for parameter table. +// + +// Constructor. +qsamplerDeviceParamTableSpinBox::qsamplerDeviceParamTableSpinBox ( + QTable *pTable, EditType editType, const QString& sText ) + : QTableItem(pTable, editType, sText) +{ + m_iValue = sText.toInt(); + m_iMinValue = m_iMaxValue = 0; +} + +// Public accessors. +void qsamplerDeviceParamTableSpinBox::setValue ( int iValue ) +{ + m_iValue = iValue; + QTableItem::setText(QString::number(m_iValue)); +} + +void qsamplerDeviceParamTableSpinBox::setMinValue ( int iMinValue ) +{ + m_iMinValue = iMinValue; +} + +void qsamplerDeviceParamTableSpinBox::setMaxValue ( int iMaxValue ) +{ + m_iMaxValue = iMaxValue; +} + +// Virtual implemetations. +QWidget *qsamplerDeviceParamTableSpinBox::createEditor (void) const +{ + QSpinBox *pSpinBox = new QSpinBox(QTableItem::table()->viewport()); + QObject::connect(pSpinBox, SIGNAL(valueChanged(int)), + QTableItem::table(), SLOT(doValueChanged())); + if (m_iValue >= m_iMinValue && m_iMaxValue >= m_iValue) { + pSpinBox->setMinValue(m_iMinValue); + pSpinBox->setMaxValue(m_iMaxValue); + } + pSpinBox->setValue(m_iValue); + return pSpinBox; +} + +void qsamplerDeviceParamTableSpinBox::setContentFromEditor ( QWidget *pWidget ) +{ + if (pWidget->inherits("QSpinBox")) + QTableItem::setText(QString::number(((QSpinBox *) pWidget)->value())); + else + QTableItem::setContentFromEditor(pWidget); +} + + +//------------------------------------------------------------------------- +// qsamplerDeviceParamTableEditBox - Custom edit box for parameter table. +// + +// Constructor. +qsamplerDeviceParamTableEditBox::qsamplerDeviceParamTableEditBox ( + QTable *pTable, EditType editType, const QString& sText ) + : QTableItem(pTable, editType, sText) +{ +} + +// Virtual implemetations. +QWidget *qsamplerDeviceParamTableEditBox::createEditor (void) const +{ + QLineEdit *pEditBox = new QLineEdit(QTableItem::table()->viewport()); + QObject::connect(pEditBox, SIGNAL(returnPressed()), + QTableItem::table(), SLOT(doValueChanged())); + pEditBox->setText(QTableItem::text()); + return pEditBox; +} + +void qsamplerDeviceParamTableEditBox::setContentFromEditor ( QWidget *pWidget ) +{ + if (pWidget->inherits("QLineEdit")) + QTableItem::setText(((QLineEdit *) pWidget)->text()); + else + QTableItem::setContentFromEditor(pWidget); +} + + // end of qsamplerDevice.cpp