kopia lustrzana https://github.com/f4exb/sdrangel
				
				
				
			Revert "BFM demod: introducing LSB stereo for what it's worth..."
This reverts commit b5669fee2f.
			
			
				pull/6/head
			
			
		
							rodzic
							
								
									7e67793059
								
							
						
					
					
						commit
						8065c4157c
					
				| 
						 | 
					@ -128,9 +128,7 @@ protected:
 | 
				
			||||||
    	samples_out[0] = m_psin; // f Pilot
 | 
					    	samples_out[0] = m_psin; // f Pilot
 | 
				
			||||||
        // Generate double-frequency output.
 | 
					        // Generate double-frequency output.
 | 
				
			||||||
        // sin(2*x) = 2 * sin(x) * cos(x)
 | 
					        // sin(2*x) = 2 * sin(x) * cos(x)
 | 
				
			||||||
    	samples_out[1] = 2.0 * m_psin * m_pcos; // 2f Pilot sin
 | 
					    	samples_out[1] = 2.0 * m_psin * m_pcos; // 2f Pilot
 | 
				
			||||||
        // cos(2*x) = 2 * cos(x) * cos(x) - 1
 | 
					 | 
				
			||||||
    	samples_out[1] = (2.0 * m_pcos * m_pcos) - 1.0; // 2f Pilot cos
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -152,8 +150,6 @@ protected:
 | 
				
			||||||
        // Generate double-frequency output.
 | 
					        // Generate double-frequency output.
 | 
				
			||||||
        // sin(2*x) = 2 * sin(x) * cos(x)
 | 
					        // sin(2*x) = 2 * sin(x) * cos(x)
 | 
				
			||||||
        samples_out[1] = 2.0 * m_psin * m_pcos; // Pilot signal (2f)
 | 
					        samples_out[1] = 2.0 * m_psin * m_pcos; // Pilot signal (2f)
 | 
				
			||||||
        // cos(2*x) = 2 * cos(x) * cos(x) - 1
 | 
					        samples_out[2] = m_phase; // Pilot phase
 | 
				
			||||||
    	samples_out[1] = (2.0 * m_pcos * m_pcos) - 1.0; // 2f Pilot cos
 | 
					 | 
				
			||||||
        samples_out[3] = m_phase; // Pilot phase
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -50,7 +50,7 @@ BFMDemod::BFMDemod(SampleSink* sampleSink, RDSParser *rdsParser) :
 | 
				
			||||||
	m_config.m_audioSampleRate = DSPEngine::instance()->getAudioSampleRate(); // normally 48 kHz
 | 
						m_config.m_audioSampleRate = DSPEngine::instance()->getAudioSampleRate(); // normally 48 kHz
 | 
				
			||||||
	m_deemphasisFilterX.configure(default_deemphasis * m_config.m_audioSampleRate * 1.0e-6);
 | 
						m_deemphasisFilterX.configure(default_deemphasis * m_config.m_audioSampleRate * 1.0e-6);
 | 
				
			||||||
	m_deemphasisFilterY.configure(default_deemphasis * m_config.m_audioSampleRate * 1.0e-6);
 | 
						m_deemphasisFilterY.configure(default_deemphasis * m_config.m_audioSampleRate * 1.0e-6);
 | 
				
			||||||
	m_rfFilter = new fftfilt(-50000.0 / 384000.0, 50000.0 / 384000.0, filtFftLen);
 | 
						m_rfFilter = new fftfilt(-50000.0 / 384000.0, 50000.0 / 384000.0, rfFilterFftLength);
 | 
				
			||||||
	m_phaseDiscri.setFMScaling(384000/m_fmExcursion);
 | 
						m_phaseDiscri.setFMScaling(384000/m_fmExcursion);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apply();
 | 
						apply();
 | 
				
			||||||
| 
						 | 
					@ -79,7 +79,6 @@ void BFMDemod::configure(MessageQueue* messageQueue,
 | 
				
			||||||
		Real volume,
 | 
							Real volume,
 | 
				
			||||||
		Real squelch,
 | 
							Real squelch,
 | 
				
			||||||
		bool audioStereo,
 | 
							bool audioStereo,
 | 
				
			||||||
		bool lsbStereo,
 | 
					 | 
				
			||||||
		bool showPilot,
 | 
							bool showPilot,
 | 
				
			||||||
		bool rdsActive)
 | 
							bool rdsActive)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -88,7 +87,6 @@ void BFMDemod::configure(MessageQueue* messageQueue,
 | 
				
			||||||
			volume,
 | 
								volume,
 | 
				
			||||||
			squelch,
 | 
								squelch,
 | 
				
			||||||
			audioStereo,
 | 
								audioStereo,
 | 
				
			||||||
			lsbStereo,
 | 
					 | 
				
			||||||
			showPilot,
 | 
								showPilot,
 | 
				
			||||||
			rdsActive);
 | 
								rdsActive);
 | 
				
			||||||
	messageQueue->push(cmd);
 | 
						messageQueue->push(cmd);
 | 
				
			||||||
| 
						 | 
					@ -140,8 +138,8 @@ void BFMDemod::feed(const SampleVector::const_iterator& begin, const SampleVecto
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (m_running.m_rdsActive)
 | 
								if (m_running.m_rdsActive)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
				//Complex r(demod * 2.0 * std::cos(3.0 * m_pilotPLLSamples[3]), 0.0);
 | 
									//Complex r(demod * 2.0 * std::cos(3.0 * m_pilotPLLSamples[2]), 0.0);
 | 
				
			||||||
				Complex r(demod * 2.0 * std::cos(3.0 * m_pilotPLLSamples[3]), 0.0);
 | 
									Complex r(demod * 2.0 * std::cos(3.0 * m_pilotPLLSamples[2]), 0.0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (m_interpolatorRDS.interpolate(&m_interpolatorRDSDistanceRemain, r, &cr))
 | 
									if (m_interpolatorRDS.interpolate(&m_interpolatorRDSDistanceRemain, r, &cr))
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
| 
						 | 
					@ -175,25 +173,12 @@ void BFMDemod::feed(const SampleVector::const_iterator& begin, const SampleVecto
 | 
				
			||||||
					m_sampleBuffer.push_back(Sample(m_pilotPLLSamples[1] * (1<<15), 0.0)); // debug 38 kHz pilot
 | 
										m_sampleBuffer.push_back(Sample(m_pilotPLLSamples[1] * (1<<15), 0.0)); // debug 38 kHz pilot
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (m_running.m_lsbStereo)
 | 
									Complex s(demod * 1.17 * m_pilotPLLSamples[1], 0);
 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
					Complex s(demod * 1.21 * m_pilotPLLSamples[1], demod * 1.21 * m_pilotPLLSamples[2]);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
					if (m_interpolatorStereo.interpolate(&m_interpolatorStereoDistanceRemain, s, &cs))
 | 
									if (m_interpolatorStereo.interpolate(&m_interpolatorStereoDistanceRemain, s, &cs))
 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						sampleStereo = cs.real() + cs.imag();
 | 
					 | 
				
			||||||
						m_interpolatorStereoDistanceRemain += m_interpolatorStereoDistance;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
				else
 | 
					 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
					Complex s(demod * 1.17 * m_pilotPLLSamples[1], 0);
 | 
										sampleStereo = cs.real();
 | 
				
			||||||
 | 
										m_interpolatorStereoDistanceRemain += m_interpolatorStereoDistance;
 | 
				
			||||||
					if (m_interpolatorStereo.interpolate(&m_interpolatorStereoDistanceRemain, s, &cs))
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						sampleStereo = cs.real();
 | 
					 | 
				
			||||||
						m_interpolatorStereoDistanceRemain += m_interpolatorStereoDistance;
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -206,16 +191,8 @@ void BFMDemod::feed(const SampleVector::const_iterator& begin, const SampleVecto
 | 
				
			||||||
					Real deemph_l, deemph_r; // Pre-emphasis is applied on each channel before multiplexing
 | 
										Real deemph_l, deemph_r; // Pre-emphasis is applied on each channel before multiplexing
 | 
				
			||||||
					m_deemphasisFilterX.process(ci.real() + sampleStereo, deemph_l);
 | 
										m_deemphasisFilterX.process(ci.real() + sampleStereo, deemph_l);
 | 
				
			||||||
					m_deemphasisFilterY.process(ci.real() - sampleStereo, deemph_r);
 | 
										m_deemphasisFilterY.process(ci.real() - sampleStereo, deemph_r);
 | 
				
			||||||
					if (m_running.m_lsbStereo)
 | 
										m_audioBuffer[m_audioBufferFill].l = (qint16)(deemph_l * (1<<12) * m_running.m_volume);
 | 
				
			||||||
					{
 | 
										m_audioBuffer[m_audioBufferFill].r = (qint16)(deemph_r * (1<<12) * m_running.m_volume);
 | 
				
			||||||
						m_audioBuffer[m_audioBufferFill].l = (qint16)(deemph_l * (1<<12) * m_running.m_volume);
 | 
					 | 
				
			||||||
						m_audioBuffer[m_audioBufferFill].r = (qint16)(deemph_r * (1<<12) * m_running.m_volume);
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
					else
 | 
					 | 
				
			||||||
					{
 | 
					 | 
				
			||||||
						m_audioBuffer[m_audioBufferFill].l = (qint16)(deemph_l * (1<<12) * m_running.m_volume);
 | 
					 | 
				
			||||||
						m_audioBuffer[m_audioBufferFill].r = (qint16)(deemph_r * (1<<12) * m_running.m_volume);
 | 
					 | 
				
			||||||
					}
 | 
					 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
				else
 | 
									else
 | 
				
			||||||
				{
 | 
									{
 | 
				
			||||||
| 
						 | 
					@ -303,7 +280,6 @@ bool BFMDemod::handleMessage(const Message& cmd)
 | 
				
			||||||
		m_config.m_volume = cfg.getVolume();
 | 
							m_config.m_volume = cfg.getVolume();
 | 
				
			||||||
		m_config.m_squelch = cfg.getSquelch();
 | 
							m_config.m_squelch = cfg.getSquelch();
 | 
				
			||||||
		m_config.m_audioStereo = cfg.getAudioStereo();
 | 
							m_config.m_audioStereo = cfg.getAudioStereo();
 | 
				
			||||||
		m_config.m_lsbStereo = cfg.getLsbStereo();
 | 
					 | 
				
			||||||
		m_config.m_showPilot = cfg.getShowPilot();
 | 
							m_config.m_showPilot = cfg.getShowPilot();
 | 
				
			||||||
		m_config.m_rdsActive = cfg.getRDSActive();
 | 
							m_config.m_rdsActive = cfg.getRDSActive();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -314,7 +290,6 @@ bool BFMDemod::handleMessage(const Message& cmd)
 | 
				
			||||||
				<< " m_volume: " << m_config.m_volume
 | 
									<< " m_volume: " << m_config.m_volume
 | 
				
			||||||
				<< " m_squelch: " << m_config.m_squelch
 | 
									<< " m_squelch: " << m_config.m_squelch
 | 
				
			||||||
				<< " m_audioStereo: " << m_config.m_audioStereo
 | 
									<< " m_audioStereo: " << m_config.m_audioStereo
 | 
				
			||||||
				<< " m_lsbStereo: " << m_config.m_lsbStereo
 | 
					 | 
				
			||||||
				<< " m_showPilot: " << m_config.m_showPilot
 | 
									<< " m_showPilot: " << m_config.m_showPilot
 | 
				
			||||||
				<< " m_rdsActive: " << m_config.m_rdsActive;
 | 
									<< " m_rdsActive: " << m_config.m_rdsActive;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -417,7 +392,6 @@ void BFMDemod::apply()
 | 
				
			||||||
	m_running.m_volume = m_config.m_volume;
 | 
						m_running.m_volume = m_config.m_volume;
 | 
				
			||||||
	m_running.m_audioSampleRate = m_config.m_audioSampleRate;
 | 
						m_running.m_audioSampleRate = m_config.m_audioSampleRate;
 | 
				
			||||||
	m_running.m_audioStereo = m_config.m_audioStereo;
 | 
						m_running.m_audioStereo = m_config.m_audioStereo;
 | 
				
			||||||
	m_running.m_lsbStereo = m_config.m_lsbStereo;
 | 
					 | 
				
			||||||
	m_running.m_showPilot = m_config.m_showPilot;
 | 
						m_running.m_showPilot = m_config.m_showPilot;
 | 
				
			||||||
	m_running.m_rdsActive = m_config.m_rdsActive;
 | 
						m_running.m_rdsActive = m_config.m_rdsActive;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -34,6 +34,8 @@
 | 
				
			||||||
#include "rdsdemod.h"
 | 
					#include "rdsdemod.h"
 | 
				
			||||||
#include "rdsdecoder.h"
 | 
					#include "rdsdecoder.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define rfFilterFftLength 1024
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class RDSParser;
 | 
					class RDSParser;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class BFMDemod : public SampleSink {
 | 
					class BFMDemod : public SampleSink {
 | 
				
			||||||
| 
						 | 
					@ -47,7 +49,6 @@ public:
 | 
				
			||||||
			Real volume,
 | 
								Real volume,
 | 
				
			||||||
			Real squelch,
 | 
								Real squelch,
 | 
				
			||||||
			bool audioStereo,
 | 
								bool audioStereo,
 | 
				
			||||||
			bool lsbStereo,
 | 
					 | 
				
			||||||
			bool showPilot,
 | 
								bool showPilot,
 | 
				
			||||||
			bool rdsActive);
 | 
								bool rdsActive);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -78,7 +79,6 @@ private:
 | 
				
			||||||
		Real getVolume() const { return m_volume; }
 | 
							Real getVolume() const { return m_volume; }
 | 
				
			||||||
		Real getSquelch() const { return m_squelch; }
 | 
							Real getSquelch() const { return m_squelch; }
 | 
				
			||||||
		bool getAudioStereo() const { return m_audioStereo; }
 | 
							bool getAudioStereo() const { return m_audioStereo; }
 | 
				
			||||||
		bool getLsbStereo() const { return m_lsbStereo; }
 | 
					 | 
				
			||||||
		bool getShowPilot() const { return m_showPilot; }
 | 
							bool getShowPilot() const { return m_showPilot; }
 | 
				
			||||||
		bool getRDSActive() const { return m_rdsActive; }
 | 
							bool getRDSActive() const { return m_rdsActive; }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -87,7 +87,6 @@ private:
 | 
				
			||||||
				Real volume,
 | 
									Real volume,
 | 
				
			||||||
				Real squelch,
 | 
									Real squelch,
 | 
				
			||||||
				bool audioStereo,
 | 
									bool audioStereo,
 | 
				
			||||||
				bool lsbStereo,
 | 
					 | 
				
			||||||
				bool showPilot,
 | 
									bool showPilot,
 | 
				
			||||||
				bool rdsActive)
 | 
									bool rdsActive)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
| 
						 | 
					@ -96,7 +95,6 @@ private:
 | 
				
			||||||
					volume,
 | 
										volume,
 | 
				
			||||||
					squelch,
 | 
										squelch,
 | 
				
			||||||
					audioStereo,
 | 
										audioStereo,
 | 
				
			||||||
					lsbStereo,
 | 
					 | 
				
			||||||
					showPilot,
 | 
										showPilot,
 | 
				
			||||||
					rdsActive);
 | 
										rdsActive);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
| 
						 | 
					@ -107,7 +105,6 @@ private:
 | 
				
			||||||
		Real m_volume;
 | 
							Real m_volume;
 | 
				
			||||||
		Real m_squelch;
 | 
							Real m_squelch;
 | 
				
			||||||
		bool m_audioStereo;
 | 
							bool m_audioStereo;
 | 
				
			||||||
		bool m_lsbStereo;
 | 
					 | 
				
			||||||
		bool m_showPilot;
 | 
							bool m_showPilot;
 | 
				
			||||||
		bool m_rdsActive;
 | 
							bool m_rdsActive;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -116,7 +113,6 @@ private:
 | 
				
			||||||
				Real volume,
 | 
									Real volume,
 | 
				
			||||||
				Real squelch,
 | 
									Real squelch,
 | 
				
			||||||
				bool audioStereo,
 | 
									bool audioStereo,
 | 
				
			||||||
				bool lsbStereo,
 | 
					 | 
				
			||||||
				bool showPilot,
 | 
									bool showPilot,
 | 
				
			||||||
				bool rdsActive) :
 | 
									bool rdsActive) :
 | 
				
			||||||
			Message(),
 | 
								Message(),
 | 
				
			||||||
| 
						 | 
					@ -125,7 +121,6 @@ private:
 | 
				
			||||||
			m_volume(volume),
 | 
								m_volume(volume),
 | 
				
			||||||
			m_squelch(squelch),
 | 
								m_squelch(squelch),
 | 
				
			||||||
			m_audioStereo(audioStereo),
 | 
								m_audioStereo(audioStereo),
 | 
				
			||||||
			m_lsbStereo(lsbStereo),
 | 
					 | 
				
			||||||
			m_showPilot(showPilot),
 | 
								m_showPilot(showPilot),
 | 
				
			||||||
			m_rdsActive(rdsActive)
 | 
								m_rdsActive(rdsActive)
 | 
				
			||||||
		{ }
 | 
							{ }
 | 
				
			||||||
| 
						 | 
					@ -151,7 +146,6 @@ private:
 | 
				
			||||||
		Real m_volume;
 | 
							Real m_volume;
 | 
				
			||||||
		quint32 m_audioSampleRate;
 | 
							quint32 m_audioSampleRate;
 | 
				
			||||||
		bool m_audioStereo;
 | 
							bool m_audioStereo;
 | 
				
			||||||
		bool m_lsbStereo;
 | 
					 | 
				
			||||||
		bool m_showPilot;
 | 
							bool m_showPilot;
 | 
				
			||||||
		bool m_rdsActive;
 | 
							bool m_rdsActive;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -164,7 +158,6 @@ private:
 | 
				
			||||||
			m_volume(0),
 | 
								m_volume(0),
 | 
				
			||||||
			m_audioSampleRate(0),
 | 
								m_audioSampleRate(0),
 | 
				
			||||||
			m_audioStereo(false),
 | 
								m_audioStereo(false),
 | 
				
			||||||
			m_lsbStereo(false),
 | 
					 | 
				
			||||||
			m_showPilot(false),
 | 
								m_showPilot(false),
 | 
				
			||||||
			m_rdsActive(false)
 | 
								m_rdsActive(false)
 | 
				
			||||||
		{ }
 | 
							{ }
 | 
				
			||||||
| 
						 | 
					@ -188,7 +181,6 @@ private:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	Lowpass<Real> m_lowpass;
 | 
						Lowpass<Real> m_lowpass;
 | 
				
			||||||
	fftfilt* m_rfFilter;
 | 
						fftfilt* m_rfFilter;
 | 
				
			||||||
	static const int filtFftLen = 1024;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	Real m_squelchLevel;
 | 
						Real m_squelchLevel;
 | 
				
			||||||
	int m_squelchState;
 | 
						int m_squelchState;
 | 
				
			||||||
| 
						 | 
					@ -206,7 +198,7 @@ private:
 | 
				
			||||||
	QMutex m_settingsMutex;
 | 
						QMutex m_settingsMutex;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	RDSPhaseLock m_pilotPLL;
 | 
						RDSPhaseLock m_pilotPLL;
 | 
				
			||||||
	Real m_pilotPLLSamples[4];
 | 
						Real m_pilotPLLSamples[3];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	RDSDemod m_rdsDemod;
 | 
						RDSDemod m_rdsDemod;
 | 
				
			||||||
	RDSDecoder m_rdsDecoder;
 | 
						RDSDecoder m_rdsDecoder;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -110,7 +110,6 @@ QByteArray BFMDemodGUI::serialize() const
 | 
				
			||||||
	s.writeU32(7, m_channelMarker.getColor().rgb());
 | 
						s.writeU32(7, m_channelMarker.getColor().rgb());
 | 
				
			||||||
	s.writeBlob(8, ui->spectrumGUI->serialize());
 | 
						s.writeBlob(8, ui->spectrumGUI->serialize());
 | 
				
			||||||
	s.writeBool(9, ui->audioStereo->isChecked());
 | 
						s.writeBool(9, ui->audioStereo->isChecked());
 | 
				
			||||||
	s.writeBool(10, ui->lsbStereo->isChecked());
 | 
					 | 
				
			||||||
	return s.final();
 | 
						return s.final();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -163,9 +162,6 @@ bool BFMDemodGUI::deserialize(const QByteArray& data)
 | 
				
			||||||
		d.readBool(9, &booltmp, false);
 | 
							d.readBool(9, &booltmp, false);
 | 
				
			||||||
		ui->audioStereo->setChecked(booltmp);
 | 
							ui->audioStereo->setChecked(booltmp);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		d.readBool(10, &booltmp, false);
 | 
					 | 
				
			||||||
		ui->lsbStereo->setChecked(booltmp);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		blockApplySettings(false);
 | 
							blockApplySettings(false);
 | 
				
			||||||
	    m_channelMarker.blockSignals(false);
 | 
						    m_channelMarker.blockSignals(false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -247,11 +243,6 @@ void BFMDemodGUI::on_audioStereo_toggled(bool stereo)
 | 
				
			||||||
	applySettings();
 | 
						applySettings();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void BFMDemodGUI::on_lsbStereo_toggled(bool lsb)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
	applySettings();
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void BFMDemodGUI::on_showPilot_clicked()
 | 
					void BFMDemodGUI::on_showPilot_clicked()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	applySettings();
 | 
						applySettings();
 | 
				
			||||||
| 
						 | 
					@ -445,7 +436,6 @@ void BFMDemodGUI::applySettings()
 | 
				
			||||||
			ui->volume->value() / 10.0,
 | 
								ui->volume->value() / 10.0,
 | 
				
			||||||
			ui->squelch->value(),
 | 
								ui->squelch->value(),
 | 
				
			||||||
			ui->audioStereo->isChecked(),
 | 
								ui->audioStereo->isChecked(),
 | 
				
			||||||
			ui->lsbStereo->isChecked(),
 | 
					 | 
				
			||||||
			ui->showPilot->isChecked(),
 | 
								ui->showPilot->isChecked(),
 | 
				
			||||||
			ui->rds->isChecked());
 | 
								ui->rds->isChecked());
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -63,7 +63,6 @@ private slots:
 | 
				
			||||||
	void on_volume_valueChanged(int value);
 | 
						void on_volume_valueChanged(int value);
 | 
				
			||||||
	void on_squelch_valueChanged(int value);
 | 
						void on_squelch_valueChanged(int value);
 | 
				
			||||||
	void on_audioStereo_toggled(bool stereo);
 | 
						void on_audioStereo_toggled(bool stereo);
 | 
				
			||||||
	void on_lsbStereo_toggled(bool lsb);
 | 
					 | 
				
			||||||
	void on_showPilot_clicked();
 | 
						void on_showPilot_clicked();
 | 
				
			||||||
	void on_rds_clicked();
 | 
						void on_rds_clicked();
 | 
				
			||||||
	void on_g14ProgServiceNames_currentIndexChanged(int index);
 | 
						void on_g14ProgServiceNames_currentIndexChanged(int index);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -21,7 +21,7 @@
 | 
				
			||||||
    <rect>
 | 
					    <rect>
 | 
				
			||||||
     <x>10</x>
 | 
					     <x>10</x>
 | 
				
			||||||
     <y>20</y>
 | 
					     <y>20</y>
 | 
				
			||||||
     <width>411</width>
 | 
					     <width>311</width>
 | 
				
			||||||
     <height>121</height>
 | 
					     <height>121</height>
 | 
				
			||||||
    </rect>
 | 
					    </rect>
 | 
				
			||||||
   </property>
 | 
					   </property>
 | 
				
			||||||
| 
						 | 
					@ -160,26 +160,6 @@
 | 
				
			||||||
          </property>
 | 
					          </property>
 | 
				
			||||||
         </widget>
 | 
					         </widget>
 | 
				
			||||||
        </item>
 | 
					        </item>
 | 
				
			||||||
        <item>
 | 
					 | 
				
			||||||
         <widget class="ButtonSwitch" name="lsbStereo">
 | 
					 | 
				
			||||||
          <property name="toolTip">
 | 
					 | 
				
			||||||
           <string>Use only LSB from stereo subcarrier </string>
 | 
					 | 
				
			||||||
          </property>
 | 
					 | 
				
			||||||
          <property name="text">
 | 
					 | 
				
			||||||
           <string/>
 | 
					 | 
				
			||||||
          </property>
 | 
					 | 
				
			||||||
          <property name="icon">
 | 
					 | 
				
			||||||
           <iconset resource="../../../sdrbase/resources/res.qrc">
 | 
					 | 
				
			||||||
            <normaloff>:/lsb.png</normaloff>:/lsb.png</iconset>
 | 
					 | 
				
			||||||
          </property>
 | 
					 | 
				
			||||||
          <property name="checkable">
 | 
					 | 
				
			||||||
           <bool>true</bool>
 | 
					 | 
				
			||||||
          </property>
 | 
					 | 
				
			||||||
          <property name="autoRaise">
 | 
					 | 
				
			||||||
           <bool>true</bool>
 | 
					 | 
				
			||||||
          </property>
 | 
					 | 
				
			||||||
         </widget>
 | 
					 | 
				
			||||||
        </item>
 | 
					 | 
				
			||||||
        <item>
 | 
					        <item>
 | 
				
			||||||
         <widget class="ButtonSwitch" name="showPilot">
 | 
					         <widget class="ButtonSwitch" name="showPilot">
 | 
				
			||||||
          <property name="toolTip">
 | 
					          <property name="toolTip">
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
										
											Plik binarny nie jest wyświetlany.
										
									
								
							| 
		 Przed Szerokość: | Wysokość: | Rozmiar: 350 B  | 
| 
						 | 
					@ -48,6 +48,5 @@
 | 
				
			||||||
        <file>carrier.png</file>
 | 
					        <file>carrier.png</file>
 | 
				
			||||||
        <file>rds.png</file>
 | 
					        <file>rds.png</file>
 | 
				
			||||||
        <file>recycle.png</file>
 | 
					        <file>recycle.png</file>
 | 
				
			||||||
        <file>lsb.png</file>
 | 
					 | 
				
			||||||
    </qresource>
 | 
					    </qresource>
 | 
				
			||||||
</RCC>
 | 
					</RCC>
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Ładowanie…
	
		Reference in New Issue