Mercurial > hg > svgui
comparison layer/SpectrogramLayer.cpp @ 1417:2487521e857b
Merge
author | Chris Cannam |
---|---|
date | Wed, 23 Jan 2019 14:44:16 +0000 |
parents | c8a6fd3f9dff |
children | 8e40faa56ffd |
comparison
equal
deleted
inserted
replaced
1416:d794630429a7 | 1417:2487521e857b |
---|---|
54 //#define DEBUG_SPECTROGRAM_REPAINT 1 | 54 //#define DEBUG_SPECTROGRAM_REPAINT 1 |
55 | 55 |
56 using namespace std; | 56 using namespace std; |
57 | 57 |
58 SpectrogramLayer::SpectrogramLayer(Configuration config) : | 58 SpectrogramLayer::SpectrogramLayer(Configuration config) : |
59 m_model(0), | 59 m_model(nullptr), |
60 m_channel(0), | 60 m_channel(0), |
61 m_windowSize(1024), | 61 m_windowSize(1024), |
62 m_windowType(HanningWindow), | 62 m_windowType(HanningWindow), |
63 m_windowHopLevel(2), | 63 m_windowHopLevel(2), |
64 m_oversampling(1), | 64 m_oversampling(1), |
81 m_normalizeVisibleArea(false), | 81 m_normalizeVisibleArea(false), |
82 m_lastEmittedZoomStep(-1), | 82 m_lastEmittedZoomStep(-1), |
83 m_synchronous(false), | 83 m_synchronous(false), |
84 m_haveDetailedScale(false), | 84 m_haveDetailedScale(false), |
85 m_exiting(false), | 85 m_exiting(false), |
86 m_fftModel(0), | 86 m_fftModel(nullptr), |
87 m_wholeCache(0), | 87 m_wholeCache(nullptr), |
88 m_peakCache(0), | 88 m_peakCache(nullptr), |
89 m_peakCacheDivisor(8) | 89 m_peakCacheDivisor(8) |
90 { | 90 { |
91 QString colourConfigName = "spectrogram-colour"; | 91 QString colourConfigName = "spectrogram-colour"; |
92 int colourConfigDefault = int(ColourMapper::Green); | 92 int colourConfigDefault = int(ColourMapper::Green); |
93 | 93 |
146 | 146 |
147 delete m_fftModel; | 147 delete m_fftModel; |
148 delete m_peakCache; | 148 delete m_peakCache; |
149 delete m_wholeCache; | 149 delete m_wholeCache; |
150 | 150 |
151 m_fftModel = 0; | 151 m_fftModel = nullptr; |
152 m_peakCache = 0; | 152 m_peakCache = nullptr; |
153 m_wholeCache = 0; | 153 m_wholeCache = nullptr; |
154 } | 154 } |
155 | 155 |
156 pair<ColourScaleType, double> | 156 pair<ColourScaleType, double> |
157 SpectrogramLayer::convertToColourScale(int value) | 157 SpectrogramLayer::convertToColourScale(int value) |
158 { | 158 { |
580 } | 580 } |
581 if (name == "Threshold") { | 581 if (name == "Threshold") { |
582 return new LinearRangeMapper(-81, -1, -81, -1, tr("dB"), false, | 582 return new LinearRangeMapper(-81, -1, -81, -1, tr("dB"), false, |
583 { { -81, Strings::minus_infinity } }); | 583 { { -81, Strings::minus_infinity } }); |
584 } | 584 } |
585 return 0; | 585 return nullptr; |
586 } | 586 } |
587 | 587 |
588 void | 588 void |
589 SpectrogramLayer::setProperty(const PropertyName &name, int value) | 589 SpectrogramLayer::setProperty(const PropertyName &name, int value) |
590 { | 590 { |
1370 SpectrogramLayer::recreateFFTModel() | 1370 SpectrogramLayer::recreateFFTModel() |
1371 { | 1371 { |
1372 SVDEBUG << "SpectrogramLayer::recreateFFTModel called" << endl; | 1372 SVDEBUG << "SpectrogramLayer::recreateFFTModel called" << endl; |
1373 | 1373 |
1374 if (!m_model || !m_model->isOK()) { | 1374 if (!m_model || !m_model->isOK()) { |
1375 emit sliceableModelReplaced(m_fftModel, 0); | 1375 emit sliceableModelReplaced(m_fftModel, nullptr); |
1376 deleteDerivedModels(); | 1376 deleteDerivedModels(); |
1377 return; | 1377 return; |
1378 } | 1378 } |
1379 | 1379 |
1380 if (m_fftModel) m_fftModel->aboutToDelete(); | 1380 if (m_fftModel) m_fftModel->aboutToDelete(); |
1381 | 1381 |
1382 if (m_peakCache) m_peakCache->aboutToDelete(); | 1382 if (m_peakCache) m_peakCache->aboutToDelete(); |
1383 delete m_peakCache; | 1383 delete m_peakCache; |
1384 m_peakCache = 0; | 1384 m_peakCache = nullptr; |
1385 | 1385 |
1386 if (m_wholeCache) m_wholeCache->aboutToDelete(); | 1386 if (m_wholeCache) m_wholeCache->aboutToDelete(); |
1387 delete m_wholeCache; | 1387 delete m_wholeCache; |
1388 m_wholeCache = 0; | 1388 m_wholeCache = nullptr; |
1389 | 1389 |
1390 FFTModel *newModel = new FFTModel(m_model, | 1390 FFTModel *newModel = new FFTModel(m_model, |
1391 m_channel, | 1391 m_channel, |
1392 m_windowType, | 1392 m_windowType, |
1393 m_windowSize, | 1393 m_windowSize, |
1394 getWindowIncrement(), | 1394 getWindowIncrement(), |
1395 getFFTSize()); | 1395 getFFTSize()); |
1396 | 1396 |
1397 if (!newModel->isOK()) { | 1397 if (!newModel->isOK()) { |
1398 QMessageBox::critical | 1398 QMessageBox::critical |
1399 (0, tr("FFT cache failed"), | 1399 (nullptr, tr("FFT cache failed"), |
1400 tr("Failed to create the FFT model for this spectrogram.\n" | 1400 tr("Failed to create the FFT model for this spectrogram.\n" |
1401 "There may be insufficient memory or disc space to continue.")); | 1401 "There may be insufficient memory or disc space to continue.")); |
1402 delete newModel; | 1402 delete newModel; |
1403 delete m_fftModel; | 1403 delete m_fftModel; |
1404 m_fftModel = 0; | 1404 m_fftModel = nullptr; |
1405 return; | 1405 return; |
1406 } | 1406 } |
1407 | 1407 |
1408 FFTModel *oldModel = m_fftModel; | 1408 FFTModel *oldModel = m_fftModel; |
1409 m_fftModel = newModel; | 1409 m_fftModel = newModel; |
2312 { | 2312 { |
2313 public: | 2313 public: |
2314 SpectrogramRangeMapper(sv_samplerate_t sr, int /* fftsize */) : | 2314 SpectrogramRangeMapper(sv_samplerate_t sr, int /* fftsize */) : |
2315 m_dist(sr / 2), | 2315 m_dist(sr / 2), |
2316 m_s2(sqrt(sqrt(2))) { } | 2316 m_s2(sqrt(sqrt(2))) { } |
2317 ~SpectrogramRangeMapper() { } | 2317 ~SpectrogramRangeMapper() override { } |
2318 | 2318 |
2319 virtual int getPositionForValue(double value) const { | 2319 int getPositionForValue(double value) const override { |
2320 | 2320 |
2321 double dist = m_dist; | 2321 double dist = m_dist; |
2322 | 2322 |
2323 int n = 0; | 2323 int n = 0; |
2324 | 2324 |
2328 } | 2328 } |
2329 | 2329 |
2330 return n; | 2330 return n; |
2331 } | 2331 } |
2332 | 2332 |
2333 virtual int getPositionForValueUnclamped(double value) const { | 2333 int getPositionForValueUnclamped(double value) const override { |
2334 // We don't really support this | 2334 // We don't really support this |
2335 return getPositionForValue(value); | 2335 return getPositionForValue(value); |
2336 } | 2336 } |
2337 | 2337 |
2338 virtual double getValueForPosition(int position) const { | 2338 double getValueForPosition(int position) const override { |
2339 | 2339 |
2340 // Vertical zoom step 0 shows the entire range from DC -> | 2340 // Vertical zoom step 0 shows the entire range from DC -> |
2341 // Nyquist frequency. Step 1 shows 2^(1/4) of the range of | 2341 // Nyquist frequency. Step 1 shows 2^(1/4) of the range of |
2342 // step 0, and so on until the visible range is smaller than | 2342 // step 0, and so on until the visible range is smaller than |
2343 // the frequency step between bins at the current fft size. | 2343 // the frequency step between bins at the current fft size. |
2351 } | 2351 } |
2352 | 2352 |
2353 return dist; | 2353 return dist; |
2354 } | 2354 } |
2355 | 2355 |
2356 virtual double getValueForPositionUnclamped(int position) const { | 2356 double getValueForPositionUnclamped(int position) const override { |
2357 // We don't really support this | 2357 // We don't really support this |
2358 return getValueForPosition(position); | 2358 return getValueForPosition(position); |
2359 } | 2359 } |
2360 | 2360 |
2361 virtual QString getUnit() const { return "Hz"; } | 2361 QString getUnit() const override { return "Hz"; } |
2362 | 2362 |
2363 protected: | 2363 protected: |
2364 double m_dist; | 2364 double m_dist; |
2365 double m_s2; | 2365 double m_s2; |
2366 }; | 2366 }; |
2471 } | 2471 } |
2472 | 2472 |
2473 RangeMapper * | 2473 RangeMapper * |
2474 SpectrogramLayer::getNewVerticalZoomRangeMapper() const | 2474 SpectrogramLayer::getNewVerticalZoomRangeMapper() const |
2475 { | 2475 { |
2476 if (!m_model) return 0; | 2476 if (!m_model) return nullptr; |
2477 return new SpectrogramRangeMapper(m_model->getSampleRate(), getFFTSize()); | 2477 return new SpectrogramRangeMapper(m_model->getSampleRate(), getFFTSize()); |
2478 } | 2478 } |
2479 | 2479 |
2480 void | 2480 void |
2481 SpectrogramLayer::updateMeasureRectYCoords(LayerGeometryProvider *v, const MeasureRect &r) const | 2481 SpectrogramLayer::updateMeasureRectYCoords(LayerGeometryProvider *v, const MeasureRect &r) const |