mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 18:10:22 -04:00 
			
		
		
		
	Scope GUI updates.
Save/restore state of freerun button, trigger stream index and trigger pre index. Increase number of channels from 4 to 8.
This commit is contained in:
		
							parent
							
								
									485986acec
								
							
						
					
					
						commit
						72971a3dba
					
				| @ -66,6 +66,7 @@ void GLScopeSettings::resetToDefaults() | |||||||
|     m_timeOfs = 0; |     m_timeOfs = 0; | ||||||
|     m_traceLenMult = 1; |     m_traceLenMult = 1; | ||||||
|     m_trigPre = 0; |     m_trigPre = 0; | ||||||
|  |     m_freerun = true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QByteArray GLScopeSettings::serialize() const | QByteArray GLScopeSettings::serialize() const | ||||||
| @ -79,6 +80,7 @@ QByteArray GLScopeSettings::serialize() const | |||||||
|     s.writeS32(4, m_time); |     s.writeS32(4, m_time); | ||||||
|     // s.writeS32(5, m_timeOfs);
 |     // s.writeS32(5, m_timeOfs);
 | ||||||
|     s.writeS32(6, m_traceLenMult); |     s.writeS32(6, m_traceLenMult); | ||||||
|  |     s.writeBool(7, m_freerun); | ||||||
| 
 | 
 | ||||||
|     std::vector<TraceData>::const_iterator traceDataIt = m_tracesData.begin(); |     std::vector<TraceData>::const_iterator traceDataIt = m_tracesData.begin(); | ||||||
|     unsigned int i = 0; |     unsigned int i = 0; | ||||||
| @ -148,6 +150,7 @@ bool GLScopeSettings::deserialize(const QByteArray& data) | |||||||
|         d.readS32(4, &m_time, 1); |         d.readS32(4, &m_time, 1); | ||||||
|         // d.readS32(5, &m_timeOfs, 0);
 |         // d.readS32(5, &m_timeOfs, 0);
 | ||||||
|         d.readS32(6, &m_traceLenMult, 1); |         d.readS32(6, &m_traceLenMult, 1); | ||||||
|  |         d.readBool(7, &m_freerun, true); | ||||||
|         d.readS32(201, &m_trigPre, 0); |         d.readS32(201, &m_trigPre, 0); | ||||||
| 
 | 
 | ||||||
|         uint32_t nbTracesSaved; |         uint32_t nbTracesSaved; | ||||||
|  | |||||||
| @ -162,6 +162,7 @@ public: | |||||||
|     int m_timeOfs; |     int m_timeOfs; | ||||||
|     int m_traceLenMult; |     int m_traceLenMult; | ||||||
|     int m_trigPre; |     int m_trigPre; | ||||||
|  |     bool m_freerun; | ||||||
|     std::vector<TraceData> m_tracesData; |     std::vector<TraceData> m_tracesData; | ||||||
|     std::vector<TriggerData> m_triggersData; |     std::vector<TriggerData> m_triggersData; | ||||||
|     static const double AMPS[27]; |     static const double AMPS[27]; | ||||||
|  | |||||||
| @ -809,7 +809,7 @@ void GLScopeGUI::on_memorySave_clicked(bool checked) | |||||||
| { | { | ||||||
|     (void) checked; |     (void) checked; | ||||||
|     QString fileName = QFileDialog::getSaveFileName(this, |     QString fileName = QFileDialog::getSaveFileName(this, | ||||||
|         tr("Open trace memory file"), ".", tr("Trace memory files (*.trcm)"), 0, QFileDialog::DontUseNativeDialog); |         tr("Create trace memory file"), ".", tr("Trace memory files (*.trcm)"), 0, QFileDialog::DontUseNativeDialog); | ||||||
| 
 | 
 | ||||||
|     if (fileName != "") |     if (fileName != "") | ||||||
|     { |     { | ||||||
| @ -1008,6 +1008,8 @@ void GLScopeGUI::on_freerun_toggled(bool checked) | |||||||
|         (uint32_t) (m_glScope->getTraceSize() * (ui->trigPre->value()/100.0f)), |         (uint32_t) (m_glScope->getTraceSize() * (ui->trigPre->value()/100.0f)), | ||||||
|         ui->freerun->isChecked() |         ui->freerun->isChecked() | ||||||
|     ); |     ); | ||||||
|  | 
 | ||||||
|  |     m_settings.m_freerun = checked; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GLScopeGUI::setTraceIndexDisplay() | void GLScopeGUI::setTraceIndexDisplay() | ||||||
| @ -1367,6 +1369,7 @@ void GLScopeGUI::fillTraceData(GLScopeSettings::TraceData& traceData) | |||||||
| 
 | 
 | ||||||
| void GLScopeGUI::fillTriggerData(GLScopeSettings::TriggerData& triggerData) | void GLScopeGUI::fillTriggerData(GLScopeSettings::TriggerData& triggerData) | ||||||
| { | { | ||||||
|  |     triggerData.m_streamIndex = ui->trigStream->currentIndex(); | ||||||
|     triggerData.m_projectionType = (Projector::ProjectionType) ui->trigMode->currentIndex(); |     triggerData.m_projectionType = (Projector::ProjectionType) ui->trigMode->currentIndex(); | ||||||
|     triggerData.m_inputIndex = 0; |     triggerData.m_inputIndex = 0; | ||||||
|     triggerData.m_triggerLevel = (ui->trigLevelCoarse->value() / 100.0) + (ui->trigLevelFine->value() / 50000.0); |     triggerData.m_triggerLevel = (ui->trigLevelCoarse->value() / 100.0) + (ui->trigLevelFine->value() / 50000.0); | ||||||
| @ -1428,6 +1431,7 @@ void GLScopeGUI::setTriggerUI(const GLScopeSettings::TriggerData& triggerData) | |||||||
| { | { | ||||||
|     TrigUIBlocker trigUIBlocker(ui); |     TrigUIBlocker trigUIBlocker(ui); | ||||||
| 
 | 
 | ||||||
|  |     ui->trigStream->setCurrentIndex(triggerData.m_streamIndex); | ||||||
|     ui->trigMode->setCurrentIndex((int) triggerData.m_projectionType); |     ui->trigMode->setCurrentIndex((int) triggerData.m_projectionType); | ||||||
|     ui->trigCount->setValue(triggerData.m_triggerRepeat); |     ui->trigCount->setValue(triggerData.m_triggerRepeat); | ||||||
|     setTrigCountDisplay(); |     setTrigCountDisplay(); | ||||||
| @ -1507,6 +1511,9 @@ void GLScopeGUI::displaySettings() | |||||||
|     ui->timeOfs->setValue(m_settings.m_timeOfs); |     ui->timeOfs->setValue(m_settings.m_timeOfs); | ||||||
|     setTimeOfsDisplay(); |     setTimeOfsDisplay(); | ||||||
|     ui->traceLen->setValue(m_settings.m_traceLenMult); |     ui->traceLen->setValue(m_settings.m_traceLenMult); | ||||||
|  |     setPreTrigger(100.0f * m_settings.m_trigPre / m_glScope->getTraceSize()); | ||||||
|  |     ui->freerun->setChecked(m_settings.m_freerun); | ||||||
|  |     changeCurrentTrigger(); // Ensure consistency with GUI
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool GLScopeGUI::handleMessage(Message* message) | bool GLScopeGUI::handleMessage(Message* message) | ||||||
| @ -1518,6 +1525,7 @@ bool GLScopeGUI::handleMessage(Message* message) | |||||||
| GLScopeGUI::TrigUIBlocker::TrigUIBlocker(Ui::GLScopeGUI *ui) : | GLScopeGUI::TrigUIBlocker::TrigUIBlocker(Ui::GLScopeGUI *ui) : | ||||||
|         m_ui(ui) |         m_ui(ui) | ||||||
| { | { | ||||||
|  |     m_oldStateTrigStream      = ui->trigStream->blockSignals(true); | ||||||
|     m_oldStateTrigMode        = ui->trigMode->blockSignals(true); |     m_oldStateTrigMode        = ui->trigMode->blockSignals(true); | ||||||
|     m_oldStateTrigCount       = ui->trigCount->blockSignals(true); |     m_oldStateTrigCount       = ui->trigCount->blockSignals(true); | ||||||
|     m_oldStateTrigPos         = ui->trigPos->blockSignals(true); |     m_oldStateTrigPos         = ui->trigPos->blockSignals(true); | ||||||
| @ -1537,6 +1545,7 @@ GLScopeGUI::TrigUIBlocker::~TrigUIBlocker() | |||||||
| 
 | 
 | ||||||
| void GLScopeGUI::TrigUIBlocker::unBlock() | void GLScopeGUI::TrigUIBlocker::unBlock() | ||||||
| { | { | ||||||
|  |     m_ui->trigStream->blockSignals(m_oldStateTrigStream); | ||||||
|     m_ui->trigMode->blockSignals(m_oldStateTrigMode); |     m_ui->trigMode->blockSignals(m_oldStateTrigMode); | ||||||
|     m_ui->trigCount->blockSignals(m_oldStateTrigCount); |     m_ui->trigCount->blockSignals(m_oldStateTrigCount); | ||||||
|     m_ui->trigPos->blockSignals(m_oldStateTrigPos); |     m_ui->trigPos->blockSignals(m_oldStateTrigPos); | ||||||
| @ -1746,7 +1755,7 @@ void GLScopeGUI::changeTrace(int traceIndex, const GLScopeSettings::TraceData& t | |||||||
| 
 | 
 | ||||||
| void GLScopeGUI::addTrace(const GLScopeSettings::TraceData& traceData) | void GLScopeGUI::addTrace(const GLScopeSettings::TraceData& traceData) | ||||||
| { | { | ||||||
|     if (ui->trace->maximum() < 3) |     if (ui->trace->maximum() < 7) // Limit number of channels to 8. Is it necessary?
 | ||||||
|     { |     { | ||||||
|         if (ui->trace->value() == 0) |         if (ui->trace->value() == 0) | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -89,6 +89,7 @@ private: | |||||||
| 
 | 
 | ||||||
|     private: |     private: | ||||||
|         Ui::GLScopeGUI *m_ui; |         Ui::GLScopeGUI *m_ui; | ||||||
|  |         bool m_oldStateTrigStream; | ||||||
|         bool m_oldStateTrigMode; |         bool m_oldStateTrigMode; | ||||||
|         bool m_oldStateTrigCount; |         bool m_oldStateTrigCount; | ||||||
|         bool m_oldStateTrigPos; |         bool m_oldStateTrigPos; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user