--- qsampler/trunk/src/qsamplerDevice.cpp 2005/08/28 11:44:10 759 +++ qsampler/trunk/src/qsamplerDevice.cpp 2007/11/17 02:02:28 1486 @@ -1,7 +1,8 @@ // qsamplerDevice.cpp // /**************************************************************************** - Copyright (C) 2005, rncbc aka Rui Nuno Capela. All rights reserved. + Copyright (C) 2004-2007, rncbc aka Rui Nuno Capela. All rights reserved. + Copyright (C) 2007, Christian Schoenebeck This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License @@ -13,9 +14,9 @@ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. *****************************************************************************/ @@ -28,6 +29,7 @@ #include #include +using namespace QSampler; //------------------------------------------------------------------------- // qsamplerDeviceParam - MIDI/Audio Device parameter structure. @@ -103,11 +105,8 @@ // // Constructor. -qsamplerDevice::qsamplerDevice ( qsamplerMainForm *pMainForm, - qsamplerDeviceType deviceType, int iDeviceID ) +qsamplerDevice::qsamplerDevice ( qsamplerDeviceType deviceType, int iDeviceID ) { - m_pMainForm = pMainForm; - m_ports.setAutoDelete(true); setDevice(deviceType, iDeviceID); @@ -122,7 +121,6 @@ qsamplerDevice::qsamplerDevice ( const qsamplerDevice& device ) : m_params(device.m_params), m_ports(m_ports) { - m_pMainForm = device.m_pMainForm; m_iDeviceID = device.m_iDeviceID; m_deviceType = device.m_deviceType; m_sDeviceType = device.m_sDeviceType; @@ -134,6 +132,12 @@ // Initializer. void qsamplerDevice::setDevice ( qsamplerDeviceType deviceType, int iDeviceID ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return; + if (pMainForm->client() == NULL) + return; + // Device id and type should be always set. m_iDeviceID = iDeviceID; m_deviceType = deviceType; @@ -148,13 +152,13 @@ case qsamplerDevice::Audio: m_sDeviceType = QObject::tr("Audio"); if (m_iDeviceID >= 0 && (pDeviceInfo = ::lscp_get_audio_device_info( - client(), m_iDeviceID)) == NULL) + pMainForm->client(), m_iDeviceID)) == NULL) appendMessagesClient("lscp_get_audio_device_info"); break; case qsamplerDevice::Midi: m_sDeviceType = QObject::tr("MIDI"); if (m_iDeviceID >= 0 && (pDeviceInfo = ::lscp_get_midi_device_info( - client(), m_iDeviceID)) == NULL) + pMainForm->client(), m_iDeviceID)) == NULL) appendMessagesClient("lscp_get_midi_device_info"); break; case qsamplerDevice::None: @@ -179,12 +183,12 @@ lscp_param_info_t *pParamInfo = NULL; switch (deviceType) { case qsamplerDevice::Audio: - if ((pParamInfo = ::lscp_get_audio_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_audio_driver_param_info(pMainForm->client(), m_sDriverName.latin1(), sParam.latin1(), NULL)) == NULL) appendMessagesClient("lscp_get_audio_driver_param_info"); break; case qsamplerDevice::Midi: - if ((pParamInfo = ::lscp_get_midi_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_midi_driver_param_info(pMainForm->client(), m_sDriverName.latin1(), sParam.latin1(), NULL)) == NULL) appendMessagesClient("lscp_get_midi_driver_param_info"); break; @@ -207,6 +211,12 @@ // Driver name initializer/settler. void qsamplerDevice::setDriver ( const QString& sDriverName ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return; + if (pMainForm->client() == NULL) + return; + // Valid only for scratch devices. if (m_sDriverName == sDriverName) return; @@ -219,12 +229,12 @@ lscp_driver_info_t *pDriverInfo = NULL; switch (m_deviceType) { case qsamplerDevice::Audio: - if ((pDriverInfo = ::lscp_get_audio_driver_info(client(), + if ((pDriverInfo = ::lscp_get_audio_driver_info(pMainForm->client(), sDriverName.latin1())) == NULL) appendMessagesClient("lscp_get_audio_driver_info"); break; case qsamplerDevice::Midi: - if ((pDriverInfo = ::lscp_get_midi_driver_info(client(), + if ((pDriverInfo = ::lscp_get_midi_driver_info(pMainForm->client(), sDriverName.latin1())) == NULL) appendMessagesClient("lscp_get_midi_driver_info"); break; @@ -245,12 +255,12 @@ lscp_param_info_t *pParamInfo = NULL; switch (m_deviceType) { case qsamplerDevice::Audio: - if ((pParamInfo = ::lscp_get_audio_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_audio_driver_param_info(pMainForm->client(), sDriverName.latin1(), sParam.latin1(), NULL)) == NULL) appendMessagesClient("lscp_get_audio_driver_param_info"); break; case qsamplerDevice::Midi: - if ((pParamInfo = ::lscp_get_midi_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_midi_driver_param_info(pMainForm->client(), sDriverName.latin1(), sParam.latin1(), NULL)) == NULL) appendMessagesClient("lscp_get_midi_driver_param_info"); break; @@ -270,16 +280,6 @@ } -// The client descriptor delegated property. -lscp_client_t *qsamplerDevice::client (void) const -{ - if (m_pMainForm == NULL) - return NULL; - - return m_pMainForm->client(); -} - - // Device property accessors. int qsamplerDevice::deviceID (void) const { @@ -315,12 +315,18 @@ bool qsamplerDevice::setParam ( const QString& sParam, const QString& sValue ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return false; + if (pMainForm->client() == NULL) + return false; + // Set proper device parameter. m_params[sParam.upper()].value = sValue; // If the device already exists, things get immediate... int iRefresh = 0; - if (m_iDeviceID >= 0) { + if (m_iDeviceID >= 0 && sValue != QString::null) { // Prepare parameter struct. lscp_param_t param; param.key = (char *) sParam.latin1(); @@ -330,13 +336,13 @@ switch (m_deviceType) { case qsamplerDevice::Audio: if (sParam == "CHANNELS") iRefresh++; - if ((ret = ::lscp_set_audio_device_param(client(), + if ((ret = ::lscp_set_audio_device_param(pMainForm->client(), m_iDeviceID, ¶m)) != LSCP_OK) appendMessagesClient("lscp_set_audio_device_param"); break; case qsamplerDevice::Midi: if (sParam == "PORTS") iRefresh++; - if ((ret = ::lscp_set_midi_device_param(client(), + if ((ret = ::lscp_set_midi_device_param(pMainForm->client(), m_iDeviceID, ¶m)) != LSCP_OK) appendMessagesClient("lscp_set_midi_device_param"); break; @@ -379,7 +385,10 @@ // Create a new device, as a copy of this current one. bool qsamplerDevice::createDevice (void) { - if (client() == NULL) + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return false; + if (pMainForm->client() == NULL) return false; // Build the parameter list... @@ -387,6 +396,7 @@ int iParam = 0; qsamplerDeviceParamMap::ConstIterator iter; for (iter = m_params.begin(); iter != m_params.end(); ++iter) { + if (iter.data().value == QString::null) continue; pParams[iParam].key = (char *) iter.key().latin1(); pParams[iParam].value = (char *) iter.data().value.latin1(); ++iParam; @@ -398,12 +408,12 @@ // Now it depends on the device type... switch (m_deviceType) { case qsamplerDevice::Audio: - if ((m_iDeviceID = ::lscp_create_audio_device(client(), + if ((m_iDeviceID = ::lscp_create_audio_device(pMainForm->client(), m_sDriverName.latin1(), pParams)) < 0) appendMessagesClient("lscp_create_audio_device"); break; case qsamplerDevice::Midi: - if ((m_iDeviceID = ::lscp_create_midi_device(client(), + if ((m_iDeviceID = ::lscp_create_midi_device(pMainForm->client(), m_sDriverName.latin1(), pParams)) < 0) appendMessagesClient("lscp_create_midi_device"); break; @@ -431,16 +441,22 @@ // Destroy existing device. bool qsamplerDevice::deleteDevice (void) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return false; + if (pMainForm->client() == NULL) + return false; + // Now it depends on the device type... lscp_status_t ret = LSCP_FAILED; switch (m_deviceType) { case qsamplerDevice::Audio: - if ((ret = ::lscp_destroy_audio_device(client(), + if ((ret = ::lscp_destroy_audio_device(pMainForm->client(), m_iDeviceID)) != LSCP_OK) appendMessagesClient("lscp_destroy_audio_device"); break; case qsamplerDevice::Midi: - if ((ret = ::lscp_destroy_midi_device(client(), + if ((ret = ::lscp_destroy_midi_device(pMainForm->client(), m_iDeviceID)) != LSCP_OK) appendMessagesClient("lscp_destroy_midi_device"); break; @@ -526,6 +542,12 @@ // Refresh/set given parameter based on driver supplied dependencies. int qsamplerDevice::refreshParam ( const QString& sParam ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return 0; + if (pMainForm->client() == NULL) + return 0; + // Check if we have dependencies... qsamplerDeviceParam& param = m_params[sParam.upper()]; if (param.depends.isEmpty()) @@ -556,12 +578,12 @@ lscp_param_info_t *pParamInfo = NULL; switch (m_deviceType) { case qsamplerDevice::Audio: - if ((pParamInfo = ::lscp_get_audio_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_audio_driver_param_info(pMainForm->client(), m_sDriverName.latin1(), sParam.latin1(), pDepends)) == NULL) appendMessagesClient("lscp_get_audio_driver_param_info"); break; case qsamplerDevice::Midi: - if ((pParamInfo = ::lscp_get_midi_driver_param_info(client(), + if ((pParamInfo = ::lscp_get_midi_driver_param_info(pMainForm->client(), m_sDriverName.latin1(), sParam.latin1(), pDepends)) == NULL) appendMessagesClient("lscp_get_midi_driver_param_info"); break; @@ -569,7 +591,10 @@ break; } if (pParamInfo) { - param = qsamplerDeviceParam(pParamInfo, QString(param.value)); + if (param.value != QString::null) + param = qsamplerDeviceParam(pParamInfo, param.value); + else + param = qsamplerDeviceParam(pParamInfo, NULL); iRefresh++; } @@ -584,33 +609,38 @@ // Redirected messages output methods. void qsamplerDevice::appendMessages( const QString& s ) const { - if (m_pMainForm) - m_pMainForm->appendMessages(deviceName() + ' ' + s); + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm) + pMainForm->appendMessages(deviceName() + ' ' + s); } void qsamplerDevice::appendMessagesColor( const QString& s, const QString& c ) const { - if (m_pMainForm) - m_pMainForm->appendMessagesColor(deviceName() + ' ' + s, c); + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm) + pMainForm->appendMessagesColor(deviceName() + ' ' + s, c); } void qsamplerDevice::appendMessagesText( const QString& s ) const { - if (m_pMainForm) - m_pMainForm->appendMessagesText(deviceName() + ' ' + s); + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm) + pMainForm->appendMessagesText(deviceName() + ' ' + s); } void qsamplerDevice::appendMessagesError( const QString& s ) const { - if (m_pMainForm) - m_pMainForm->appendMessagesError(deviceName() + "\n\n" + s); + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm) + pMainForm->appendMessagesError(deviceName() + "\n\n" + s); } void qsamplerDevice::appendMessagesClient( const QString& s ) const { - if (m_pMainForm) - m_pMainForm->appendMessagesClient(deviceName() + ' ' + s); + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm) + pMainForm->appendMessagesClient(deviceName() + ' ' + s); } @@ -651,7 +681,7 @@ break; } - for (int iDriver = 0; ppszDrivers[iDriver]; iDriver++) + for (int iDriver = 0; ppszDrivers && ppszDrivers[iDriver]; iDriver++) drivers.append(ppszDrivers[iDriver]); return drivers; @@ -678,6 +708,12 @@ // Initializer. void qsamplerDevicePort::setDevicePort ( int iPortID ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return; + if (pMainForm->client() == NULL) + return; + // Device port id should be always set. m_iPortID = iPortID; @@ -688,12 +724,12 @@ lscp_device_port_info_t *pPortInfo = NULL; switch (m_device.deviceType()) { case qsamplerDevice::Audio: - if ((pPortInfo = ::lscp_get_audio_channel_info(m_device.client(), + if ((pPortInfo = ::lscp_get_audio_channel_info(pMainForm->client(), m_device.deviceID(), m_iPortID)) == NULL) m_device.appendMessagesClient("lscp_get_audio_channel_info"); break; case qsamplerDevice::Midi: - if ((pPortInfo = ::lscp_get_midi_port_info(m_device.client(), + if ((pPortInfo = ::lscp_get_midi_port_info(pMainForm->client(), m_device.deviceID(), m_iPortID)) == NULL) m_device.appendMessagesClient("lscp_get_midi_port_info"); break; @@ -718,13 +754,13 @@ switch (m_device.deviceType()) { case qsamplerDevice::Audio: if ((pParamInfo = ::lscp_get_audio_channel_param_info( - m_device.client(), m_device.deviceID(), + pMainForm->client(), m_device.deviceID(), m_iPortID, sParam.latin1())) == NULL) m_device.appendMessagesClient("lscp_get_audio_channel_param_info"); break; case qsamplerDevice::Midi: if ((pParamInfo = ::lscp_get_midi_port_param_info( - m_device.client(), m_device.deviceID(), + pMainForm->client(), m_device.deviceID(), m_iPortID, sParam.latin1())) == NULL) m_device.appendMessagesClient("lscp_get_midi_port_param_info"); break; @@ -761,6 +797,12 @@ bool qsamplerDevicePort::setParam ( const QString& sParam, const QString& sValue ) { + MainForm *pMainForm = MainForm::getInstance(); + if (pMainForm == NULL) + return false; + if (pMainForm->client() == NULL) + return false; + // Set proper port/channel parameter. m_params[sParam.upper()].value = sValue; @@ -775,12 +817,12 @@ lscp_status_t ret = LSCP_FAILED; switch (m_device.deviceType()) { case qsamplerDevice::Audio: - if ((ret = ::lscp_set_audio_channel_param(m_device.client(), + if ((ret = ::lscp_set_audio_channel_param(pMainForm->client(), m_device.deviceID(), m_iPortID, ¶m)) != LSCP_OK) m_device.appendMessagesClient("lscp_set_audio_channel_param"); break; case qsamplerDevice::Midi: - if ((ret = ::lscp_set_midi_port_param(m_device.client(), + if ((ret = ::lscp_set_midi_port_param(pMainForm->client(), m_device.deviceID(), m_iPortID, ¶m)) != LSCP_OK) m_device.appendMessagesClient("lscp_set_midi_port_param"); break; @@ -805,249 +847,279 @@ //------------------------------------------------------------------------- -// qsamplerDeviceItem - QListView device item. +// qsamplerDeviceItem - QTreeWidget device item. // // Constructors. -qsamplerDeviceItem::qsamplerDeviceItem ( QListView *pListView, - qsamplerMainForm *pMainForm, qsamplerDevice::qsamplerDeviceType deviceType ) - : QListViewItem(pListView), m_device(pMainForm, deviceType) +qsamplerDeviceItem::qsamplerDeviceItem ( QTreeWidget* pTreeWidget, + qsamplerDevice::qsamplerDeviceType deviceType ) + : QTreeWidgetItem(pTreeWidget, QSAMPLER_DEVICE_ITEM), + m_device(deviceType) { switch(m_device.deviceType()) { case qsamplerDevice::Audio: - QListViewItem::setPixmap(0, QPixmap::fromMimeSource("audio1.png")); - QListViewItem::setText(0, QObject::tr("Audio Devices")); + setIcon(0, QPixmap(":/icons/audio1.png")); + setText(0, QObject::tr("Audio Devices")); break; case qsamplerDevice::Midi: - QListViewItem::setPixmap(0, QPixmap::fromMimeSource("midi1.png")); - QListViewItem::setText(0, QObject::tr("MIDI Devices")); + setIcon(0, QPixmap(":/icons/midi1.png")); + setText(0, QObject::tr("MIDI Devices")); break; case qsamplerDevice::None: break; } } -qsamplerDeviceItem::qsamplerDeviceItem ( QListViewItem *pItem, - qsamplerMainForm *pMainForm, qsamplerDevice::qsamplerDeviceType deviceType, +qsamplerDeviceItem::qsamplerDeviceItem ( QTreeWidgetItem* pItem, + qsamplerDevice::qsamplerDeviceType deviceType, int iDeviceID ) - : QListViewItem(pItem), m_device(pMainForm, deviceType, iDeviceID) + : QTreeWidgetItem(pItem, QSAMPLER_DEVICE_ITEM), + m_device(deviceType, iDeviceID) { switch(m_device.deviceType()) { case qsamplerDevice::Audio: - QListViewItem::setPixmap(0, QPixmap::fromMimeSource("audio2.png")); + setIcon(0, QPixmap(":/icons/audio2.png")); break; case qsamplerDevice::Midi: - QListViewItem::setPixmap(0, QPixmap::fromMimeSource("midi2.png")); + setIcon(0, QPixmap(":/icons/midi2.png")); break; case qsamplerDevice::None: break; } - QListViewItem::setText(0, m_device.deviceName()); + setText(0, m_device.deviceName()); } // Default destructor. -qsamplerDeviceItem::~qsamplerDeviceItem (void) +qsamplerDeviceItem::~qsamplerDeviceItem () { } // Instance accessors. -qsamplerDevice& qsamplerDeviceItem::device (void) +qsamplerDevice& qsamplerDeviceItem::device () { return m_device; } -// To virtually distinguish between list view items. -int qsamplerDeviceItem::rtti() const -{ - return QSAMPLER_DEVICE_ITEM; -} - - //------------------------------------------------------------------------- -// qsamplerDeviceParamTable - Device parameter view table. +// AbstractDeviceParamModel - data model base class for device parameters // -// Constructor. -qsamplerDeviceParamTable::qsamplerDeviceParamTable ( QWidget *pParent, - const char *pszName ) - : QTable(pParent, pszName) -{ - // Set fixed number of columns. - QTable::setNumCols(3); - QTable::setShowGrid(false); - QTable::setSorting(false); - QTable::setFocusStyle(QTable::FollowStyle); - QTable::setSelectionMode(QTable::NoSelection); - // No vertical header. - QTable::verticalHeader()->hide(); - QTable::setLeftMargin(0); - // Initialize the fixed table column headings. - QHeader *pHeader = QTable::horizontalHeader(); - 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); -// QTable::setColumnReadOnly(2, false); -- of course not. - QTable::setColumnStretchable(1, true); +AbstractDeviceParamModel::AbstractDeviceParamModel(QObject* parent) : QAbstractTableModel(parent), bEditable(false) { + params = NULL; } -// Default destructor. -qsamplerDeviceParamTable::~qsamplerDeviceParamTable (void) -{ +int AbstractDeviceParamModel::rowCount(const QModelIndex& /*parent*/) const { + //std::cout << "model size=" << params.size() << "\n" << std::flush; + return (params) ? params->size() : 0; } +int AbstractDeviceParamModel::columnCount(const QModelIndex& /*parent*/) const { + return 3; +} -// Common parameter table renderer. -void qsamplerDeviceParamTable::refresh ( const qsamplerDeviceParamMap& params, - bool bEditable ) -{ - // Always (re)start it empty. - QTable::setUpdatesEnabled(false); - QTable::setNumRows(0); +Qt::ItemFlags AbstractDeviceParamModel::flags(const QModelIndex& /*index*/) const { + return Qt::ItemIsSelectable | Qt::ItemIsEditable | Qt::ItemIsEnabled; +} - // Fill the parameter table... - QTable::insertRows(0, params.count()); - int iRow = 0; - qsamplerDeviceParamMap::ConstIterator iter; - for (iter = params.begin(); iter != params.end(); ++iter) { - const qsamplerDeviceParam& param = iter.data(); - bool bEnabled = (bEditable || !param.fix); - QTable::setText(iRow, 0, iter.key()); - QTable::setText(iRow, 1, param.description); - if (param.type == LSCP_TYPE_BOOL) { - 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(bEnabled); - QTable::setItem(iRow, 2, pComboItem); - } else if (param.possibilities.count() > 0 && bEnabled) { - QStringList opts = param.possibilities; - if (param.multiplicity) - opts.prepend(tr("(none)")); - QComboTableItem *pComboItem = new QComboTableItem(this, opts); - if (param.value.isEmpty()) - pComboItem->setCurrentItem(0); - else - pComboItem->setCurrentItem(param.value); - pComboItem->setEnabled(bEnabled); - 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 { - qsamplerDeviceParamTableEditBox *pEditItem = - new qsamplerDeviceParamTableEditBox(this, - bEnabled ? QTableItem::OnTyping : QTableItem::Never, - param.value); - QTable::setItem(iRow, 2, pEditItem); - } - ++iRow; - } +QVariant AbstractDeviceParamModel::data(const QModelIndex &index, int role) const { + if (!index.isValid()) { + //std::cout << "inavlid device model index\n" << std::flush; + return QVariant(); + } + if (role != Qt::DisplayRole) { + //std::cout << "inavlid display role\n" << std::flush; + return QVariant(); + } - // Adjust optimal column widths. - QTable::adjustColumn(0); - QTable::adjustColumn(2); + DeviceParameterRow item; + item.name = params->keys()[index.row()]; + item.param = (*params)[item.name]; - QTable::setUpdatesEnabled(true); - QTable::updateContents(); + //std::cout << "item["<params = params; + this->bEditable = bEditable; + // inform the outer world (QTableView) that our data changed + QAbstractTableModel::reset(); +} + +void AbstractDeviceParamModel::clear() { + params = NULL; + // inform the outer world (QTableView) that our data changed + QAbstractTableModel::reset(); } //------------------------------------------------------------------------- -// qsamplerDeviceParamTableSpinBox - Custom spin box for parameter table. +// DeviceParamModel - data model for device parameters (used for QTableView) // -// Constructor. -qsamplerDeviceParamTableSpinBox::qsamplerDeviceParamTableSpinBox ( - QTable *pTable, EditType editType, const QString& sText ) - : QTableItem(pTable, editType, sText) -{ - m_iValue = sText.toInt(); - m_iMinValue = m_iMaxValue = 0; +DeviceParamModel::DeviceParamModel(QObject* parent) : AbstractDeviceParamModel(parent) { + device = NULL; } -// Public accessors. -void qsamplerDeviceParamTableSpinBox::setValue ( int iValue ) -{ - m_iValue = iValue; - QTableItem::setText(QString::number(m_iValue)); +bool DeviceParamModel::setData(const QModelIndex& index, const QVariant& value, int /*role*/) { + if (!index.isValid()) { + return false; + } + QString key = params->keys()[index.row()]; + //params[key].value = value.toString(); + device->setParam(key, value.toString()); + emit dataChanged(index, index); + return true; } -void qsamplerDeviceParamTableSpinBox::setMinValue ( int iMinValue ) -{ - m_iMinValue = iMinValue; +void DeviceParamModel::refresh(qsamplerDevice* pDevice, bool bEditable) { + device = pDevice; + AbstractDeviceParamModel::refresh(&pDevice->params(), bEditable); } -void qsamplerDeviceParamTableSpinBox::setMaxValue ( int iMaxValue ) -{ - m_iMaxValue = iMaxValue; +void DeviceParamModel::clear() { + AbstractDeviceParamModel::clear(); + device = NULL; } -// 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; + +//------------------------------------------------------------------------- +// PortParamModel - data model for port parameters (used for QTableView) +// + +PortParamModel::PortParamModel(QObject* parent) : AbstractDeviceParamModel(parent) { + port = NULL; } -void qsamplerDeviceParamTableSpinBox::setContentFromEditor ( QWidget *pWidget ) -{ - if (pWidget->inherits("QSpinBox")) - QTableItem::setText(QString::number(((QSpinBox *) pWidget)->value())); - else - QTableItem::setContentFromEditor(pWidget); +bool PortParamModel::setData(const QModelIndex& index, const QVariant& value, int /*role*/) { + if (!index.isValid()) { + return false; + } + QString key = params->keys()[index.row()]; + //params[key].value = value.toString(); + port->setParam(key, value.toString()); + emit dataChanged(index, index); + return true; +} + +void PortParamModel::refresh(qsamplerDevicePort* pPort, bool bEditable) { + port = pPort; + AbstractDeviceParamModel::refresh(&pPort->params(), bEditable); +} + +void PortParamModel::clear() { + AbstractDeviceParamModel::clear(); + port = NULL; } //------------------------------------------------------------------------- -// qsamplerDeviceParamTableEditBox - Custom edit box for parameter table. +// DeviceParamDelegate - table cell renderer for device/port parameters // -// Constructor. -qsamplerDeviceParamTableEditBox::qsamplerDeviceParamTableEditBox ( - QTable *pTable, EditType editType, const QString& sText ) - : QTableItem(pTable, editType, sText) -{ +DeviceParamDelegate::DeviceParamDelegate(QObject *parent) : QItemDelegate(parent) { } -// 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; +QWidget* DeviceParamDelegate::createEditor(QWidget *parent, + const QStyleOptionViewItem &/* option */, + const QModelIndex& index) const +{ + if (!index.isValid()) { + return NULL; + } + + DeviceParameterRow r = index.model()->data(index, Qt::DisplayRole).value(); + + const bool bEnabled = (/*index.model()->bEditable ||*/ !r.param.fix); + + switch (index.column()) { + case 0: + return new QLabel(r.name, parent); + case 1: { + if (r.param.type == LSCP_TYPE_BOOL) { + QCheckBox* pCheckBox = new QCheckBox(parent); + pCheckBox->setChecked(r.param.value.lower() == "true"); + pCheckBox->setEnabled(bEnabled); + return pCheckBox; + } else if (r.param.possibilities.count() > 0) { + QStringList opts = r.param.possibilities; + if (r.param.multiplicity) + opts.prepend(tr("(none)")); + QComboBox* pComboBox = new QComboBox(parent); + pComboBox->addItems(opts); + if (r.param.value.isEmpty()) + pComboBox->setCurrentIndex(0); + else + pComboBox->setCurrentIndex(pComboBox->findText(r.param.value)); + pComboBox->setEnabled(bEnabled); + return pComboBox; + } else if (r.param.type == LSCP_TYPE_INT + && !r.param.range_min.isEmpty() + && !r.param.range_max.isEmpty()) { + QSpinBox* pSpinBox = new QSpinBox(parent); + pSpinBox->setValue(r.param.value.toInt()); + pSpinBox->setMinimum(r.param.range_min.toInt()); + pSpinBox->setMaximum(r.param.range_max.toInt()); + pSpinBox->setEnabled(bEnabled); + return pSpinBox; + } else { + QLineEdit* pLineEdit = new QLineEdit(r.param.value, parent); + pLineEdit->setEnabled(bEnabled); + return pLineEdit; + } + } + case 2: + return new QLabel(r.param.description, parent); + default: + return NULL; + } +} + +void DeviceParamDelegate::setEditorData(QWidget* /*editor*/, const QModelIndex& /*index*/) const { + // unused, since we set the editor data already in createEditor() +} + +void DeviceParamDelegate::setModelData(QWidget* editor, QAbstractItemModel* model, const QModelIndex& index) const { + if (index.column() == 1) { + DeviceParameterRow r = index.model()->data(index, Qt::DisplayRole).value(); + if (r.param.type == LSCP_TYPE_BOOL) { + QCheckBox* pCheckBox = static_cast(editor); + model->setData(index, QVariant(pCheckBox->checkState() == Qt::Checked)); + } else if (r.param.possibilities.count() > 0) { + QComboBox* pComboBox = static_cast(editor); + model->setData(index, pComboBox->currentText()); + } else if (r.param.type == LSCP_TYPE_INT) { + QSpinBox* pSpinBox = static_cast(editor); + model->setData(index, pSpinBox->value()); + } else { + QLineEdit* pLineEdit = static_cast(editor); + model->setData(index, pLineEdit->text()); + } + } } -void qsamplerDeviceParamTableEditBox::setContentFromEditor ( QWidget *pWidget ) +void DeviceParamDelegate::updateEditorGeometry(QWidget* editor, + const QStyleOptionViewItem &option, const QModelIndex &/* index */) const { - if (pWidget->inherits("QLineEdit")) - QTableItem::setText(((QLineEdit *) pWidget)->text()); - else - QTableItem::setContentFromEditor(pWidget); + if (editor) editor->setGeometry(option.rect); } - // end of qsamplerDevice.cpp -