annotate data/fft/FFTFileCacheReader.h @ 981:c6f2b93a7d52

Respond tidily to user cancellation during download, instead of going on to attempt to load the nonexistent file as a non-audio format
author Chris Cannam
date Tue, 09 Sep 2014 16:52:24 +0100
parents 59e7fe1b1003
children cc27f35aa75c
rev   line source
Chris@537 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@537 2
Chris@537 3 /*
Chris@537 4 Sonic Visualiser
Chris@537 5 An audio file viewer and annotation editor.
Chris@537 6 Centre for Digital Music, Queen Mary, University of London.
Chris@537 7 This file copyright 2006-2009 Chris Cannam and QMUL.
Chris@537 8
Chris@537 9 This program is free software; you can redistribute it and/or
Chris@537 10 modify it under the terms of the GNU General Public License as
Chris@537 11 published by the Free Software Foundation; either version 2 of the
Chris@537 12 License, or (at your option) any later version. See the file
Chris@537 13 COPYING included with this distribution for more information.
Chris@537 14 */
Chris@537 15
Chris@537 16 #ifndef _FFT_FILE_CACHE_READER_H_
Chris@537 17 #define _FFT_FILE_CACHE_READER_H_
Chris@537 18
Chris@537 19 #include "data/fileio/MatrixFile.h"
Chris@537 20 #include "FFTCacheReader.h"
Chris@537 21 #include "FFTCacheStorageType.h"
Chris@537 22
Chris@537 23 class FFTFileCacheWriter;
Chris@537 24
Chris@537 25 class FFTFileCacheReader : public FFTCacheReader
Chris@537 26 {
Chris@537 27 public:
Chris@537 28 FFTFileCacheReader(FFTFileCacheWriter *);
Chris@537 29 ~FFTFileCacheReader();
Chris@537 30
Chris@929 31 int getWidth() const;
Chris@929 32 int getHeight() const;
Chris@537 33
Chris@929 34 float getMagnitudeAt(int x, int y) const;
Chris@929 35 float getNormalizedMagnitudeAt(int x, int y) const;
Chris@929 36 float getMaximumMagnitudeAt(int x) const;
Chris@929 37 float getPhaseAt(int x, int y) const;
Chris@537 38
Chris@929 39 void getValuesAt(int x, int y, float &real, float &imag) const;
Chris@929 40 void getMagnitudesAt(int x, float *values, int minbin, int count, int step) const;
Chris@537 41
Chris@929 42 bool haveSetColumnAt(int x) const;
Chris@537 43
Chris@929 44 static int getCacheSize(int width, int height,
Chris@537 45 FFTCache::StorageType type);
Chris@537 46
Chris@537 47 FFTCache::StorageType getStorageType() const { return m_storageType; }
Chris@537 48
Chris@537 49 protected:
Chris@537 50 mutable char *m_readbuf;
Chris@929 51 mutable int m_readbufCol;
Chris@929 52 mutable int m_readbufWidth;
Chris@555 53 mutable bool m_readbufGood;
Chris@537 54
Chris@929 55 float getFromReadBufStandard(int x, int y) const {
Chris@537 56 float v;
Chris@537 57 if (m_readbuf &&
Chris@537 58 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
Chris@537 59 v = ((float *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
Chris@537 60 return v;
Chris@537 61 } else {
Chris@537 62 populateReadBuf(x);
Chris@537 63 v = getFromReadBufStandard(x, y);
Chris@537 64 return v;
Chris@537 65 }
Chris@537 66 }
Chris@537 67
Chris@929 68 float getFromReadBufCompactUnsigned(int x, int y) const {
Chris@537 69 float v;
Chris@537 70 if (m_readbuf &&
Chris@537 71 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
Chris@537 72 v = ((uint16_t *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
Chris@537 73 return v;
Chris@537 74 } else {
Chris@537 75 populateReadBuf(x);
Chris@537 76 v = getFromReadBufCompactUnsigned(x, y);
Chris@537 77 return v;
Chris@537 78 }
Chris@537 79 }
Chris@537 80
Chris@929 81 float getFromReadBufCompactSigned(int x, int y) const {
Chris@537 82 float v;
Chris@537 83 if (m_readbuf &&
Chris@537 84 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
Chris@537 85 v = ((int16_t *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
Chris@537 86 return v;
Chris@537 87 } else {
Chris@537 88 populateReadBuf(x);
Chris@537 89 v = getFromReadBufCompactSigned(x, y);
Chris@537 90 return v;
Chris@537 91 }
Chris@537 92 }
Chris@537 93
Chris@929 94 void populateReadBuf(int x) const;
Chris@537 95
Chris@929 96 float getNormalizationFactor(int col) const {
Chris@929 97 int h = m_mfc->getHeight();
Chris@537 98 if (h < m_factorSize) return 0;
Chris@537 99 if (m_storageType != FFTCache::Compact) {
Chris@537 100 return getFromReadBufStandard(col, h - 1);
Chris@537 101 } else {
Chris@537 102 union {
Chris@537 103 float f;
Chris@537 104 uint16_t u[2];
Chris@537 105 } factor;
Chris@537 106 if (!m_readbuf ||
Chris@537 107 !(m_readbufCol == col ||
Chris@537 108 (m_readbufWidth > 1 && m_readbufCol+1 == col))) {
Chris@537 109 populateReadBuf(col);
Chris@537 110 }
Chris@929 111 int ix = (col - m_readbufCol) * m_mfc->getHeight() + h;
Chris@537 112 factor.u[0] = ((uint16_t *)m_readbuf)[ix - 2];
Chris@537 113 factor.u[1] = ((uint16_t *)m_readbuf)[ix - 1];
Chris@537 114 return factor.f;
Chris@537 115 }
Chris@537 116 }
Chris@537 117
Chris@537 118 FFTCache::StorageType m_storageType;
Chris@929 119 int m_factorSize;
Chris@537 120 MatrixFile *m_mfc;
Chris@537 121 };
Chris@537 122
Chris@537 123 #endif