1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-10-26 02:20:26 -04:00

Implemented multiple sample sources for one preset

This commit is contained in:
Edouard Griffiths 2015-10-01 16:57:33 +02:00
parent c85813b577
commit fa79c55f41
6 changed files with 241 additions and 44 deletions

View File

@ -103,7 +103,7 @@ private:
PluginManager* m_pluginManager; PluginManager* m_pluginManager;
void loadSettings(); void loadSettings();
void loadPresetSettings(const Preset* preset); void loadPresetSettings(Preset* preset);
void savePresetSettings(Preset* preset); void savePresetSettings(Preset* preset);
void saveSettings(); void saveSettings();

View File

@ -47,7 +47,7 @@ public:
void registerSampleSource(const QString& sourceName, PluginInterface* plugin); void registerSampleSource(const QString& sourceName, PluginInterface* plugin);
void loadSettings(const Preset* preset); void loadSettings(Preset* preset);
void saveSettings(Preset* preset); void saveSettings(Preset* preset);
void freeAll(); void freeAll();
@ -58,6 +58,7 @@ public:
void fillSampleSourceSelector(QComboBox* comboBox); void fillSampleSourceSelector(QComboBox* comboBox);
int selectSampleSource(int index); int selectSampleSource(int index);
int selectFirstSampleSource(const QString& sourceId); int selectFirstSampleSource(const QString& sourceId);
int selectSampleSourceBySerialOrSequence(const QString& sourceId, const QString& sourceSerial, int sourceSequence);
private: private:
struct ChannelRegistration { struct ChannelRegistration {

View File

@ -61,6 +61,7 @@ public:
int getChannelCount() const { return m_channelConfigs.count(); } int getChannelCount() const { return m_channelConfigs.count(); }
const ChannelConfig& getChannelConfig(int index) const { return m_channelConfigs.at(index); } const ChannelConfig& getChannelConfig(int index) const { return m_channelConfigs.at(index); }
/*
void setSourceConfig(const QString& sourceId, const QString& sourceSerial, int sourceSequence, const QByteArray& config) void setSourceConfig(const QString& sourceId, const QString& sourceSerial, int sourceSequence, const QByteArray& config)
{ {
m_sourceId = sourceId; m_sourceId = sourceId;
@ -72,7 +73,7 @@ public:
const QString& getSourceId() const { return m_sourceId; } const QString& getSourceId() const { return m_sourceId; }
const QString& getSourceSerial() const { return m_sourceSerial; } const QString& getSourceSerial() const { return m_sourceSerial; }
const int getSourceSequence() const { return m_sourceSequence; } const int getSourceSequence() const { return m_sourceSequence; }
const QByteArray& getSourceConfig() const { return m_sourceConfig; } const QByteArray& getSourceConfig() const { return m_sourceConfig; }*/
void addOrUpdateSourceConfig(const QString& sourceId, void addOrUpdateSourceConfig(const QString& sourceId,
const QString& sourceSerial, const QString& sourceSerial,
@ -83,6 +84,8 @@ public:
const QString& sourceSerial, const QString& sourceSerial,
int sourceSequence); int sourceSequence);
const QByteArray* findCurrentSourceConfig(QString& sourceId, QString& sourceSerial, int& sourceSequence) const;
protected: protected:
// group and preset description // group and preset description
QString m_group; QString m_group;
@ -107,6 +110,7 @@ protected:
// sources and configurations // sources and configurations
SourceConfigs m_sourceConfigs; SourceConfigs m_sourceConfigs;
SourceConfigs::const_iterator m_currentSourceConfig;
// screen and dock layout // screen and dock layout
QByteArray m_layout; QByteArray m_layout;

View File

@ -115,7 +115,19 @@ MainWindow::MainWindow(QWidget* parent) :
qDebug() << "MainWindow::MainWindow: select SampleSource from settings..."; qDebug() << "MainWindow::MainWindow: select SampleSource from settings...";
int sampleSourceIndex = m_pluginManager->selectFirstSampleSource(m_settings.getCurrent()->getSourceId()); // select SampleSource from settings Preset *currentPreset = m_settings.getCurrent();
if (currentPreset != 0)
{
QString sourceId, sourceSerial;
int sourceSequence;
const QByteArray *sourceConfig;
sourceConfig = currentPreset->findCurrentSourceConfig(sourceId, sourceSerial, sourceSequence);
if (sourceConfig != 0)
{
int sampleSourceIndex = m_pluginManager->selectSampleSourceBySerialOrSequence(sourceId, sourceSerial, sourceSequence); // select SampleSource from settings
if(sampleSourceIndex >= 0) if(sampleSourceIndex >= 0)
{ {
@ -123,6 +135,8 @@ MainWindow::MainWindow(QWidget* parent) :
ui->sampleSource->setCurrentIndex(sampleSourceIndex); ui->sampleSource->setCurrentIndex(sampleSourceIndex);
ui->sampleSource->blockSignals(sampleSourceSignalsBlocked); ui->sampleSource->blockSignals(sampleSourceSignalsBlocked);
} }
}
}
qDebug() << "MainWindow::MainWindow: load current preset settings..."; qDebug() << "MainWindow::MainWindow: load current preset settings...";
@ -206,9 +220,12 @@ void MainWindow::loadSettings()
} }
} }
void MainWindow::loadPresetSettings(const Preset* preset) void MainWindow::loadPresetSettings(Preset* preset)
{ {
qDebug() << "MainWindow::loadPresetSettings: preset: " << preset->getSourceId().toStdString().c_str(); qDebug("MainWindow::loadPresetSettings: group: %s desc: %s Fcenter: %llu Hz",
qPrintable(preset->getGroup()),
qPrintable(preset->getDescription()),
preset->getCenterFrequency());
ui->glSpectrumGUI->deserialize(preset->getSpectrumConfig()); ui->glSpectrumGUI->deserialize(preset->getSpectrumConfig());
@ -229,7 +246,10 @@ void MainWindow::saveSettings()
void MainWindow::savePresetSettings(Preset* preset) void MainWindow::savePresetSettings(Preset* preset)
{ {
qDebug() << "MainWindow::savePresetSettings: preset: " << preset->getSourceId().toStdString().c_str(); qDebug("MainWindow::savePresetSettings: group: %s desc: %s Fcenter: %llu Hz",
qPrintable(preset->getGroup()),
qPrintable(preset->getDescription()),
preset->getCenterFrequency());
preset->setSpectrumConfig(ui->glSpectrumGUI->serialize()); preset->setSpectrumConfig(ui->glSpectrumGUI->serialize());
preset->clearChannels(); preset->clearChannels();
@ -497,7 +517,7 @@ void MainWindow::on_presetLoad_clicked()
return; return;
} }
const Preset* preset = qvariant_cast<const Preset*>(item->data(0, Qt::UserRole)); Preset* preset = qvariant_cast<Preset*>(item->data(0, Qt::UserRole));
if(preset == 0) if(preset == 0)
{ {

View File

@ -83,7 +83,7 @@ void PluginManager::registerSampleSource(const QString& sourceName, PluginInterf
m_sampleSourceRegistrations.append(SampleSourceRegistration(sourceName, plugin)); m_sampleSourceRegistrations.append(SampleSourceRegistration(sourceName, plugin));
} }
void PluginManager::loadSettings(const Preset* preset) void PluginManager::loadSettings(Preset* preset)
{ {
fprintf(stderr, "PluginManager::loadSettings: Loading preset [%s | %s]\n", qPrintable(preset->getGroup()), qPrintable(preset->getDescription())); fprintf(stderr, "PluginManager::loadSettings: Loading preset [%s | %s]\n", qPrintable(preset->getGroup()), qPrintable(preset->getDescription()));
@ -144,6 +144,14 @@ void PluginManager::loadSettings(const Preset* preset)
if(m_sampleSourcePluginGUI != 0) if(m_sampleSourcePluginGUI != 0)
{ {
const QByteArray* sourceConfig = preset->findBestSourceConfig(m_sampleSourceId, m_sampleSourceSerial, m_sampleSourceSequence);
if (sourceConfig != 0)
{
qDebug() << "PluginManager::loadSettings: deserializing source " << qPrintable(m_sampleSourceId);
m_sampleSourcePluginGUI->deserialize(*sourceConfig);
}
/*
qDebug("PluginManager::loadSettings: source compare [%s] vs [%s]", qPrintable(m_sampleSourceId), qPrintable(preset->getSourceId())); qDebug("PluginManager::loadSettings: source compare [%s] vs [%s]", qPrintable(m_sampleSourceId), qPrintable(preset->getSourceId()));
// TODO: have one set of source presets per identified source (preset -> find source with name) // TODO: have one set of source presets per identified source (preset -> find source with name)
@ -151,9 +159,8 @@ void PluginManager::loadSettings(const Preset* preset)
{ {
qDebug() << "PluginManager::loadSettings: deserializing source " << qPrintable(m_sampleSourceId); qDebug() << "PluginManager::loadSettings: deserializing source " << qPrintable(m_sampleSourceId);
m_sampleSourcePluginGUI->deserialize(preset->getSourceConfig()); m_sampleSourcePluginGUI->deserialize(preset->getSourceConfig());
} }*/
// FIXME: get center frequency from preset center frequency
qint64 centerFrequency = preset->getCenterFrequency(); qint64 centerFrequency = preset->getCenterFrequency();
m_sampleSourcePluginGUI->setCenterFrequency(centerFrequency); m_sampleSourcePluginGUI->setCenterFrequency(centerFrequency);
} }
@ -176,13 +183,15 @@ void PluginManager::saveSettings(Preset* preset)
{ {
if(m_sampleSourcePluginGUI != NULL) if(m_sampleSourcePluginGUI != NULL)
{ {
preset->setSourceConfig(m_sampleSourceId, m_sampleSourceSerial, m_sampleSourceSequence, m_sampleSourcePluginGUI->serialize()); preset->addOrUpdateSourceConfig(m_sampleSourceId, m_sampleSourceSerial, m_sampleSourceSequence, m_sampleSourcePluginGUI->serialize());
//preset->setSourceConfig(m_sampleSourceId, m_sampleSourceSerial, m_sampleSourceSequence, m_sampleSourcePluginGUI->serialize());
preset->setCenterFrequency(m_sampleSourcePluginGUI->getCenterFrequency()); preset->setCenterFrequency(m_sampleSourcePluginGUI->getCenterFrequency());
} }
/*
else else
{ {
preset->setSourceConfig(QString::null, QString::null, 0, QByteArray()); preset->setSourceConfig(QString::null, QString::null, 0, QByteArray());
} }*/
qSort(m_channelInstanceRegistrations.begin(), m_channelInstanceRegistrations.end()); // sort by increasing delta frequency and type qSort(m_channelInstanceRegistrations.begin(), m_channelInstanceRegistrations.end()); // sort by increasing delta frequency and type
@ -264,7 +273,7 @@ void PluginManager::fillSampleSourceSelector(QComboBox* comboBox)
int PluginManager::selectSampleSource(int index) int PluginManager::selectSampleSource(int index)
{ {
qDebug() << "PluginManager::selectSampleSource by index"; qDebug("PluginManager::selectSampleSource by index: index: %d", index);
m_dspEngine->stopAcquistion(); m_dspEngine->stopAcquistion();
@ -296,19 +305,18 @@ int PluginManager::selectSampleSource(int index)
{ {
index = 0; index = 0;
} }
} else
}
if(index == -1)
{ {
return -1; return -1;
} }
}
}
m_sampleSourceId = m_sampleSourceDevices[index].m_sourceId; m_sampleSourceId = m_sampleSourceDevices[index].m_sourceId;
m_sampleSourceSerial = m_sampleSourceDevices[index].m_sourceSerial; m_sampleSourceSerial = m_sampleSourceDevices[index].m_sourceSerial;
m_sampleSourceSequence = m_sampleSourceDevices[index].m_sourceSequence; m_sampleSourceSequence = m_sampleSourceDevices[index].m_sourceSequence;
qDebug() << "m_sampleSource at index " << index qDebug() << "PluginManager::selectSampleSource by index: m_sampleSource at index " << index
<< " id: " << m_sampleSourceId.toStdString().c_str() << " id: " << m_sampleSourceId.toStdString().c_str()
<< " ser: " << m_sampleSourceSerial.toStdString().c_str() << " ser: " << m_sampleSourceSerial.toStdString().c_str()
<< " seq: " << m_sampleSourceSequence; << " seq: " << m_sampleSourceSequence;
@ -320,7 +328,7 @@ int PluginManager::selectSampleSource(int index)
int PluginManager::selectFirstSampleSource(const QString& sourceId) int PluginManager::selectFirstSampleSource(const QString& sourceId)
{ {
qDebug() << "PluginManager::selectFirstSampleSource by id: " << sourceId.toStdString().c_str(); qDebug("PluginManager::selectFirstSampleSource by id: [%s]", qPrintable(sourceId));
int index = -1; int index = -1;
@ -334,8 +342,6 @@ int PluginManager::selectFirstSampleSource(const QString& sourceId)
m_sampleSourceId.clear(); m_sampleSourceId.clear();
} }
qDebug("finding first sample source [%s]", qPrintable(sourceId));
for (int i = 0; i < m_sampleSourceDevices.count(); i++) for (int i = 0; i < m_sampleSourceDevices.count(); i++)
{ {
qDebug("*** %s vs %s", qPrintable(m_sampleSourceDevices[i].m_sourceId), qPrintable(sourceId)); qDebug("*** %s vs %s", qPrintable(m_sampleSourceDevices[i].m_sourceId), qPrintable(sourceId));
@ -353,12 +359,11 @@ int PluginManager::selectFirstSampleSource(const QString& sourceId)
{ {
index = 0; index = 0;
} }
} else
if(index == -1)
{ {
return -1; return -1;
} }
}
m_sampleSourceId = m_sampleSourceDevices[index].m_sourceId; m_sampleSourceId = m_sampleSourceDevices[index].m_sourceId;
m_sampleSourceSerial = m_sampleSourceDevices[index].m_sourceSerial; m_sampleSourceSerial = m_sampleSourceDevices[index].m_sourceSerial;
@ -374,6 +379,73 @@ int PluginManager::selectFirstSampleSource(const QString& sourceId)
return index; return index;
} }
int PluginManager::selectSampleSourceBySerialOrSequence(const QString& sourceId, const QString& sourceSerial, int sourceSequence)
{
qDebug("PluginManager::selectSampleSourceBySequence by sequence: id: %s ser: %s seq: %d", qPrintable(sourceId), qPrintable(sourceSerial), sourceSequence);
int index = -1;
int index_matchingSequence = -1;
int index_firstOfKind = -1;
for (int i = 0; i < m_sampleSourceDevices.count(); i++)
{
if (m_sampleSourceDevices[i].m_sourceId == sourceId)
{
index_firstOfKind = i;
if (m_sampleSourceDevices[i].m_sourceSerial == sourceSerial)
{
index = i; // exact match
break;
}
if (m_sampleSourceDevices[i].m_sourceSequence == sourceSequence)
{
index_matchingSequence = i;
}
}
}
if(index == -1) // no exact match
{
if (index_matchingSequence == -1) // no matching sequence
{
if (index_firstOfKind == -1) // no matching device type
{
if(m_sampleSourceDevices.count() > 0) // take first if any
{
index = 0;
}
else
{
return -1; // return if no device attached
}
}
else
{
index = index_firstOfKind; // take first that matches device type
}
}
else
{
index = index_matchingSequence; // take the one that matches the sequence in the device type
}
}
m_sampleSourceId = m_sampleSourceDevices[index].m_sourceId;
m_sampleSourceSerial = m_sampleSourceDevices[index].m_sourceSerial;
m_sampleSourceSequence = m_sampleSourceDevices[index].m_sourceSequence;
qDebug() << "PluginManager::selectSampleSourceBySequence by sequence: m_sampleSource at index " << index
<< " id: " << qPrintable(m_sampleSourceId)
<< " ser: " << qPrintable(m_sampleSourceSerial)
<< " seq: " << m_sampleSourceSequence;
m_sampleSourcePluginGUI = m_sampleSourceDevices[index].m_plugin->createSampleSourcePluginGUI(m_sampleSourceId);
return index;
}
void PluginManager::loadPlugins(const QDir& dir) void PluginManager::loadPlugins(const QDir& dir)
{ {
QDir pluginsDir(dir); QDir pluginsDir(dir);

View File

@ -19,26 +19,56 @@ void Preset::resetToDefaults()
m_channelConfigs.clear(); m_channelConfigs.clear();
m_sourceId.clear(); m_sourceId.clear();
m_sourceConfig.clear(); m_sourceConfig.clear();
m_currentSourceConfig = m_sourceConfigs.end();
} }
QByteArray Preset::serialize() const QByteArray Preset::serialize() const
{ {
qDebug() << "Preset::serialize (" << this->getSourceId().toStdString().c_str() << ")"; qDebug("Preset::serialize: m_group: %s m_description: %s m_centerFrequency: %llu",
qPrintable(m_group),
qPrintable(m_description),
m_centerFrequency);
SimpleSerializer s(1); SimpleSerializer s(1);
s.writeString(1, m_group); s.writeString(1, m_group);
s.writeString(2, m_description); s.writeString(2, m_description);
s.writeU64(3, m_centerFrequency); s.writeU64(3, m_centerFrequency);
s.writeBlob(4, m_layout); s.writeBlob(4, m_layout);
s.writeBlob(5, m_spectrumConfig); s.writeBlob(5, m_spectrumConfig);
s.writeString(6, m_sourceId);
s.writeBlob(7, m_sourceConfig); s.writeS32(20, m_sourceConfigs.size());
if ( m_currentSourceConfig == m_sourceConfigs.end())
{
s.writeBool(21, false); // no current source available
s.writeString(22, "");
s.writeS32(23, 0);
}
else
{
s.writeBool(21, true); // current source available
s.writeString(22, m_currentSourceConfig->m_sourceId);
s.writeS32(23, m_currentSourceConfig->m_sourceSequence);
}
for (int i = 0; i < m_sourceConfigs.size(); i++)
{
s.writeString(24 + i*4, m_sourceConfigs[i].m_sourceId);
s.writeString(25 + i*4, m_sourceConfigs[i].m_sourceSerial);
s.writeS32(26 + i*4, m_sourceConfigs[i].m_sourceSequence);
s.writeBlob(27 + i*4, m_sourceConfigs[i].m_config);
if (i >= (200-23)/4) // full!
{
break;
}
}
s.writeS32(200, m_channelConfigs.size()); s.writeS32(200, m_channelConfigs.size());
qDebug() << " m_group: " << m_group.toStdString().c_str(); for(int i = 0; i < m_channelConfigs.size(); i++)
{
for(int i = 0; i < m_channelConfigs.size(); i++) {
s.writeString(201 + i * 2, m_channelConfigs[i].m_channel); s.writeString(201 + i * 2, m_channelConfigs[i].m_channel);
s.writeBlob(202 + i * 2, m_channelConfigs[i].m_config); s.writeBlob(202 + i * 2, m_channelConfigs[i].m_config);
} }
@ -48,7 +78,6 @@ QByteArray Preset::serialize() const
bool Preset::deserialize(const QByteArray& data) bool Preset::deserialize(const QByteArray& data)
{ {
qDebug() << "Preset::deserialize (" << this->getSourceId().toStdString().c_str() << ")";
SimpleDeserializer d(data); SimpleDeserializer d(data);
if(!d.isValid()) { if(!d.isValid()) {
@ -65,20 +94,66 @@ bool Preset::deserialize(const QByteArray& data)
d.readString(6, &m_sourceId); d.readString(6, &m_sourceId);
d.readBlob(7, &m_sourceConfig); d.readBlob(7, &m_sourceConfig);
qDebug() << "Preset::deserialize: m_group: " << m_group.toStdString().c_str(); qDebug("Preset::deserialize: m_group: %s m_description: %s m_centerFrequency: %llu",
qPrintable(m_group),
qPrintable(m_description),
m_centerFrequency);
qint32 sourcesCount = 0;
d.readS32(20, &sourcesCount, 0);
if (sourcesCount >= (200-20)/4) // limit was hit!
{
sourcesCount = ((200-20)/4) - 1;
}
bool hasCurrentConfig;
QString currentSourceId;
int currentSourceSequence;
m_currentSourceConfig = m_sourceConfigs.end();
d.readBool(21, &hasCurrentConfig, false);
d.readString(22, &currentSourceId, QString::null);
d.readS32(23, &currentSourceSequence);
for(int i = 0; i < sourcesCount; i++)
{
QString sourceId, sourceSerial;
int sourceSequence;
QByteArray sourceConfig;
d.readString(21 + i*4, &sourceId, "");
d.readString(22 + i*4, &sourceSerial, "");
d.readS32(23 + i*4, &sourceSequence, 0);
d.readBlob(24 + i*4, &sourceConfig);
m_sourceConfigs.append(SourceConfig(sourceId, sourceSerial, sourceSequence, sourceConfig));
if (hasCurrentConfig && (sourceId == currentSourceId) && (sourceSequence == currentSourceSequence))
{
m_currentSourceConfig = m_sourceConfigs.end();
m_currentSourceConfig--;
}
}
qint32 channelCount = 0; qint32 channelCount = 0;
d.readS32(200, &channelCount, 0); d.readS32(200, &channelCount, 0);
for(int i = 0; i < channelCount; i++) { for(int i = 0; i < channelCount; i++)
{
QString channel; QString channel;
QByteArray config; QByteArray config;
d.readString(201 + i * 2, &channel, "unknown-channel"); d.readString(201 + i * 2, &channel, "unknown-channel");
d.readBlob(202 + i * 2, &config); d.readBlob(202 + i * 2, &config);
m_channelConfigs.append(ChannelConfig(channel, config)); m_channelConfigs.append(ChannelConfig(channel, config));
} }
return true; return true;
} else { }
else
{
resetToDefaults(); resetToDefaults();
return false; return false;
} }
@ -114,11 +189,14 @@ void Preset::addOrUpdateSourceConfig(const QString& sourceId,
if (it == m_sourceConfigs.end()) if (it == m_sourceConfigs.end())
{ {
m_sourceConfigs.push_back(SourceConfig(sourceId, sourceSerial, sourceSequence, config)); m_sourceConfigs.append(SourceConfig(sourceId, sourceSerial, sourceSequence, config));
m_currentSourceConfig = m_sourceConfigs.end();
--m_currentSourceConfig;
} }
else else
{ {
it->m_config = config; it->m_config = config;
m_currentSourceConfig = it;
} }
} }
@ -164,20 +242,42 @@ const QByteArray* Preset::findBestSourceConfig(const QString& sourceId,
{ {
if (itMatchSequence != m_sourceConfigs.end()) // match sequence ? if (itMatchSequence != m_sourceConfigs.end()) // match sequence ?
{ {
qDebug("Preset::findBestSourceConfig: sequence matched: id: %s seq: %d", qPrintable(it->m_sourceId), it->m_sourceSequence);
m_currentSourceConfig = itMatchSequence;
return &(itMatchSequence->m_config); return &(itMatchSequence->m_config);
} }
else if (itFirstOfKind != m_sourceConfigs.end()) // match source type ? else if (itFirstOfKind != m_sourceConfigs.end()) // match source type ?
{ {
qDebug("Preset::findBestSourceConfig: first of kind matched: id: %s", qPrintable(it->m_sourceId));
m_currentSourceConfig = itFirstOfKind;
return &(itFirstOfKind->m_config); return &(itFirstOfKind->m_config);
} }
else // definitely not found ! else // definitely not found !
{ {
qDebug("Preset::findBestSourceConfig: no match");
m_currentSourceConfig = m_sourceConfigs.end();
return 0; return 0;
} }
} }
else // exact match else // exact match
{ {
qDebug("Preset::findBestSourceConfig: serial matched (exact): id: %s ser: %d", qPrintable(it->m_sourceId), qPrintable(it->m_sourceSerial));
m_currentSourceConfig = it;
return &(it->m_config); return &(it->m_config);
} }
} }
const QByteArray* Preset::findCurrentSourceConfig(QString& sourceId, QString& sourceSerial, int& sourceSequence) const
{
if (m_currentSourceConfig == m_sourceConfigs.end())
{
return 0;
}
else
{
sourceId = m_currentSourceConfig->m_sourceId;
sourceSerial = m_currentSourceConfig->m_sourceSerial;
sourceSequence = m_currentSourceConfig->m_sourceSequence;
return &m_currentSourceConfig->m_config;
}
}