comparison layer/SpectrogramLayer.h @ 918:4fe7a09be0fe osx-retina

Many fixes for the previous stuff
author Chris Cannam
date Tue, 17 Mar 2015 16:56:03 +0000
parents 94e4952a6774
children e39d5d2734ed
comparison
equal deleted inserted replaced
917:77a1d42353ce 918:4fe7a09be0fe
58 virtual const ZoomConstraint *getZoomConstraint() const { return this; } 58 virtual const ZoomConstraint *getZoomConstraint() const { return this; }
59 virtual const Model *getModel() const { return m_model; } 59 virtual const Model *getModel() const { return m_model; }
60 virtual void paint(LayerGeometryProvider *v, QPainter &paint, QRect rect) const; 60 virtual void paint(LayerGeometryProvider *v, QPainter &paint, QRect rect) const;
61 virtual void setSynchronousPainting(bool synchronous); 61 virtual void setSynchronousPainting(bool synchronous);
62 62
63 virtual int getVerticalScaleWidth(View *v, bool detailed, QPainter &) const; 63 virtual int getVerticalScaleWidth(LayerGeometryProvider *v, bool detailed, QPainter &) const;
64 virtual void paintVerticalScale(View *v, bool detailed, QPainter &paint, QRect rect) const; 64 virtual void paintVerticalScale(LayerGeometryProvider *v, bool detailed, QPainter &paint, QRect rect) const;
65 65
66 virtual bool getCrosshairExtents(View *, QPainter &, QPoint cursorPos, 66 virtual bool getCrosshairExtents(LayerGeometryProvider *, QPainter &, QPoint cursorPos,
67 std::vector<QRect> &extents) const; 67 std::vector<QRect> &extents) const;
68 virtual void paintCrosshairs(View *, QPainter &, QPoint) const; 68 virtual void paintCrosshairs(LayerGeometryProvider *, QPainter &, QPoint) const;
69 69
70 virtual QString getFeatureDescription(View *v, QPoint &) const; 70 virtual QString getFeatureDescription(LayerGeometryProvider *v, QPoint &) const;
71 71
72 virtual bool snapToFeatureFrame(View *v, sv_frame_t &frame, 72 virtual bool snapToFeatureFrame(LayerGeometryProvider *v, sv_frame_t &frame,
73 int &resolution, 73 int &resolution,
74 SnapType snap) const; 74 SnapType snap) const;
75 75
76 virtual void measureDoubleClick(View *, QMouseEvent *); 76 virtual void measureDoubleClick(LayerGeometryProvider *, QMouseEvent *);
77 77
78 virtual bool hasLightBackground() const; 78 virtual bool hasLightBackground() const;
79 79
80 void setModel(const DenseTimeValueModel *model); 80 void setModel(const DenseTimeValueModel *model);
81 81
208 208
209 virtual ColourSignificance getLayerColourSignificance() const { 209 virtual ColourSignificance getLayerColourSignificance() const {
210 return ColourHasMeaningfulValue; 210 return ColourHasMeaningfulValue;
211 } 211 }
212 212
213 double getYForFrequency(const View *v, double frequency) const; 213 double getYForFrequency(const LayerGeometryProvider *v, double frequency) const;
214 double getFrequencyForY(const View *v, int y) const; 214 double getFrequencyForY(const LayerGeometryProvider *v, int y) const;
215 215
216 virtual int getCompletion(View *v) const; 216 virtual int getCompletion(LayerGeometryProvider *v) const;
217 virtual QString getError(View *v) const; 217 virtual QString getError(LayerGeometryProvider *v) const;
218 218
219 virtual bool getValueExtents(double &min, double &max, 219 virtual bool getValueExtents(double &min, double &max,
220 bool &logarithmic, QString &unit) const; 220 bool &logarithmic, QString &unit) const;
221 221
222 virtual bool getDisplayExtents(double &min, double &max) const; 222 virtual bool getDisplayExtents(double &min, double &max) const;
223 223
224 virtual bool setDisplayExtents(double min, double max); 224 virtual bool setDisplayExtents(double min, double max);
225 225
226 virtual bool getYScaleValue(const View *, int, double &, QString &) const; 226 virtual bool getYScaleValue(const LayerGeometryProvider *, int, double &, QString &) const;
227 227
228 virtual void toXml(QTextStream &stream, QString indent = "", 228 virtual void toXml(QTextStream &stream, QString indent = "",
229 QString extraAttributes = "") const; 229 QString extraAttributes = "") const;
230 230
231 void setProperties(const QXmlAttributes &attributes); 231 void setProperties(const QXmlAttributes &attributes);
232 232
233 virtual void setLayerDormant(const View *v, bool dormant); 233 virtual void setLayerDormant(const LayerGeometryProvider *v, bool dormant);
234 234
235 virtual bool isLayerScrollable(const View *) const { return false; } 235 virtual bool isLayerScrollable(const LayerGeometryProvider *) const { return false; }
236 236
237 virtual int getVerticalZoomSteps(int &defaultStep) const; 237 virtual int getVerticalZoomSteps(int &defaultStep) const;
238 virtual int getCurrentVerticalZoomStep() const; 238 virtual int getCurrentVerticalZoomStep() const;
239 virtual void setVerticalZoomStep(int); 239 virtual void setVerticalZoomStep(int);
240 virtual RangeMapper *getNewVerticalZoomRangeMapper() const; 240 virtual RangeMapper *getNewVerticalZoomRangeMapper() const;
311 QImage image; 311 QImage image;
312 QRect validArea; 312 QRect validArea;
313 sv_frame_t startFrame; 313 sv_frame_t startFrame;
314 int zoomLevel; 314 int zoomLevel;
315 }; 315 };
316 typedef std::map<const View *, ImageCache> ViewImageCache; 316 typedef std::map<const LayerGeometryProvider *, ImageCache> ViewImageCache;
317 void invalidateImageCaches(); 317 void invalidateImageCaches();
318 void invalidateImageCaches(sv_frame_t startFrame, sv_frame_t endFrame); 318 void invalidateImageCaches(sv_frame_t startFrame, sv_frame_t endFrame);
319 mutable ViewImageCache m_imageCaches; 319 mutable ViewImageCache m_imageCaches;
320 320
321 /** 321 /**
332 bool m_exiting; 332 bool m_exiting;
333 333
334 void initialisePalette(); 334 void initialisePalette();
335 void rotatePalette(int distance); 335 void rotatePalette(int distance);
336 336
337 unsigned char getDisplayValue(View *v, double input) const; 337 unsigned char getDisplayValue(LayerGeometryProvider *v, double input) const;
338 338
339 int getColourScaleWidth(QPainter &) const; 339 int getColourScaleWidth(QPainter &) const;
340 340
341 void illuminateLocalFeatures(View *v, QPainter &painter) const; 341 void illuminateLocalFeatures(LayerGeometryProvider *v, QPainter &painter) const;
342 342
343 double getEffectiveMinFrequency() const; 343 double getEffectiveMinFrequency() const;
344 double getEffectiveMaxFrequency() const; 344 double getEffectiveMaxFrequency() const;
345 345
346 // Note that the getYBin... methods return the nominal bin in the 346 // Note that the getYBin... methods return the nominal bin in the
347 // un-smoothed spectrogram. This is not necessarily the same bin 347 // un-smoothed spectrogram. This is not necessarily the same bin
348 // as is pulled from the spectrogram and drawn at the given 348 // as is pulled from the spectrogram and drawn at the given
349 // position, if the spectrogram has oversampling smoothing. Use 349 // position, if the spectrogram has oversampling smoothing. Use
350 // getSmoothedYBinRange to obtain that. 350 // getSmoothedYBinRange to obtain that.
351 351
352 bool getXBinRange(View *v, int x, double &windowMin, double &windowMax) const; 352 bool getXBinRange(LayerGeometryProvider *v, int x, double &windowMin, double &windowMax) const;
353 bool getYBinRange(View *v, int y, double &freqBinMin, double &freqBinMax) const; 353 bool getYBinRange(LayerGeometryProvider *v, int y, double &freqBinMin, double &freqBinMax) const;
354 bool getSmoothedYBinRange(View *v, int y, double &freqBinMin, double &freqBinMax) const; 354 bool getSmoothedYBinRange(LayerGeometryProvider *v, int y, double &freqBinMin, double &freqBinMax) const;
355 355
356 bool getYBinSourceRange(View *v, int y, double &freqMin, double &freqMax) const; 356 bool getYBinSourceRange(LayerGeometryProvider *v, int y, double &freqMin, double &freqMax) const;
357 bool getAdjustedYBinSourceRange(View *v, int x, int y, 357 bool getAdjustedYBinSourceRange(LayerGeometryProvider *v, int x, int y,
358 double &freqMin, double &freqMax, 358 double &freqMin, double &freqMax,
359 double &adjFreqMin, double &adjFreqMax) const; 359 double &adjFreqMin, double &adjFreqMax) const;
360 bool getXBinSourceRange(View *v, int x, RealTime &timeMin, RealTime &timeMax) const; 360 bool getXBinSourceRange(LayerGeometryProvider *v, int x, RealTime &timeMin, RealTime &timeMax) const;
361 bool getXYBinSourceRange(View *v, int x, int y, double &min, double &max, 361 bool getXYBinSourceRange(LayerGeometryProvider *v, int x, int y, double &min, double &max,
362 double &phaseMin, double &phaseMax) const; 362 double &phaseMin, double &phaseMax) const;
363 363
364 int getWindowIncrement() const { 364 int getWindowIncrement() const {
365 if (m_windowHopLevel == 0) return m_windowSize; 365 if (m_windowHopLevel == 0) return m_windowSize;
366 else if (m_windowHopLevel == 1) return (m_windowSize * 3) / 4; 366 else if (m_windowHopLevel == 1) return (m_windowSize * 3) / 4;
367 else return m_windowSize / (1 << (m_windowHopLevel - 1)); 367 else return m_windowSize / (1 << (m_windowHopLevel - 1));
368 } 368 }
369 369
370 int getZeroPadLevel(const View *v) const; 370 int getZeroPadLevel(const LayerGeometryProvider *v) const;
371 int getFFTSize(const View *v) const; 371 int getFFTSize(const LayerGeometryProvider *v) const;
372 FFTModel *getFFTModel(const View *v) const; 372 FFTModel *getFFTModel(const LayerGeometryProvider *v) const;
373 Dense3DModelPeakCache *getPeakCache(const View *v) const; 373 Dense3DModelPeakCache *getPeakCache(const LayerGeometryProvider *v) const;
374 void invalidateFFTModels(); 374 void invalidateFFTModels();
375 375
376 typedef std::pair<FFTModel *, sv_frame_t> FFTFillPair; // model, last fill 376 typedef std::pair<FFTModel *, sv_frame_t> FFTFillPair; // model, last fill
377 typedef std::map<const View *, FFTFillPair> ViewFFTMap; 377 typedef std::map<const LayerGeometryProvider *, FFTFillPair> ViewFFTMap;
378 typedef std::map<const View *, Dense3DModelPeakCache *> PeakCacheMap; 378 typedef std::map<const LayerGeometryProvider *, Dense3DModelPeakCache *> PeakCacheMap;
379 mutable ViewFFTMap m_fftModels; 379 mutable ViewFFTMap m_fftModels;
380 mutable PeakCacheMap m_peakCaches; 380 mutable PeakCacheMap m_peakCaches;
381 mutable Model *m_sliceableModel; 381 mutable Model *m_sliceableModel;
382 382
383 class MagnitudeRange { 383 class MagnitudeRange {
420 private: 420 private:
421 float m_min; 421 float m_min;
422 float m_max; 422 float m_max;
423 }; 423 };
424 424
425 typedef std::map<const View *, MagnitudeRange> ViewMagMap; 425 typedef std::map<const LayerGeometryProvider *, MagnitudeRange> ViewMagMap;
426 mutable ViewMagMap m_viewMags; 426 mutable ViewMagMap m_viewMags;
427 mutable std::vector<MagnitudeRange> m_columnMags; 427 mutable std::vector<MagnitudeRange> m_columnMags;
428 void invalidateMagnitudes(); 428 void invalidateMagnitudes();
429 bool updateViewMagnitudes(View *v) const; 429 bool updateViewMagnitudes(LayerGeometryProvider *v) const;
430 bool paintDrawBuffer(View *v, int w, int h, 430 bool paintDrawBuffer(LayerGeometryProvider *v, int w, int h,
431 const std::vector<int> &binforx, 431 const std::vector<int> &binforx,
432 const std::vector<double> &binfory, 432 const std::vector<double> &binfory,
433 bool usePeaksCache, 433 bool usePeaksCache,
434 MagnitudeRange &overallMag, 434 MagnitudeRange &overallMag,
435 bool &overallMagChanged) const; 435 bool &overallMagChanged) const;
436 bool paintDrawBufferPeakFrequencies(View *v, int w, int h, 436 bool paintDrawBufferPeakFrequencies(LayerGeometryProvider *v, int w, int h,
437 const std::vector<int> &binforx, 437 const std::vector<int> &binforx,
438 int minbin, 438 int minbin,
439 int maxbin, 439 int maxbin,
440 double displayMinFreq, 440 double displayMinFreq,
441 double displayMaxFreq, 441 double displayMaxFreq,
442 bool logarithmic, 442 bool logarithmic,
443 MagnitudeRange &overallMag, 443 MagnitudeRange &overallMag,
444 bool &overallMagChanged) const; 444 bool &overallMagChanged) const;
445 445
446 virtual void updateMeasureRectYCoords(View *v, const MeasureRect &r) const; 446 virtual void updateMeasureRectYCoords(LayerGeometryProvider *v, const MeasureRect &r) const;
447 virtual void setMeasureRectYCoord(View *v, MeasureRect &r, bool start, int y) const; 447 virtual void setMeasureRectYCoord(LayerGeometryProvider *v, MeasureRect &r, bool start, int y) const;
448 }; 448 };
449 449
450 #endif 450 #endif