mirror of
https://github.com/LMMS/lmms.git
synced 2026-01-23 13:58:17 -05:00
199 lines
4.7 KiB
C++
199 lines
4.7 KiB
C++
/*
|
|
* MidiClient.h - base-class for MIDI clients like ALSA-sequencer-client
|
|
*
|
|
* Copyright (c) 2005-2014 Tobias Doerffel <tobydox/at/users.sourceforge.net>
|
|
*
|
|
* This file is part of LMMS - http://lmms.io
|
|
*
|
|
* 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.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public
|
|
* License along with this program (see COPYING); if not, write to the
|
|
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
* Boston, MA 02110-1301 USA.
|
|
*
|
|
*/
|
|
|
|
#ifndef MIDI_CLIENT_H
|
|
#define MIDI_CLIENT_H
|
|
|
|
#include <QtCore/QStringList>
|
|
#include <QtCore/QVector>
|
|
|
|
|
|
#include "MidiEvent.h"
|
|
#include "MidiEventProcessor.h"
|
|
#include "TabWidget.h"
|
|
|
|
|
|
class MidiPort;
|
|
|
|
|
|
// base-class for all MIDI-clients
|
|
class MidiClient
|
|
{
|
|
public:
|
|
MidiClient();
|
|
virtual ~MidiClient();
|
|
|
|
// to be implemented by sub-classes
|
|
virtual void processOutEvent( const MidiEvent & _me,
|
|
const MidiTime & _time,
|
|
const MidiPort * _port ) = 0;
|
|
|
|
// inheriting classes can re-implement this for being able to update
|
|
// their internal port-structures etc.
|
|
virtual void applyPortMode( MidiPort * _port );
|
|
virtual void applyPortName( MidiPort * _port );
|
|
|
|
virtual void addPort( MidiPort * _port );
|
|
|
|
// re-implemented methods HAVE to call removePort() of base-class!!
|
|
virtual void removePort( MidiPort * _port );
|
|
|
|
|
|
// returns whether client works with raw-MIDI, only needs to be
|
|
// re-implemented by MidiClientRaw for returning true
|
|
virtual bool isRaw() const
|
|
{
|
|
return false;
|
|
}
|
|
|
|
// if not raw-client, return all readable/writable ports
|
|
virtual QStringList readablePorts() const
|
|
{
|
|
return QStringList();
|
|
}
|
|
virtual QStringList writablePorts() const
|
|
{
|
|
return QStringList();
|
|
}
|
|
|
|
// return name of port which specified MIDI event came from
|
|
virtual QString sourcePortName( const MidiEvent & ) const
|
|
{
|
|
return QString();
|
|
}
|
|
|
|
|
|
// (un)subscribe given MidiPort to/from destination-port
|
|
virtual void subscribeReadablePort( MidiPort * _port,
|
|
const QString & _dest,
|
|
bool _subscribe = true );
|
|
virtual void subscribeWritablePort( MidiPort * _port,
|
|
const QString & _dest,
|
|
bool _subscribe = true );
|
|
|
|
// qobject-derived classes can use this for make a slot being
|
|
// connected to signal of non-raw-MIDI-client if port-lists change
|
|
virtual void connectRPChanged( QObject *, const char * )
|
|
{
|
|
}
|
|
|
|
virtual void connectWPChanged( QObject *, const char * )
|
|
{
|
|
}
|
|
|
|
// tries to open either MIDI-driver from config-file or (if it fails)
|
|
// any other working
|
|
static MidiClient * openMidiClient();
|
|
|
|
|
|
class setupWidget : public TabWidget
|
|
{
|
|
public:
|
|
setupWidget( const QString & _caption, QWidget * _parent ) :
|
|
TabWidget( TabWidget::tr( "Settings for %1" ).arg(
|
|
tr( _caption.toLatin1() ) ).toUpper(),
|
|
_parent )
|
|
{
|
|
}
|
|
|
|
virtual ~setupWidget()
|
|
{
|
|
}
|
|
|
|
virtual void saveSettings() = 0;
|
|
|
|
virtual void show()
|
|
{
|
|
parentWidget()->show();
|
|
QWidget::show();
|
|
}
|
|
|
|
} ;
|
|
|
|
|
|
protected:
|
|
QVector<MidiPort *> m_midiPorts;
|
|
|
|
} ;
|
|
|
|
|
|
|
|
|
|
const uint32_t RAW_MIDI_PARSE_BUF_SIZE = 16;
|
|
|
|
|
|
class MidiClientRaw : public MidiClient
|
|
{
|
|
public:
|
|
MidiClientRaw();
|
|
virtual ~MidiClientRaw();
|
|
|
|
// we are raw-clients for sure!
|
|
virtual bool isRaw() const
|
|
{
|
|
return true;
|
|
}
|
|
|
|
|
|
protected:
|
|
// generic raw-MIDI-parser which generates appropriate MIDI-events
|
|
void parseData( const unsigned char c );
|
|
|
|
// to be implemented by actual client-implementation
|
|
virtual void sendByte( const unsigned char c ) = 0;
|
|
|
|
|
|
private:
|
|
// this does MIDI-event-process
|
|
void processParsedEvent();
|
|
virtual void processOutEvent( const MidiEvent& event, const MidiTime& time, const MidiPort* port );
|
|
|
|
// small helper function returning length of a certain event - this
|
|
// is necessary for parsing raw-MIDI-data
|
|
static int eventLength( const unsigned char event );
|
|
|
|
|
|
// data being used for parsing
|
|
struct midiParserData
|
|
{
|
|
uint8_t m_status; // identifies the type of event, that
|
|
// is currently received ('Noteon',
|
|
// 'Pitch Bend' etc).
|
|
uint8_t m_channel; // The channel of the event that is
|
|
// received (in case of a channel event)
|
|
uint32_t m_bytes; // How many bytes have been read for
|
|
// the current event?
|
|
uint32_t m_bytesTotal; // How many bytes does the current
|
|
// event type include?
|
|
uint32_t m_buffer[RAW_MIDI_PARSE_BUF_SIZE];
|
|
// buffer for incoming data
|
|
MidiEvent m_midiEvent; // midi-event
|
|
} m_midiParseData;
|
|
|
|
} ;
|
|
|
|
|
|
#endif
|
|
|