mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-26 10:30:25 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include "dsp/spectrumscopecombovis.h"
 | |
| #include "dsp/dspcommands.h"
 | |
| #include "dsp/scopevis.h"
 | |
| #include "util/messagequeue.h"
 | |
| 
 | |
| SpectrumScopeComboVis::SpectrumScopeComboVis(SpectrumVis* spectrumVis, ScopeVis* scopeVis) :
 | |
| 	m_spectrumVis(spectrumVis),
 | |
| 	m_scopeVis(scopeVis)
 | |
| {
 | |
| 	setObjectName("SpectrumScopeComboVis");
 | |
| }
 | |
| 
 | |
| SpectrumScopeComboVis::~SpectrumScopeComboVis()
 | |
| {
 | |
| }
 | |
| 
 | |
| void SpectrumScopeComboVis::feed(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, bool positiveOnly)
 | |
| {
 | |
|     (void) positiveOnly;
 | |
| 	m_scopeVis->feed(begin, end, false);
 | |
| 	//SampleVector::const_iterator triggerPoint = m_scopeVis->getTriggerPoint();
 | |
| 	//m_spectrumVis->feedTriggered(triggerPoint, end, positiveOnly);
 | |
|     int triggerPointLocation = m_scopeVis->getTriggerLocation();
 | |
| 
 | |
|     if (m_scopeVis->getFreeRun()) {
 | |
|         m_spectrumVis->feed(begin, end, positiveOnly);
 | |
|     } else if ((triggerPointLocation >= 0) && (triggerPointLocation <= end - begin)) {
 | |
|         m_spectrumVis->feedTriggered(end - triggerPointLocation, end, positiveOnly);
 | |
|     } else {
 | |
|         m_spectrumVis->feedTriggered(begin, end, positiveOnly);
 | |
|     }
 | |
| }
 | |
| 
 | |
| void SpectrumScopeComboVis::start()
 | |
| {
 | |
| 	m_spectrumVis->start();
 | |
| 	m_scopeVis->start();
 | |
| }
 | |
| 
 | |
| void SpectrumScopeComboVis::stop()
 | |
| {
 | |
| 	m_spectrumVis->stop();
 | |
| 	m_scopeVis->stop();
 | |
| }
 | |
| 
 | |
| bool SpectrumScopeComboVis::handleMessage(const Message& message)
 | |
| {
 | |
| 	bool spectDone = m_spectrumVis->handleMessage(message);
 | |
| 	bool scopeDone = m_scopeVis->handleMessage(message);
 | |
| 
 | |
| 	return (spectDone || scopeDone);
 | |
| }
 |