-Removed C++ APC controller, now working trough GenericMIDI JSON .ctlr file

main
Harry van Haaren 2013-10-09 00:16:05 +01:00
parent 2f88994b2d
commit 87ee78787a
3 changed files with 2 additions and 423 deletions

View File

@ -1,369 +0,0 @@
#include "apc.hxx"
#include <iostream>
#include "../jack.hxx"
#include "../gridlogic.hxx"
extern Jack* jack;
AkaiAPC::AkaiAPC() :
Controller(),
MidiIO(),
shiftPressed(false),
footpedalTrack(0),
footpedalScene(0)
{
// register the port in JACK
//registerPorts("apc");
//_port = port();
}
void AkaiAPC::recordArm(int t, bool enabled)
{
unsigned char data[3];
data[0] = 144 + t;
data[1] = 48; // record enable LED
data[2] = enabled ? 127 : 0;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::progress(int t, int s, float f)
{
/*
unsigned char data[3];
data[0] = 176;
data[1] = 48; // record enable LED
data[2] = 127 * f;
jack->midiObserverWriteMIDI( _port, &data[0] );
*/
}
void AkaiAPC::trackSend(int t, int send, float v)
{
if ( t >= NTRACKS)
{
// master track, no sidechains / sends
return;
}
unsigned char data[3];
/*
if ( send == SEND_KEY )
{
int tmp = v > 0.5 ? 144 : 128;
data[0] = tmp + t;
data[1] = 49;
data[2] = 127 ;
}
*/
if ( send == SEND_XSIDE )
{
data[0] = 176 + t;
data[1] = 16;
data[2] = 127 * v;
}
else if ( send == SEND_POSTFADER )
{
data[0] = 176 + t;
data[1] = 20;
data[2] = 127 * v;
}
else
{
//cout << "AkaiAPC::trackSend() unknown send!" << endl;
}
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::trackSendActive(int t, int send, bool a)
{
unsigned char data[3];
if ( a )
data[0] = 0x90;
else
data[0] = 0x80;
data[1] = 0x30;
data[2] = 0x7F;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::setSceneState(int t, int clip, GridLogic::State s)
{
unsigned char data[3];
data[0] = 144 + t;
data[1] = 53 + clip;
switch (s)
{
case GridLogic::STATE_EMPTY: data[2] = 0; break;
case GridLogic::STATE_PLAYING: data[2] = 1; break;
case GridLogic::STATE_PLAY_QUEUED: data[2] = 2; break;
case GridLogic::STATE_RECORDING: data[2] = 3; break;
case GridLogic::STATE_RECORD_QUEUED: data[2] = 4; break;
case GridLogic::STATE_STOPPED: data[2] = 5; break;
case GridLogic::STATE_STOP_QUEUED: data[2] = 6; break;
}
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::metronomeEnable(bool b)
{
unsigned char data[3];
data[0] = 144;
data[1] = 65;
data[2] = 127;
if ( !b )
data[0] = 128;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::launchScene( int s )
{
unsigned char data[3];
for(int i = 0; i < 5; i++ )
{
data[0] = 128;
data[1] = 82 + i; // scene play
data[2] = 0;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
data[0] = 144;
data[1] = 82 + s;
data[2] = 127;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
void AkaiAPC::mute(int t, bool b)
{
}
void AkaiAPC::volume(int t, float f)
{
}
void AkaiAPC::noteOn( int track, int note, int vel )
{
#ifdef DEBUG_CONTROLLER
printf("apc noteOn: t = %i, n = %i, vel = %i\n", track, note, vel);
#endif
if ( note >= 53 && note <= 57 )
{
if ( shiftPressed )
{
footpedalTrack = track;
footpedalScene = note - 53;
}
else
jack->getGridLogic()->pressed( track, note - 53 );
return;
}
switch( note )
{
case 48: { // record
jack->getLogic()->trackRecordArm(track, true);
} break;
case 49: { // solo / cue
jack->getLogic()->trackSend(track, SEND_KEY, 1);
} break;
case 65: { // metronome button
jack->getLogic()->metronomeEnable( true );
} break;
case 82: // Master Scene Clips
case 83:
case 84:
case 85:
case 86: {
jack->getGridLogic()->launchScene(note - 82);
} break;
case 98: { // Shift
shiftPressed = true;
break; }
case 99: { // tap tempo
jack->getLogic()->tapTempo();
jack->getControllerUpdater()->tapTempo( true );
} break;
case 100: { // nudge +
} break;
case 101: { // nudge -
} break;
default:
break;
}
}
void AkaiAPC::noteOff( int track, int note, int vel )
{
#ifdef DEBUG_CONTROLLER
printf("apc noteOff: t = %i, n = %i, vel = %i\n", track, note, vel);
#endif
if ( note >= 53 && note <= 57 )
{
jack->getGridLogic()->released( track, note - 53 );
}
switch( note )
{
case 48: { // record
jack->getLogic()->trackRecordArm(track, false);
} break;
case 49: { // solo / cue
jack->getLogic()->trackSend(track, SEND_KEY, 0);
}
case 65: { // metronome button
jack->getLogic()->metronomeEnable( false );
} break;
case 99: { // tap tempo
EventTimeTempoTap e(false);
writeToGuiRingbuffer( &e );
} break;
case 82: // scene launch
case 83:
case 84:
case 85:
case 86: {
int s = jack->getGridLogic()->getLaunchedScene();
launchScene( s );
} break ;
case 98: { // Shift
shiftPressed = false;
break; }
}
}
void AkaiAPC::ccChange( int track, int cc, float value )
{
if ( track >= 0 && track < NTRACKS )
{
switch( cc )
{
/// Track faders
case 7: {
jack->getLogic()->trackVolume( track, value );
break; }
case 14: { // master
jack->getLogic()->trackVolume( -1, value );
break; }
/// X-Fader
case 15: {
//jack->getTimeManager()->setBpm( 60 + value * 180 );
break; }
/// Device Control
case 16: {
jack->getLogic()->trackSend( track, SEND_XSIDE, value );
break; }
case 17: {
//jack->getLogic()->trackSend( track, SEND_KEY, value );
break; }
case 18: {
//jack->getLogic()->trackSend( track, SEND_KEY, value );
break; }
case 19: {
//jack->getLogic()->trackSend( track, SEND_KEY, value );
break; }
case 20: {
jack->getLogic()->trackSend( track, SEND_POSTFADER, value );
break; }
case 21: {
//jack->getLogic()->trackSend( track, SEND_POSTFADER, value );
break; }
case 22: {
//jack->getLogic()->trackSend( track, SEND_POSTFADER, value );
break; }
case 23: {
//jack->getLogic()->trackSend( track, SEND_POSTFADER, value );
break; }
case 64: { // FootSwitch 1
if ( value > 0.5 )
{
//printf("footpedal press %i, %i\n", footpedalTrack, footpedalScene );
jack->getGridLogic()->pressed( footpedalTrack, footpedalScene );
}
else
{
//printf("footpedal release %i, %i\n", footpedalTrack, footpedalScene );
jack->getGridLogic()->released( footpedalTrack, footpedalScene );
} break; }
case 67: { // FootSwitch 2
break; }
}
}
else
// tracks outside normal track range
// handle master track buttons etc here
{
if ( cc == 16 ) // master device control select
{
}
}
}
void AkaiAPC::midi(unsigned char* data)
{
int b1 = data[0];
int b2 = data[1];
int b3 = data[2];
if ( b1 >= 144 && b1 < 144 + 16 ) // NOTE_ON
{
noteOn( b1 - 144, b2, b3 );
}
else if ( b1 >= 128 && b1 < 128 + 16 ) // NOTE_OFF
{
noteOff( b1 - 128, b2, b3 );
}
else if ( b1 >= 176 && b1 < 176 + 16 ) // CC
{
ccChange( b1 - 176, b2, data[2] / 127.f );
}
}
void AkaiAPC::reset()
{
unsigned char data[3];
// setup "volume" style rotary display
for(int i = 0; i < NTRACKS; i++)
{
data[0] = 176 + i;
data[1] = 0x19;
data[2] = 2;
//jack->midiObserverWriteMIDI( _port, &data[0] );
}
}

View File

@ -1,52 +0,0 @@
#ifndef LUPPP_APC_H
#define LUPPP_APC_H
#include "controller.hxx"
#include "../observer/midi.hxx"
class AkaiAPC : public Controller, public MidiIO
{
public:
AkaiAPC();
std::string getName(){return "Akai APC";}
/// global state
void metronomeEnable(bool b);
/// track actions
void mute(int t, bool b);
void volume(int t, float f);
void progress(int t, int s, float f);
void recordArm(int t, bool b);
void launchScene( int scene );
void setSceneState(int track, int clip, GridLogic::State s);
/// track FX
void trackSend(int t, int send, float v);
void trackSendActive(int t, int send, bool a);
void reset();
void midi(unsigned char* data);
private:
int _port;
bool shiftPressed;
int footpedalTrack;
int footpedalScene;
/// for handling events
void ccChange( int track, int cc, float value );
void noteOff( int track, int note, int vel );
void noteOn( int track, int note, int vel );
};
#endif // LUPPP_APC_H

View File

@ -7,9 +7,9 @@
#include "audiobuffer.hxx"
#include "eventhandler.hxx"
#include "controller/guicontroller.hxx"
#include "controller/genericmidi.hxx"
#include "controller/apc.hxx"
#include "controller/guicontroller.hxx"
using namespace std;