Mercurial > hg > svcore
annotate data/fileio/DataFileReaderFactory.h @ 157:c03ec31005e1
* Add zoom thumbwheels to Pane. Implement horizontal thumbwheel, and
vertical depending on layer type (supported for waveform and spectrogram,
though wrong for log-scale spectrogram at the moment).
* Add bare bones of a spectrum layer.
* Add window icon
* Add shortcut for "insert time instant" on laptops without keypad enter (";")
* Delete FFT processing thread when it exits (at least, next time we're asked
for something interesting)
* Get audio file extensions from the file readers, and thus from libsndfile for
the wave file reader -- leads to rather a wide combo box in file dialog though
* Better refresh order for spectrogram (redraw centre section first)
author | Chris Cannam |
---|---|
date | Fri, 04 Aug 2006 17:01:37 +0000 |
parents | 1a42221a1522 |
children | 14e0f60435b8 |
rev | line source |
---|---|
Chris@148 | 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ |
Chris@148 | 2 |
Chris@148 | 3 /* |
Chris@148 | 4 Sonic Visualiser |
Chris@148 | 5 An audio file viewer and annotation editor. |
Chris@148 | 6 Centre for Digital Music, Queen Mary, University of London. |
Chris@148 | 7 This file copyright 2006 Chris Cannam. |
Chris@148 | 8 |
Chris@148 | 9 This program is free software; you can redistribute it and/or |
Chris@148 | 10 modify it under the terms of the GNU General Public License as |
Chris@148 | 11 published by the Free Software Foundation; either version 2 of the |
Chris@148 | 12 License, or (at your option) any later version. See the file |
Chris@148 | 13 COPYING included with this distribution for more information. |
Chris@148 | 14 */ |
Chris@148 | 15 |
Chris@148 | 16 #ifndef _DATA_FILE_READER_FACTORY_H_ |
Chris@148 | 17 #define _DATA_FILE_READER_FACTORY_H_ |
Chris@148 | 18 |
Chris@148 | 19 #include <QString> |
Chris@148 | 20 |
Chris@148 | 21 class DataFileReader; |
Chris@148 | 22 class Model; |
Chris@148 | 23 |
Chris@148 | 24 class DataFileReaderFactory |
Chris@148 | 25 { |
Chris@148 | 26 public: |
Chris@148 | 27 /** |
Chris@148 | 28 * Return the file extensions that we have data file readers for, |
Chris@148 | 29 * in a format suitable for use with QFileDialog. For example, |
Chris@148 | 30 * "*.csv *.xml". |
Chris@148 | 31 */ |
Chris@148 | 32 static QString getKnownExtensions(); |
Chris@148 | 33 |
Chris@148 | 34 /** |
Chris@148 | 35 * Return a data file reader initialised to the file at the |
Chris@148 | 36 * given path, or NULL if no suitable reader for this path is |
Chris@148 | 37 * available or the file cannot be opened. |
Chris@148 | 38 * Caller owns the returned object and must delete it after use. |
Chris@148 | 39 */ |
Chris@148 | 40 static DataFileReader *createReader(QString path, |
Chris@148 | 41 size_t mainModelSampleRate); |
Chris@148 | 42 |
Chris@148 | 43 /** |
Chris@148 | 44 * Read the given path, if a suitable reader is available. |
Chris@148 | 45 * Return NULL if no reader succeeded in reading this file. |
Chris@148 | 46 */ |
Chris@148 | 47 static Model *load(QString path, size_t mainModelSampleRate); |
Chris@148 | 48 }; |
Chris@148 | 49 |
Chris@148 | 50 #endif |
Chris@148 | 51 |