mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-25 10:00:21 -04:00 
			
		
		
		
	ATV Modulator: implemented independent number of lines and FPS settings
This commit is contained in:
		
							parent
							
								
									cba85d2ef1
								
							
						
					
					
						commit
						f9f0c53168
					
				| @ -72,6 +72,8 @@ ATVMod::ATVMod() : | |||||||
|     m_config.m_rfBandwidth = 1000000; |     m_config.m_rfBandwidth = 1000000; | ||||||
|     m_config.m_atvModInput = ATVModInputHBars; |     m_config.m_atvModInput = ATVModInputHBars; | ||||||
|     m_config.m_atvStd = ATVStdPAL625; |     m_config.m_atvStd = ATVStdPAL625; | ||||||
|  |     m_config.m_nbLines = 625; | ||||||
|  |     m_config.m_fps = 25; | ||||||
| 
 | 
 | ||||||
|     m_SSBFilter = new fftfilt(0, m_config.m_rfBandwidth / m_config.m_outputSampleRate, m_ssbFftLen); |     m_SSBFilter = new fftfilt(0, m_config.m_rfBandwidth / m_config.m_outputSampleRate, m_ssbFftLen); | ||||||
|     m_SSBFilterBuffer = new Complex[m_ssbFftLen>>1]; // filter returns data exactly half of its size
 |     m_SSBFilterBuffer = new Complex[m_ssbFftLen>>1]; // filter returns data exactly half of its size
 | ||||||
| @ -101,6 +103,8 @@ void ATVMod::configure(MessageQueue* messageQueue, | |||||||
|             Real rfBandwidth, |             Real rfBandwidth, | ||||||
|             Real rfOppBandwidth, |             Real rfOppBandwidth, | ||||||
|             ATVStd atvStd, |             ATVStd atvStd, | ||||||
|  |             int nbLines, | ||||||
|  |             int fps, | ||||||
|             ATVModInput atvModInput, |             ATVModInput atvModInput, | ||||||
|             Real uniformLevel, |             Real uniformLevel, | ||||||
| 			ATVModulation atvModulation, | 			ATVModulation atvModulation, | ||||||
| @ -114,6 +118,8 @@ void ATVMod::configure(MessageQueue* messageQueue, | |||||||
|             rfBandwidth, |             rfBandwidth, | ||||||
|             rfOppBandwidth, |             rfOppBandwidth, | ||||||
|             atvStd, |             atvStd, | ||||||
|  |             nbLines, | ||||||
|  |             fps, | ||||||
|             atvModInput, |             atvModInput, | ||||||
|             uniformLevel, |             uniformLevel, | ||||||
|             atvModulation, |             atvModulation, | ||||||
| @ -520,6 +526,8 @@ bool ATVMod::handleMessage(const Message& cmd) | |||||||
|         m_config.m_rfOppBandwidth = cfg.getRFOppBandwidth(); |         m_config.m_rfOppBandwidth = cfg.getRFOppBandwidth(); | ||||||
|         m_config.m_atvModInput = cfg.getATVModInput(); |         m_config.m_atvModInput = cfg.getATVModInput(); | ||||||
|         m_config.m_atvStd = cfg.getATVStd(); |         m_config.m_atvStd = cfg.getATVStd(); | ||||||
|  |         m_config.m_nbLines = cfg.getNbLines(); | ||||||
|  |         m_config.m_fps = cfg.getFPS(); | ||||||
|         m_config.m_uniformLevel = cfg.getUniformLevel(); |         m_config.m_uniformLevel = cfg.getUniformLevel(); | ||||||
|         m_config.m_atvModulation = cfg.getModulation(); |         m_config.m_atvModulation = cfg.getModulation(); | ||||||
|         m_config.m_videoPlayLoop = cfg.getVideoPlayLoop(); |         m_config.m_videoPlayLoop = cfg.getVideoPlayLoop(); | ||||||
| @ -534,6 +542,8 @@ bool ATVMod::handleMessage(const Message& cmd) | |||||||
|                 << " m_rfBandwidth: " << m_config.m_rfBandwidth |                 << " m_rfBandwidth: " << m_config.m_rfBandwidth | ||||||
|                 << " m_rfOppBandwidth: " << m_config.m_rfOppBandwidth |                 << " m_rfOppBandwidth: " << m_config.m_rfOppBandwidth | ||||||
|                 << " m_atvStd: " << (int) m_config.m_atvStd |                 << " m_atvStd: " << (int) m_config.m_atvStd | ||||||
|  |                 << " m_nbLines: " << m_config.m_nbLines | ||||||
|  |                 << " m_fps: " << m_config.m_fps | ||||||
|                 << " m_atvModInput: " << (int) m_config.m_atvModInput |                 << " m_atvModInput: " << (int) m_config.m_atvModInput | ||||||
|                 << " m_uniformLevel: " << m_config.m_uniformLevel |                 << " m_uniformLevel: " << m_config.m_uniformLevel | ||||||
| 				<< " m_atvModulation: " << (int) m_config.m_atvModulation | 				<< " m_atvModulation: " << (int) m_config.m_atvModulation | ||||||
| @ -639,10 +649,13 @@ void ATVMod::apply(bool force) | |||||||
| { | { | ||||||
|     if ((m_config.m_outputSampleRate != m_running.m_outputSampleRate) |     if ((m_config.m_outputSampleRate != m_running.m_outputSampleRate) | ||||||
|         || (m_config.m_atvStd != m_running.m_atvStd) |         || (m_config.m_atvStd != m_running.m_atvStd) | ||||||
|  |         || (m_config.m_nbLines != m_running.m_nbLines) | ||||||
|  |         || (m_config.m_fps != m_running.m_fps) | ||||||
|         || (m_config.m_rfBandwidth != m_running.m_rfBandwidth) |         || (m_config.m_rfBandwidth != m_running.m_rfBandwidth) | ||||||
|         || (m_config.m_atvModulation != m_running.m_atvModulation) || force) |         || (m_config.m_atvModulation != m_running.m_atvModulation) || force) | ||||||
|     { |     { | ||||||
|         int rateUnits = getSampleRateUnits(m_config.m_atvStd); |         int rateUnits, nbPointsPerRateUnit; | ||||||
|  |         getBaseValues(m_config.m_nbLines * m_config.m_fps, rateUnits, nbPointsPerRateUnit); | ||||||
|         m_tvSampleRate = (m_config.m_outputSampleRate / rateUnits) * rateUnits; // make sure working sample rate is a multiple of rate units
 |         m_tvSampleRate = (m_config.m_outputSampleRate / rateUnits) * rateUnits; // make sure working sample rate is a multiple of rate units
 | ||||||
| 
 | 
 | ||||||
|         m_settingsMutex.lock(); |         m_settingsMutex.lock(); | ||||||
| @ -673,10 +686,12 @@ void ATVMod::apply(bool force) | |||||||
|         getOutputMessageQueue()->push(report); |         getOutputMessageQueue()->push(report); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if ((m_config.m_outputSampleRate != m_running.m_outputSampleRate) || |     if ((m_config.m_outputSampleRate != m_running.m_outputSampleRate) | ||||||
|         (m_config.m_rfOppBandwidth != m_running.m_rfOppBandwidth) || |         || (m_config.m_rfOppBandwidth != m_running.m_rfOppBandwidth) | ||||||
|         (m_config.m_rfBandwidth != m_running.m_rfBandwidth) || |         || (m_config.m_rfBandwidth != m_running.m_rfBandwidth) | ||||||
|         (m_config.m_atvStd != m_running.m_atvStd) || force) // difference in TV standard may have changed TV sample rate
 |         || (m_config.m_nbLines != m_running.m_nbLines) // difference in line period may have changed TV sample rate
 | ||||||
|  |         || (m_config.m_fps != m_running.m_fps)         //
 | ||||||
|  |         || force) | ||||||
|     { |     { | ||||||
|         m_settingsMutex.lock(); |         m_settingsMutex.lock(); | ||||||
| 
 | 
 | ||||||
| @ -701,6 +716,8 @@ void ATVMod::apply(bool force) | |||||||
|     m_running.m_rfOppBandwidth = m_config.m_rfOppBandwidth; |     m_running.m_rfOppBandwidth = m_config.m_rfOppBandwidth; | ||||||
|     m_running.m_atvModInput = m_config.m_atvModInput; |     m_running.m_atvModInput = m_config.m_atvModInput; | ||||||
|     m_running.m_atvStd = m_config.m_atvStd; |     m_running.m_atvStd = m_config.m_atvStd; | ||||||
|  |     m_running.m_nbLines = m_config.m_nbLines; | ||||||
|  |     m_running.m_fps = m_config.m_fps; | ||||||
|     m_running.m_uniformLevel = m_config.m_uniformLevel; |     m_running.m_uniformLevel = m_config.m_uniformLevel; | ||||||
|     m_running.m_atvModulation = m_config.m_atvModulation; |     m_running.m_atvModulation = m_config.m_atvModulation; | ||||||
|     m_running.m_videoPlayLoop = m_config.m_videoPlayLoop; |     m_running.m_videoPlayLoop = m_config.m_videoPlayLoop; | ||||||
| @ -710,23 +727,18 @@ void ATVMod::apply(bool force) | |||||||
|     m_running.m_invertedVideo = m_config.m_invertedVideo; |     m_running.m_invertedVideo = m_config.m_invertedVideo; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int ATVMod::getSampleRateUnits(ATVStd std) | void ATVMod::getBaseValues(int linesPerSecond, int& sampleRateUnits, int& nbPointsPerRateUnit) | ||||||
| { | { | ||||||
|     switch(std) |     int i = 0; | ||||||
|  | 
 | ||||||
|  |     for (; i < 100; i++) | ||||||
|     { |     { | ||||||
|     case ATVStd405: |         if (((100+i) * linesPerSecond) % 1000 == 0) | ||||||
|         return 729000;  // 72 * 10125
 |             break; | ||||||
|         break; |  | ||||||
|     case ATVStdPAL525: |  | ||||||
|     	return 1008000; // 64 * 15750
 |  | ||||||
|     	break; |  | ||||||
|     case ATVStd525L20F: |  | ||||||
|         return 735000;  // 70 * 10500
 |  | ||||||
|         break; |  | ||||||
|     case ATVStdPAL625: |  | ||||||
|     default: |  | ||||||
|         return 1000000; // 64 * 15625 Exact MS/s - us
 |  | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     nbPointsPerRateUnit = (i == 100) ? 100 : 100+i; | ||||||
|  |     sampleRateUnits = nbPointsPerRateUnit * linesPerSecond; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| float ATVMod::getRFBandwidthDivisor(ATVModulation modulation) | float ATVMod::getRFBandwidthDivisor(ATVModulation modulation) | ||||||
| @ -748,95 +760,51 @@ float ATVMod::getRFBandwidthDivisor(ATVModulation modulation) | |||||||
| 
 | 
 | ||||||
| void ATVMod::applyStandard() | void ATVMod::applyStandard() | ||||||
| { | { | ||||||
|     int rateUnits = getSampleRateUnits(m_config.m_atvStd); |     int rateUnits, nbPointsPerRateUnit; | ||||||
|  |     getBaseValues(m_config.m_nbLines * m_config.m_fps, rateUnits, nbPointsPerRateUnit); | ||||||
|     m_pointsPerTU = m_tvSampleRate / rateUnits; // TV sample rate is already set at a multiple of rate units
 |     m_pointsPerTU = m_tvSampleRate / rateUnits; // TV sample rate is already set at a multiple of rate units
 | ||||||
| 
 | 
 | ||||||
|  |     m_pointsPerSync    = (uint32_t) roundf(4.7f * m_pointsPerTU); // normal sync pulse (4.7 us / rateUnits)
 | ||||||
|  |     m_pointsPerBP      = (uint32_t) roundf(4.7f * m_pointsPerTU); // back porch        (4.7 us / rateUnits)
 | ||||||
|  |     m_pointsPerFP      = (uint32_t) roundf(1.5f * m_pointsPerTU); // front porch       (1.5 us / rateUnits)
 | ||||||
|  |     m_pointsPerFSync   = (uint32_t) roundf(2.3f * m_pointsPerTU); // equalizing pulse  (2.3 us / rateUnits)
 | ||||||
|  |     m_pointsPerImgLine = nbPointsPerRateUnit * m_pointsPerTU - m_pointsPerSync - m_pointsPerBP - m_pointsPerFP; | ||||||
|  |     m_nbHorizPoints    = nbPointsPerRateUnit * m_pointsPerTU; // full line
 | ||||||
|  |     m_pointsPerHBar    = m_pointsPerImgLine / m_nbBars; | ||||||
|  |     m_linesPerVBar     = m_nbImageLines2  / m_nbBars; | ||||||
|  |     m_hBarIncrement    = m_spanLevel / (float) m_nbBars; | ||||||
|  |     m_vBarIncrement    = m_spanLevel / (float) m_nbBars; | ||||||
|  | 
 | ||||||
|  |     m_nbLines          = m_config.m_nbLines; | ||||||
|  |     m_nbLines2         = (m_nbLines / 2) + 1; | ||||||
|  |     m_fps              = m_config.m_fps * 1.0f; | ||||||
|  | 
 | ||||||
|     switch(m_config.m_atvStd) |     switch(m_config.m_atvStd) | ||||||
|     { |     { | ||||||
|     case ATVStd405:    // Follows loosely the 405 lines standard
 |     case ATVStd405: // Follows loosely the 405 lines standard
 | ||||||
|         m_pointsPerSync    = (uint32_t) roundf(4.7f * m_pointsPerTU); // normal sync pulse (4.7/0.729 us)
 |         // what is left in a 64 us line for the image
 | ||||||
|         m_pointsPerBP      = (uint32_t) roundf(4.7f * m_pointsPerTU); // back porch        (4.7/0.729 us)
 |         m_nbImageLines     = m_nbLines - 15; // lines less the total number of sync lines
 | ||||||
|         m_pointsPerFP      = (uint32_t) roundf(1.5f * m_pointsPerTU); // front porch       (1.5/0.729 us)
 |         m_nbImageLines2    = m_nbImageLines / 2; | ||||||
|         m_pointsPerFSync   = (uint32_t) roundf(2.3f * m_pointsPerTU); // equalizing pulse  (2.3/0.729 us)
 |  | ||||||
|         // what is left in a 72/0.729 us line for the image
 |  | ||||||
|         m_pointsPerImgLine = 72 * m_pointsPerTU - m_pointsPerSync - m_pointsPerBP - m_pointsPerFP; |  | ||||||
|         m_nbLines          = 405; |  | ||||||
|         m_nbLines2         = 203; |  | ||||||
|         m_nbImageLines     = 390; |  | ||||||
|         m_nbImageLines2    = 195; |  | ||||||
|         m_interlaced       = true; |         m_interlaced       = true; | ||||||
|         m_nbHorizPoints    = 72 * m_pointsPerTU; // full line
 |         m_nbSyncLinesHead  = 5; // number of sync lines on the top of a frame
 | ||||||
|         m_nbSyncLinesHead  = 5; |  | ||||||
|         m_nbBlankLines     = 7; // yields 376 lines (195 - 7) * 2
 |         m_nbBlankLines     = 7; // yields 376 lines (195 - 7) * 2
 | ||||||
|         m_pointsPerHBar    = m_pointsPerImgLine / m_nbBars; |  | ||||||
|         m_linesPerVBar     = m_nbImageLines2  / m_nbBars; |  | ||||||
|         m_hBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_vBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_fps              = 25.0f; |  | ||||||
|         break; |         break; | ||||||
|     case ATVStdPAL525: // Follows PAL-M standard
 |     case ATVStdPAL525: // Follows PAL-M standard
 | ||||||
|         m_pointsPerSync    = (uint32_t) roundf(4.7f * m_pointsPerTU); // normal sync pulse (4.7/1.008 us)
 |  | ||||||
|         m_pointsPerBP      = (uint32_t) roundf(4.7f * m_pointsPerTU); // back porch        (4.7/1.008 us)
 |  | ||||||
|         m_pointsPerFP      = (uint32_t) roundf(1.5f * m_pointsPerTU); // front porch       (1.5/1.008 us)
 |  | ||||||
|         m_pointsPerFSync   = (uint32_t) roundf(2.3f * m_pointsPerTU); // equalizing pulse  (2.3/1.008 us)
 |  | ||||||
|         // what is left in a 64/1.008 us line for the image
 |         // what is left in a 64/1.008 us line for the image
 | ||||||
|         m_pointsPerImgLine = 64 * m_pointsPerTU - m_pointsPerSync - m_pointsPerBP - m_pointsPerFP; |         m_nbImageLines     = m_nbLines - 15; | ||||||
|         m_nbLines          = 525; |         m_nbImageLines2    = m_nbImageLines / 2; | ||||||
|         m_nbLines2         = 263; |  | ||||||
|         m_nbImageLines     = 510; |  | ||||||
|         m_nbImageLines2    = 255; |  | ||||||
|         m_interlaced       = true; |         m_interlaced       = true; | ||||||
|         m_nbHorizPoints    = 64 * m_pointsPerTU; // full line
 |  | ||||||
|         m_nbSyncLinesHead  = 5; |         m_nbSyncLinesHead  = 5; | ||||||
|         m_nbBlankLines     = 15; // yields 480 lines (255 - 15) * 2
 |         m_nbBlankLines     = 15; // yields 480 lines (255 - 15) * 2
 | ||||||
|         m_pointsPerHBar    = m_pointsPerImgLine / m_nbBars; |  | ||||||
|         m_linesPerVBar     = m_nbImageLines2  / m_nbBars; |  | ||||||
|         m_hBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_vBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_fps              = 30.0f; |  | ||||||
|         break; |  | ||||||
|     case ATVStd525L20F: // PAL M based 20 FPS
 |  | ||||||
|         m_pointsPerSync    = (uint32_t) roundf(4.7f * m_pointsPerTU); // normal sync pulse (4.7/0.735 us)
 |  | ||||||
|         m_pointsPerBP      = (uint32_t) roundf(4.7f * m_pointsPerTU); // back porch        (4.7/0.735 us)
 |  | ||||||
|         m_pointsPerFP      = (uint32_t) roundf(2.3f * m_pointsPerTU); // front porch       (2.3/0.735 us)
 |  | ||||||
|         m_pointsPerFSync   = (uint32_t) roundf(2.3f * m_pointsPerTU); // equalizing pulse  (2.3/0.735 us)
 |  | ||||||
|         // what is left in a 70/0.735 us line for the image
 |  | ||||||
|         m_pointsPerImgLine = 70 * m_pointsPerTU - m_pointsPerSync - m_pointsPerBP - m_pointsPerFP; |  | ||||||
|         m_nbLines          = 525; |  | ||||||
|         m_nbLines2         = 263; |  | ||||||
|         m_nbImageLines     = 510; |  | ||||||
|         m_nbImageLines2    = 255; |  | ||||||
|         m_interlaced       = true; |  | ||||||
|         m_nbHorizPoints    = 70 * m_pointsPerTU; // full line
 |  | ||||||
|         m_nbSyncLinesHead  = 5; |  | ||||||
|         m_nbBlankLines     = 15; // yields 480 lines (255 - 15) * 2
 |  | ||||||
|         m_pointsPerHBar    = m_pointsPerImgLine / m_nbBars; |  | ||||||
|         m_linesPerVBar     = m_nbImageLines2  / m_nbBars; |  | ||||||
|         m_hBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_vBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_fps              = 20.0f; |  | ||||||
|         break; |         break; | ||||||
|     case ATVStdPAL625: // Follows PAL-B/G/H standard
 |     case ATVStdPAL625: // Follows PAL-B/G/H standard
 | ||||||
|     default: |     default: | ||||||
|         m_pointsPerSync    = (uint32_t) roundf(4.7f * m_pointsPerTU); // normal sync pulse (4.7 us)
 |  | ||||||
|         m_pointsPerBP      = (uint32_t) roundf(4.7f * m_pointsPerTU); // back porch        (4.7 us)
 |  | ||||||
|         m_pointsPerFP      = (uint32_t) roundf(1.5f * m_pointsPerTU); // front porch       (1.5 us)
 |  | ||||||
|         m_pointsPerFSync   = (uint32_t) roundf(2.3f * m_pointsPerTU); // equalizing pulse  (2.3 us)
 |  | ||||||
|         // what is left in a 64 us line for the image
 |         // what is left in a 64 us line for the image
 | ||||||
|         m_pointsPerImgLine = 64 * m_pointsPerTU - m_pointsPerSync - m_pointsPerBP - m_pointsPerFP; |         m_nbImageLines     = m_nbLines - 15; | ||||||
|         m_nbLines          = 625; |         m_nbImageLines2    = m_nbImageLines / 2; | ||||||
|         m_nbLines2         = 313; |  | ||||||
|         m_nbImageLines     = 610; |  | ||||||
|         m_nbImageLines2    = 305; |  | ||||||
|         m_interlaced       = true; |         m_interlaced       = true; | ||||||
|         m_nbHorizPoints    = 64 * m_pointsPerTU; // full line
 |  | ||||||
|         m_nbSyncLinesHead  = 5; |         m_nbSyncLinesHead  = 5; | ||||||
|         m_nbBlankLines     = 17; // yields 576 lines (305 - 17) * 2
 |         m_nbBlankLines     = 17; // yields 576 lines (305 - 17) * 2
 | ||||||
|         m_pointsPerHBar    = m_pointsPerImgLine / m_nbBars; |  | ||||||
|         m_linesPerVBar     = m_nbImageLines2 / m_nbBars; |  | ||||||
|         m_hBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_vBarIncrement    = m_spanLevel / (float) m_nbBars; |  | ||||||
|         m_fps              = 25.0f; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (m_imageOK) |     if (m_imageOK) | ||||||
|  | |||||||
| @ -333,6 +333,8 @@ public: | |||||||
|             Real rfBandwidth, |             Real rfBandwidth, | ||||||
|             Real rfOppBandwidth, |             Real rfOppBandwidth, | ||||||
|             ATVStd atvStd, |             ATVStd atvStd, | ||||||
|  |             int nbLines, | ||||||
|  |             int fps, | ||||||
|             ATVModInput atvModInput, |             ATVModInput atvModInput, | ||||||
|             Real uniformLevel, |             Real uniformLevel, | ||||||
| 			ATVModulation atvModulation, | 			ATVModulation atvModulation, | ||||||
| @ -352,7 +354,7 @@ public: | |||||||
| 
 | 
 | ||||||
|     void getCameraNumbers(std::vector<int>& numbers); |     void getCameraNumbers(std::vector<int>& numbers); | ||||||
| 
 | 
 | ||||||
|     static int getSampleRateUnits(ATVStd std); |     static void getBaseValues(int linesPerSecond, int& sampleRateUnits, int& nbPointsPerRateUnit); | ||||||
|     static float getRFBandwidthDivisor(ATVModulation modulation); |     static float getRFBandwidthDivisor(ATVModulation modulation); | ||||||
| 
 | 
 | ||||||
| signals: | signals: | ||||||
| @ -374,6 +376,8 @@ private: | |||||||
|         Real getRFOppBandwidth() const { return m_rfOppBandwidth; } |         Real getRFOppBandwidth() const { return m_rfOppBandwidth; } | ||||||
|         ATVStd getATVStd() const { return m_atvStd; } |         ATVStd getATVStd() const { return m_atvStd; } | ||||||
|         ATVModInput getATVModInput() const { return m_atvModInput; } |         ATVModInput getATVModInput() const { return m_atvModInput; } | ||||||
|  |         int getNbLines() const { return m_nbLines; } | ||||||
|  |         int getFPS() const { return m_fps; } | ||||||
|         Real getUniformLevel() const { return m_uniformLevel; } |         Real getUniformLevel() const { return m_uniformLevel; } | ||||||
|         ATVModulation getModulation() const { return m_atvModulation; } |         ATVModulation getModulation() const { return m_atvModulation; } | ||||||
|         bool getVideoPlayLoop() const { return m_videoPlayLoop; } |         bool getVideoPlayLoop() const { return m_videoPlayLoop; } | ||||||
| @ -386,6 +390,8 @@ private: | |||||||
|             Real rfBandwidth, |             Real rfBandwidth, | ||||||
|             Real rfOppBandwidth, |             Real rfOppBandwidth, | ||||||
|             ATVStd atvStd, |             ATVStd atvStd, | ||||||
|  |             int nbLines, | ||||||
|  |             int fps, | ||||||
|             ATVModInput atvModInput, |             ATVModInput atvModInput, | ||||||
|             Real uniformLevel, |             Real uniformLevel, | ||||||
| 			ATVModulation atvModulation, | 			ATVModulation atvModulation, | ||||||
| @ -399,6 +405,8 @@ private: | |||||||
|                     rfBandwidth, |                     rfBandwidth, | ||||||
|                     rfOppBandwidth, |                     rfOppBandwidth, | ||||||
|                     atvStd, |                     atvStd, | ||||||
|  |                     nbLines, | ||||||
|  |                     fps, | ||||||
|                     atvModInput, |                     atvModInput, | ||||||
|                     uniformLevel, |                     uniformLevel, | ||||||
|                     atvModulation, |                     atvModulation, | ||||||
| @ -413,6 +421,8 @@ private: | |||||||
|         Real          m_rfBandwidth; |         Real          m_rfBandwidth; | ||||||
|         Real          m_rfOppBandwidth; |         Real          m_rfOppBandwidth; | ||||||
|         ATVStd        m_atvStd; |         ATVStd        m_atvStd; | ||||||
|  |         int           m_nbLines; | ||||||
|  |         int           m_fps; | ||||||
|         ATVModInput   m_atvModInput; |         ATVModInput   m_atvModInput; | ||||||
|         Real          m_uniformLevel; |         Real          m_uniformLevel; | ||||||
|         ATVModulation m_atvModulation; |         ATVModulation m_atvModulation; | ||||||
| @ -426,6 +436,8 @@ private: | |||||||
|                 Real rfBandwidth, |                 Real rfBandwidth, | ||||||
|                 Real rfOppBandwidth, |                 Real rfOppBandwidth, | ||||||
|                 ATVStd atvStd, |                 ATVStd atvStd, | ||||||
|  |                 int nbLines, | ||||||
|  |                 int fps, | ||||||
|                 ATVModInput atvModInput, |                 ATVModInput atvModInput, | ||||||
|                 Real uniformLevel, |                 Real uniformLevel, | ||||||
| 				ATVModulation atvModulation, | 				ATVModulation atvModulation, | ||||||
| @ -438,6 +450,8 @@ private: | |||||||
|             m_rfBandwidth(rfBandwidth), |             m_rfBandwidth(rfBandwidth), | ||||||
|             m_rfOppBandwidth(rfOppBandwidth), |             m_rfOppBandwidth(rfOppBandwidth), | ||||||
|             m_atvStd(atvStd), |             m_atvStd(atvStd), | ||||||
|  |             m_nbLines(nbLines), | ||||||
|  |             m_fps(fps), | ||||||
|             m_atvModInput(atvModInput), |             m_atvModInput(atvModInput), | ||||||
|             m_uniformLevel(uniformLevel), |             m_uniformLevel(uniformLevel), | ||||||
| 			m_atvModulation(atvModulation), | 			m_atvModulation(atvModulation), | ||||||
| @ -484,6 +498,8 @@ private: | |||||||
|         Real          m_rfBandwidth;          //!< Bandwidth of modulated signal or direct sideband for SSB / vestigial SSB
 |         Real          m_rfBandwidth;          //!< Bandwidth of modulated signal or direct sideband for SSB / vestigial SSB
 | ||||||
|         Real          m_rfOppBandwidth;       //!< Bandwidth of opposite sideband for vestigial SSB
 |         Real          m_rfOppBandwidth;       //!< Bandwidth of opposite sideband for vestigial SSB
 | ||||||
|         ATVStd        m_atvStd;               //!< Standard
 |         ATVStd        m_atvStd;               //!< Standard
 | ||||||
|  |         int           m_nbLines;              //!< Number of lines per full frame
 | ||||||
|  |         int           m_fps;                  //!< Number of frames per second
 | ||||||
|         ATVModInput   m_atvModInput;          //!< Input source type
 |         ATVModInput   m_atvModInput;          //!< Input source type
 | ||||||
|         Real          m_uniformLevel;         //!< Percentage between black and white for uniform screen display
 |         Real          m_uniformLevel;         //!< Percentage between black and white for uniform screen display
 | ||||||
|         ATVModulation m_atvModulation;        //!< RF modulation type
 |         ATVModulation m_atvModulation;        //!< RF modulation type
 | ||||||
| @ -499,6 +515,8 @@ private: | |||||||
|             m_rfBandwidth(0), |             m_rfBandwidth(0), | ||||||
|             m_rfOppBandwidth(0), |             m_rfOppBandwidth(0), | ||||||
|             m_atvStd(ATVStdPAL625), |             m_atvStd(ATVStdPAL625), | ||||||
|  |             m_nbLines(625), | ||||||
|  |             m_fps(25), | ||||||
|             m_atvModInput(ATVModInputHBars), |             m_atvModInput(ATVModInputHBars), | ||||||
|             m_uniformLevel(0.5f), |             m_uniformLevel(0.5f), | ||||||
| 			m_atvModulation(ATVModulationAM), | 			m_atvModulation(ATVModulationAM), | ||||||
|  | |||||||
| @ -241,6 +241,44 @@ void ATVModGUI::setRFFiltersSlidersRange(int sampleRate) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | int ATVModGUI::getNbLines() | ||||||
|  | { | ||||||
|  |     switch(ui->nbLines->currentIndex()) | ||||||
|  |     { | ||||||
|  |     case 1: | ||||||
|  |         return 525; | ||||||
|  |         break; | ||||||
|  |     case 2: | ||||||
|  |         return 405; | ||||||
|  |         break; | ||||||
|  |     case 0: | ||||||
|  |     default: | ||||||
|  |         return 625; | ||||||
|  |         break; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int ATVModGUI::getFPS() | ||||||
|  | { | ||||||
|  |     switch(ui->fps->currentIndex()) | ||||||
|  |     { | ||||||
|  |     case 0: | ||||||
|  |         return 30; | ||||||
|  |         break; | ||||||
|  |     case 2: | ||||||
|  |         return 20; | ||||||
|  |         break; | ||||||
|  |     case 3: | ||||||
|  |         return 16; | ||||||
|  |         break; | ||||||
|  |     case 1: | ||||||
|  |     default: | ||||||
|  |         return 25; | ||||||
|  |         break; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void ATVModGUI::handleSourceMessages() | void ATVModGUI::handleSourceMessages() | ||||||
| { | { | ||||||
|     Message* message; |     Message* message; | ||||||
| @ -365,6 +403,17 @@ void ATVModGUI::on_rfOppBW_valueChanged(int value) | |||||||
|     applySettings(); |     applySettings(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void ATVModGUI::on_nbLines_currentIndexChanged(int index) | ||||||
|  | { | ||||||
|  |     applySettings(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ATVModGUI::on_fps_currentIndexChanged(int index) | ||||||
|  | { | ||||||
|  |     applySettings(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| void ATVModGUI::on_standard_currentIndexChanged(int index) | void ATVModGUI::on_standard_currentIndexChanged(int index) | ||||||
| { | { | ||||||
|     applySettings(); |     applySettings(); | ||||||
| @ -580,6 +629,8 @@ void ATVModGUI::applySettings() | |||||||
| 			ui->rfBW->value() * m_rfSliderDivisor * 1.0f, | 			ui->rfBW->value() * m_rfSliderDivisor * 1.0f, | ||||||
| 			ui->rfOppBW->value() * m_rfSliderDivisor * 1.0f, | 			ui->rfOppBW->value() * m_rfSliderDivisor * 1.0f, | ||||||
| 			(ATVMod::ATVStd) ui->standard->currentIndex(), | 			(ATVMod::ATVStd) ui->standard->currentIndex(), | ||||||
|  | 			getNbLines(), | ||||||
|  | 			getFPS(), | ||||||
| 			(ATVMod::ATVModInput) ui->inputSelect->currentIndex(), | 			(ATVMod::ATVModInput) ui->inputSelect->currentIndex(), | ||||||
| 			ui->uniformLevel->value() / 100.0f, | 			ui->uniformLevel->value() / 100.0f, | ||||||
| 			(ATVMod::ATVModulation) ui->modulation->currentIndex(), | 			(ATVMod::ATVModulation) ui->modulation->currentIndex(), | ||||||
|  | |||||||
| @ -66,6 +66,8 @@ private slots: | |||||||
|     void on_modulation_currentIndexChanged(int index); |     void on_modulation_currentIndexChanged(int index); | ||||||
|     void on_rfBW_valueChanged(int value); |     void on_rfBW_valueChanged(int value); | ||||||
|     void on_rfOppBW_valueChanged(int value); |     void on_rfOppBW_valueChanged(int value); | ||||||
|  |     void on_nbLines_currentIndexChanged(int index); | ||||||
|  |     void on_fps_currentIndexChanged(int index); | ||||||
|     void on_standard_currentIndexChanged(int index); |     void on_standard_currentIndexChanged(int index); | ||||||
|     void on_invertVideo_clicked(); |     void on_invertVideo_clicked(); | ||||||
|     void on_uniformLevel_valueChanged(int value); |     void on_uniformLevel_valueChanged(int value); | ||||||
| @ -121,6 +123,8 @@ private: | |||||||
|     void updateWithStreamData(); |     void updateWithStreamData(); | ||||||
|     void updateWithStreamTime(); |     void updateWithStreamTime(); | ||||||
|     void setRFFiltersSlidersRange(int sampleRate); |     void setRFFiltersSlidersRange(int sampleRate); | ||||||
|  |     int getNbLines(); | ||||||
|  |     int getFPS(); | ||||||
| 
 | 
 | ||||||
|     void leaveEvent(QEvent*); |     void leaveEvent(QEvent*); | ||||||
|     void enterEvent(QEvent*); |     void enterEvent(QEvent*); | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
|    <rect> |    <rect> | ||||||
|     <x>0</x> |     <x>0</x> | ||||||
|     <y>0</y> |     <y>0</y> | ||||||
|     <width>490</width> |     <width>619</width> | ||||||
|     <height>364</height> |     <height>364</height> | ||||||
|    </rect> |    </rect> | ||||||
|   </property> |   </property> | ||||||
| @ -39,7 +39,7 @@ | |||||||
|     <rect> |     <rect> | ||||||
|      <x>0</x> |      <x>0</x> | ||||||
|      <y>10</y> |      <y>10</y> | ||||||
|      <width>480</width> |      <width>611</width> | ||||||
|      <height>341</height> |      <height>341</height> | ||||||
|     </rect> |     </rect> | ||||||
|    </property> |    </property> | ||||||
| @ -391,23 +391,106 @@ | |||||||
|     <item> |     <item> | ||||||
|      <layout class="QHBoxLayout" name="recordFileSelectLayout"> |      <layout class="QHBoxLayout" name="recordFileSelectLayout"> | ||||||
|       <item> |       <item> | ||||||
|        <widget class="QComboBox" name="standard"> |        <widget class="QLabel" name="nbLinesLabel"> | ||||||
|  |         <property name="text"> | ||||||
|  |          <string>L:</string> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QComboBox" name="nbLines"> | ||||||
|  |         <property name="maximumSize"> | ||||||
|  |          <size> | ||||||
|  |           <width>50</width> | ||||||
|  |           <height>16777215</height> | ||||||
|  |          </size> | ||||||
|  |         </property> | ||||||
|         <property name="toolTip"> |         <property name="toolTip"> | ||||||
|          <string>TV standard</string> |          <string>Lines per full frame</string> | ||||||
|         </property> |         </property> | ||||||
|         <item> |         <item> | ||||||
|          <property name="text"> |          <property name="text"> | ||||||
|           <string>PAL625L</string> |           <string>625</string> | ||||||
|          </property> |          </property> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <property name="text"> |          <property name="text"> | ||||||
|           <string>PAL525L</string> |           <string>525</string> | ||||||
|          </property> |          </property> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <property name="text"> |          <property name="text"> | ||||||
|           <string>525L20F</string> |           <string>405</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QLabel" name="fpsLabel"> | ||||||
|  |         <property name="text"> | ||||||
|  |          <string>F:</string> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QComboBox" name="fps"> | ||||||
|  |         <property name="maximumSize"> | ||||||
|  |          <size> | ||||||
|  |           <width>45</width> | ||||||
|  |           <height>16777215</height> | ||||||
|  |          </size> | ||||||
|  |         </property> | ||||||
|  |         <property name="toolTip"> | ||||||
|  |          <string>Frames per second</string> | ||||||
|  |         </property> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>30</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>25</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>20</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>16</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QLabel" name="standardLabel"> | ||||||
|  |         <property name="text"> | ||||||
|  |          <string>S:</string> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QComboBox" name="standard"> | ||||||
|  |         <property name="maximumSize"> | ||||||
|  |          <size> | ||||||
|  |           <width>70</width> | ||||||
|  |           <height>16777215</height> | ||||||
|  |          </size> | ||||||
|  |         </property> | ||||||
|  |         <property name="toolTip"> | ||||||
|  |          <string>TV standard scheme</string> | ||||||
|  |         </property> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>PAL625</string> | ||||||
|  |          </property> | ||||||
|  |         </item> | ||||||
|  |         <item> | ||||||
|  |          <property name="text"> | ||||||
|  |           <string>PAL525</string> | ||||||
|          </property> |          </property> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
| @ -417,6 +500,13 @@ | |||||||
|         </item> |         </item> | ||||||
|        </widget> |        </widget> | ||||||
|       </item> |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="Line" name="line_8"> | ||||||
|  |         <property name="orientation"> | ||||||
|  |          <enum>Qt::Vertical</enum> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|       <item> |       <item> | ||||||
|        <widget class="QComboBox" name="inputSelect"> |        <widget class="QComboBox" name="inputSelect"> | ||||||
|         <property name="toolTip"> |         <property name="toolTip"> | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user