mirror of
https://github.com/f4exb/sdrangel.git
synced 2025-05-30 22:02:26 -04:00
Implemented coarse and fine trigger level sliders
This commit is contained in:
parent
6dea38ab47
commit
4b4a1c57f1
@ -49,7 +49,8 @@ private:
|
|||||||
int m_displayGridIntensity;
|
int m_displayGridIntensity;
|
||||||
int m_displayTraceIntensity;
|
int m_displayTraceIntensity;
|
||||||
qint32 m_triggerChannel;
|
qint32 m_triggerChannel;
|
||||||
qint32 m_triggerLevel; // percent
|
qint32 m_triggerLevelCoarse; // percent of full range
|
||||||
|
qint32 m_triggerLevelFine; // percent of coarse
|
||||||
bool m_triggerPositiveEdge;
|
bool m_triggerPositiveEdge;
|
||||||
bool m_triggerBothEdges;
|
bool m_triggerBothEdges;
|
||||||
qint32 m_triggerPre;
|
qint32 m_triggerPre;
|
||||||
@ -93,7 +94,8 @@ private slots:
|
|||||||
void on_slopeNeg_clicked();
|
void on_slopeNeg_clicked();
|
||||||
void on_slopeBoth_clicked();
|
void on_slopeBoth_clicked();
|
||||||
void on_oneShot_clicked();
|
void on_oneShot_clicked();
|
||||||
void on_trigLevel_valueChanged(int value);
|
void on_trigLevelCoarse_valueChanged(int value);
|
||||||
|
void on_trigLevelFine_valueChanged(int value);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // INCLUDE_GLSCOPEGUI_H
|
#endif // INCLUDE_GLSCOPEGUI_H
|
||||||
|
@ -26,7 +26,8 @@ GLScopeGUI::GLScopeGUI(QWidget* parent) :
|
|||||||
m_ampOffset(0),
|
m_ampOffset(0),
|
||||||
m_displayGridIntensity(1),
|
m_displayGridIntensity(1),
|
||||||
m_triggerChannel(ScopeVis::TriggerFreeRun),
|
m_triggerChannel(ScopeVis::TriggerFreeRun),
|
||||||
m_triggerLevel(0.0),
|
m_triggerLevelCoarse(0),
|
||||||
|
m_triggerLevelFine(0),
|
||||||
m_triggerPositiveEdge(true),
|
m_triggerPositiveEdge(true),
|
||||||
m_triggerBothEdges(false),
|
m_triggerBothEdges(false),
|
||||||
m_triggerPre(0),
|
m_triggerPre(0),
|
||||||
@ -65,7 +66,8 @@ void GLScopeGUI::resetToDefaults()
|
|||||||
m_amplification = 0;
|
m_amplification = 0;
|
||||||
m_displayGridIntensity = 5;
|
m_displayGridIntensity = 5;
|
||||||
m_triggerChannel = ScopeVis::TriggerFreeRun;
|
m_triggerChannel = ScopeVis::TriggerFreeRun;
|
||||||
m_triggerLevel = 0.0;
|
m_triggerLevelCoarse = 0;
|
||||||
|
m_triggerLevelFine = 0;
|
||||||
m_triggerPositiveEdge = true;
|
m_triggerPositiveEdge = true;
|
||||||
m_triggerPre = 0;
|
m_triggerPre = 0;
|
||||||
m_triggerDelay = 0;
|
m_triggerDelay = 0;
|
||||||
@ -86,13 +88,14 @@ QByteArray GLScopeGUI::serialize() const
|
|||||||
s.writeS32(7, m_ampOffset);
|
s.writeS32(7, m_ampOffset);
|
||||||
s.writeS32(8, m_displays);
|
s.writeS32(8, m_displays);
|
||||||
s.writeS32(9, m_triggerChannel);
|
s.writeS32(9, m_triggerChannel);
|
||||||
s.writeS32(10, m_triggerLevel);
|
s.writeS32(10, m_triggerLevelCoarse);
|
||||||
s.writeBool(11, m_triggerPositiveEdge);
|
s.writeBool(11, m_triggerPositiveEdge);
|
||||||
s.writeS32(12, m_displayTraceIntensity);
|
s.writeS32(12, m_displayTraceIntensity);
|
||||||
s.writeS32(13, m_triggerPre);
|
s.writeS32(13, m_triggerPre);
|
||||||
s.writeS32(14, m_traceLenMult);
|
s.writeS32(14, m_traceLenMult);
|
||||||
s.writeS32(15, m_triggerDelay);
|
s.writeS32(15, m_triggerDelay);
|
||||||
s.writeBool(16, m_triggerBothEdges);
|
s.writeBool(16, m_triggerBothEdges);
|
||||||
|
s.writeS32(17, m_triggerLevelFine);
|
||||||
|
|
||||||
return s.final();
|
return s.final();
|
||||||
}
|
}
|
||||||
@ -119,9 +122,8 @@ bool GLScopeGUI::deserialize(const QByteArray& data)
|
|||||||
d.readS32(8, &m_displays, GLScope::DisplayBoth);
|
d.readS32(8, &m_displays, GLScope::DisplayBoth);
|
||||||
d.readS32(9, &m_triggerChannel, ScopeVis::TriggerFreeRun);
|
d.readS32(9, &m_triggerChannel, ScopeVis::TriggerFreeRun);
|
||||||
ui->trigMode->setCurrentIndex(m_triggerChannel);
|
ui->trigMode->setCurrentIndex(m_triggerChannel);
|
||||||
d.readS32(10, &m_triggerLevel, 0);
|
d.readS32(10, &m_triggerLevelCoarse, 0);
|
||||||
ui->trigLevel->setValue(m_triggerLevel);
|
ui->trigLevelCoarse->setValue(m_triggerLevelCoarse);
|
||||||
setTrigLevelDisplay();
|
|
||||||
d.readBool(11, &m_triggerPositiveEdge, true);
|
d.readBool(11, &m_triggerPositiveEdge, true);
|
||||||
d.readS32(12, &m_displayTraceIntensity, 50);
|
d.readS32(12, &m_displayTraceIntensity, 50);
|
||||||
d.readS32(13, &m_triggerPre, 0);
|
d.readS32(13, &m_triggerPre, 0);
|
||||||
@ -143,6 +145,9 @@ bool GLScopeGUI::deserialize(const QByteArray& data)
|
|||||||
ui->slopePos->setChecked(m_triggerPositiveEdge);
|
ui->slopePos->setChecked(m_triggerPositiveEdge);
|
||||||
ui->slopeNeg->setChecked(!m_triggerPositiveEdge);
|
ui->slopeNeg->setChecked(!m_triggerPositiveEdge);
|
||||||
}
|
}
|
||||||
|
d.readS32(17, &m_triggerLevelFine, 0);
|
||||||
|
ui->trigLevelFine->setValue(m_triggerLevelFine);
|
||||||
|
setTrigLevelDisplay();
|
||||||
applySettings();
|
applySettings();
|
||||||
applyTriggerSettings();
|
applyTriggerSettings();
|
||||||
return true;
|
return true;
|
||||||
@ -197,21 +202,22 @@ void GLScopeGUI::applySettings()
|
|||||||
|
|
||||||
void GLScopeGUI::applyTriggerSettings()
|
void GLScopeGUI::applyTriggerSettings()
|
||||||
{
|
{
|
||||||
Real triggerLevel;
|
qreal t = (m_triggerLevelCoarse / 100.0) + (m_triggerLevelFine / 20000.0); // [-1.0, 1.0]
|
||||||
|
qreal triggerLevel;
|
||||||
quint32 preTriggerSamples = (m_glScope->getTraceSize() * m_triggerPre) / 100;
|
quint32 preTriggerSamples = (m_glScope->getTraceSize() * m_triggerPre) / 100;
|
||||||
|
|
||||||
if (m_triggerChannel == ScopeVis::TriggerMagDb) {
|
if (m_triggerChannel == ScopeVis::TriggerMagDb) {
|
||||||
triggerLevel = m_triggerLevel/10.0 - 100.0; // [-200.0, 0.0]
|
triggerLevel = 100.0 * (t - 1.0); // [-200.0, 0.0]
|
||||||
}
|
}
|
||||||
else if (m_triggerChannel == ScopeVis::TriggerMagLin) {
|
else if (m_triggerChannel == ScopeVis::TriggerMagLin) {
|
||||||
triggerLevel = 1.0 + (m_triggerLevel / 1000.0); // [0.0, 2.0]
|
triggerLevel = 1.0 + t; // [0.0, 2.0]
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
triggerLevel = m_triggerLevel / 1000.0; // [-1.0, 1.0]
|
triggerLevel = t; // [-1.0, 1.0]
|
||||||
}
|
}
|
||||||
|
|
||||||
m_glScope->setTriggerChannel((ScopeVis::TriggerChannel) m_triggerChannel);
|
m_glScope->setTriggerChannel((ScopeVis::TriggerChannel) m_triggerChannel);
|
||||||
m_glScope->setTriggerLevel(m_triggerLevel / 1000.0); // [-1.0, 1.0]
|
m_glScope->setTriggerLevel(t); // [-1.0, 1.0]
|
||||||
|
|
||||||
m_scopeVis->configure(m_messageQueue,
|
m_scopeVis->configure(m_messageQueue,
|
||||||
(ScopeVis::TriggerChannel) m_triggerChannel,
|
(ScopeVis::TriggerChannel) m_triggerChannel,
|
||||||
@ -225,17 +231,22 @@ void GLScopeGUI::applyTriggerSettings()
|
|||||||
|
|
||||||
void GLScopeGUI::setTrigLevelDisplay()
|
void GLScopeGUI::setTrigLevelDisplay()
|
||||||
{
|
{
|
||||||
|
qreal t = (m_triggerLevelCoarse / 100.0) + (m_triggerLevelFine / 20000.0);
|
||||||
|
|
||||||
|
ui->trigLevelCoarse->setToolTip(QString("Trigger level coarse: %1 %").arg(m_triggerLevelCoarse));
|
||||||
|
ui->trigLevelFine->setToolTip(QString("Trigger level fine: %1 ppm").arg(m_triggerLevelFine * 50));
|
||||||
|
|
||||||
if (m_triggerChannel == ScopeVis::TriggerMagDb) {
|
if (m_triggerChannel == ScopeVis::TriggerMagDb) {
|
||||||
ui->trigText->setText(tr("%1\ndB").arg(m_triggerLevel/10.0 - 100.0, 0, 'f', 1));
|
ui->trigText->setText(tr("%1\ndB").arg(100.0 * (t - 1.0), 0, 'f', 1));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
qreal a;
|
qreal a;
|
||||||
|
|
||||||
if (m_glScope->getDataMode() == GLScope::ModeMagLinPha) {
|
if (m_glScope->getDataMode() == GLScope::ModeMagLinPha) {
|
||||||
a = 1.0 + (m_triggerLevel/1000.0);
|
a = 1.0 + t;
|
||||||
} else {
|
} else {
|
||||||
a = m_triggerLevel/1000.0;
|
a = t;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(fabs(a) < 0.000001)
|
if(fabs(a) < 0.000001)
|
||||||
@ -592,9 +603,16 @@ void GLScopeGUI::on_trigMode_currentIndexChanged(int index)
|
|||||||
applyTriggerSettings();
|
applyTriggerSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLScopeGUI::on_trigLevel_valueChanged(int value)
|
void GLScopeGUI::on_trigLevelCoarse_valueChanged(int value)
|
||||||
{
|
{
|
||||||
m_triggerLevel = value;
|
m_triggerLevelCoarse = value;
|
||||||
|
setTrigLevelDisplay();
|
||||||
|
applyTriggerSettings();
|
||||||
|
}
|
||||||
|
|
||||||
|
void GLScopeGUI::on_trigLevelFine_valueChanged(int value)
|
||||||
|
{
|
||||||
|
m_triggerLevelFine = value;
|
||||||
setTrigLevelDisplay();
|
setTrigLevelDisplay();
|
||||||
applyTriggerSettings();
|
applyTriggerSettings();
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>809</width>
|
<width>809</width>
|
||||||
<height>69</height>
|
<height>65</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
@ -38,13 +38,13 @@
|
|||||||
<number>2</number>
|
<number>2</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="topMargin">
|
<property name="topMargin">
|
||||||
<number>2</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="rightMargin">
|
<property name="rightMargin">
|
||||||
<number>2</number>
|
<number>2</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="bottomMargin">
|
<property name="bottomMargin">
|
||||||
<number>2</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="dataLabel">
|
<widget class="QLabel" name="dataLabel">
|
||||||
@ -500,13 +500,13 @@
|
|||||||
<number>2</number>
|
<number>2</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="topMargin">
|
<property name="topMargin">
|
||||||
<number>2</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="rightMargin">
|
<property name="rightMargin">
|
||||||
<number>2</number>
|
<number>2</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="bottomMargin">
|
<property name="bottomMargin">
|
||||||
<number>2</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="trigLabel">
|
<widget class="QLabel" name="trigLabel">
|
||||||
@ -712,20 +712,23 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QSlider" name="trigLevel">
|
<layout class="QVBoxLayout" name="trigLevelLayout">
|
||||||
<property name="font">
|
<item>
|
||||||
<font>
|
<widget class="QSlider" name="trigLevelCoarse">
|
||||||
<pointsize>8</pointsize>
|
<property name="maximumSize">
|
||||||
</font>
|
<size>
|
||||||
|
<width>16777215</width>
|
||||||
|
<height>9</height>
|
||||||
|
</size>
|
||||||
</property>
|
</property>
|
||||||
<property name="toolTip">
|
<property name="toolTip">
|
||||||
<string>Trigger level</string>
|
<string>Trigger level coarse</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="minimum">
|
<property name="minimum">
|
||||||
<number>-1000</number>
|
<number>-100</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="maximum">
|
<property name="maximum">
|
||||||
<number>1000</number>
|
<number>100</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="pageStep">
|
<property name="pageStep">
|
||||||
<number>1</number>
|
<number>1</number>
|
||||||
@ -735,6 +738,33 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
<item>
|
||||||
|
<widget class="QSlider" name="trigLevelFine">
|
||||||
|
<property name="maximumSize">
|
||||||
|
<size>
|
||||||
|
<width>16777215</width>
|
||||||
|
<height>9</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
<property name="toolTip">
|
||||||
|
<string>Trigger level fine</string>
|
||||||
|
</property>
|
||||||
|
<property name="minimum">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="maximum">
|
||||||
|
<number>200</number>
|
||||||
|
</property>
|
||||||
|
<property name="pageStep">
|
||||||
|
<number>1</number>
|
||||||
|
</property>
|
||||||
|
<property name="orientation">
|
||||||
|
<enum>Qt::Horizontal</enum>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
</item>
|
||||||
|
</layout>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="trigText">
|
<widget class="QLabel" name="trigText">
|
||||||
<property name="font">
|
<property name="font">
|
||||||
|
Loading…
x
Reference in New Issue
Block a user