view transform/RealTimePluginTransform.h @ 7:c3ef80114040

* 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 40116f709d3b
children d88d117e0c34
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */

/*
    Sonic Visualiser
    An audio file viewer and annotation editor.
    Centre for Digital Music, Queen Mary, University of London.
    This file copyright 2006 Chris Cannam.
    
    This program is free software; you can redistribute it and/or
    modify it under the terms of the GNU General Public License as
    published by the Free Software Foundation; either version 2 of the
    License, or (at your option) any later version.  See the file
    COPYING included with this distribution for more information.
*/

#ifndef _REAL_TIME_PLUGIN_TRANSFORM_H_
#define _REAL_TIME_PLUGIN_TRANSFORM_H_

#include "Transform.h"
#include "plugin/RealTimePluginInstance.h"

class DenseTimeValueModel;

class RealTimePluginTransform : public Transform
{
public:
    RealTimePluginTransform(Model *inputModel,
			    QString plugin,
                            int channel,
			    QString configurationXml = "",
                            QString units = "",
			    int output = 0);
    virtual ~RealTimePluginTransform();

protected:
    virtual void run();

    RealTimePluginInstance *m_plugin;
    int m_channel;
    int m_outputNo;

    // just casts
    DenseTimeValueModel *getInput();
};

#endif