2013-12-08 22:44:43 +01:00
|
|
|
/*
|
|
|
|
* Author: Harry van Haaren 2013
|
|
|
|
* harryhaaren@gmail.com
|
2016-12-27 13:47:19 +01:00
|
|
|
*
|
2013-12-08 22:44:43 +01:00
|
|
|
* 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
2016-12-27 13:47:19 +01:00
|
|
|
*
|
2013-12-08 22:44:43 +01:00
|
|
|
* 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.
|
2016-12-27 13:47:19 +01:00
|
|
|
*
|
2013-12-08 22:44:43 +01:00
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2013-09-10 22:51:05 +02:00
|
|
|
|
|
|
|
#include "gmastertrack.hxx"
|
|
|
|
|
2014-08-30 17:44:09 +02:00
|
|
|
#include <FL/Fl_Menu_Item.H>
|
2019-05-31 20:59:48 +02:00
|
|
|
#include <stdlib.h>
|
2014-08-30 17:44:09 +02:00
|
|
|
|
2013-09-14 04:57:58 +02:00
|
|
|
static void gmastertrack_tempoDial_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Dial* b = (Avtk::Dial*)w;
|
2018-03-31 14:30:24 +02:00
|
|
|
float bpm = (int)(b->value() * (float)(MAX_TEMPO - MIN_TEMPO) + MIN_TEMPO);
|
2016-12-27 13:47:19 +01:00
|
|
|
if(std::fabs(bpm-round(bpm))) {
|
|
|
|
LUPPP_WARN("%f",bpm);
|
|
|
|
}
|
|
|
|
EventTimeBPM e = EventTimeBPM( bpm );
|
|
|
|
writeToDspRingbuffer( &e );
|
2013-09-14 04:57:58 +02:00
|
|
|
}
|
|
|
|
|
2013-09-20 11:29:05 +02:00
|
|
|
static void gmastertrack_volume_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Volume* b = (Avtk::Volume*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterVol e( v );
|
|
|
|
writeToDspRingbuffer( &e );
|
2013-09-20 11:29:05 +02:00
|
|
|
}
|
|
|
|
|
2013-09-20 14:11:47 +02:00
|
|
|
static void gmastertrack_inputVolume_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Volume* b = (Avtk::Volume*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterInputVol e( v );
|
|
|
|
writeToDspRingbuffer( &e );
|
2013-09-20 14:11:47 +02:00
|
|
|
}
|
|
|
|
|
2013-09-20 12:23:59 +02:00
|
|
|
static void gmastertrack_sidchainKeyButton_callback(Fl_Widget *w, void *data)
|
2013-09-18 10:53:15 +02:00
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::LightButton* b = (Avtk::LightButton*)w;
|
|
|
|
b->value( !b->value() );
|
|
|
|
EventMasterInputToActive e( INPUT_TO_SIDE_KEY, b->value() );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
//printf("Key button\n");
|
2013-09-18 10:53:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void gmastertrack_mixButton_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::LightButton* b = (Avtk::LightButton*)w;
|
|
|
|
b->value( !b->value() );
|
|
|
|
EventMasterInputToActive e( INPUT_TO_MIX, b->value() );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
//printf("Mix button\n");
|
2013-09-18 10:53:15 +02:00
|
|
|
}
|
|
|
|
|
2013-09-20 13:40:50 +02:00
|
|
|
static void gmastertrack_sendButton_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::LightButton* b = (Avtk::LightButton*)w;
|
|
|
|
b->value( !b->value() );
|
|
|
|
EventMasterInputToActive e( INPUT_TO_SEND, b->value() );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
//printf("Send button\n");
|
2013-09-20 14:02:27 +02:00
|
|
|
|
2013-09-20 13:40:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void gmastertrack_sendVol_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Dial* b = (Avtk::Dial*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterInputTo e = EventMasterInputTo( INPUT_TO_SEND, v );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
///printf("Send dial\n");
|
2013-09-20 14:02:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void gmastertrack_xSideVol_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Dial* b = (Avtk::Dial*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterInputTo e = EventMasterInputTo( INPUT_TO_XSIDE, v );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
//printf("XSide dial\n");
|
2013-09-20 14:02:27 +02:00
|
|
|
}
|
|
|
|
|
2013-10-07 16:21:24 +02:00
|
|
|
/// return volume
|
|
|
|
static void gmastertrack_returnVol_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Dial* b = (Avtk::Dial*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterReturn e( RETURN_MAIN, v );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
//printf("Return dial\n");
|
2013-10-07 16:21:24 +02:00
|
|
|
}
|
|
|
|
|
2013-09-20 14:02:27 +02:00
|
|
|
static void gmastertrack_mixVol_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::Dial* b = (Avtk::Dial*)w;
|
|
|
|
float v = b->value();
|
|
|
|
EventMasterInputTo e = EventMasterInputTo( INPUT_TO_MIX, v );
|
|
|
|
writeToDspRingbuffer( &e );
|
2013-09-20 13:40:50 +02:00
|
|
|
}
|
|
|
|
|
2014-08-08 14:54:18 +02:00
|
|
|
static void gmastertrack_transport_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
Avtk::LightButton* b = (Avtk::LightButton*)w;
|
|
|
|
if( b->value() ) {
|
|
|
|
EventTransportState e = EventTransportState( TRANSPORT_ROLLING );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
w->label( "Stop" );
|
|
|
|
b->value( 0 );
|
|
|
|
} else {
|
|
|
|
EventTransportState e = EventTransportState( TRANSPORT_STOPPED );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
w->label( "Play" );
|
|
|
|
b->value( 1 );
|
|
|
|
}
|
|
|
|
|
2014-08-08 14:54:18 +02:00
|
|
|
}
|
|
|
|
|
2013-09-14 04:57:58 +02:00
|
|
|
static void gmastertrack_button_callback(Fl_Widget *w, void *data)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
if ( strcmp( w->label(), "Metro" ) == 0 ) {
|
|
|
|
if ( Fl::event_button() == FL_RIGHT_MOUSE ) {
|
|
|
|
// popup volume menu: 10 "steps of volume"
|
|
|
|
Fl_Menu_Item rclick_menu[] = {
|
|
|
|
{ "Vol 100%" },
|
|
|
|
{ "Vol 75%" },
|
|
|
|
{ "Vol 50%" },
|
|
|
|
{ "Vol 25%"},
|
|
|
|
{ 0 }
|
|
|
|
};
|
|
|
|
|
|
|
|
Fl_Menu_Item *m = (Fl_Menu_Item*) rclick_menu->popup( Fl::event_x(), Fl::event_y(), 0, 0, 0);
|
|
|
|
|
|
|
|
float v = 0.f;
|
|
|
|
if ( !m ) {
|
|
|
|
return;
|
|
|
|
} else if ( strcmp(m->label(), "Vol 100%") == 0 ) {
|
|
|
|
v = 1;
|
|
|
|
} else if ( strcmp(m->label(), "Vol 75%") == 0 ) {
|
|
|
|
v = 0.75;
|
|
|
|
} else if ( strcmp(m->label(), "Vol 50%") == 0 ) {
|
|
|
|
v = 0.5;
|
|
|
|
} else
|
|
|
|
v = 0.25;
|
|
|
|
|
|
|
|
LUPPP_NOTE("metro vol = %f", v );
|
|
|
|
|
|
|
|
EventMetronomeVolume e( v );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
} else {
|
|
|
|
Avtk::LightButton* b = (Avtk::LightButton*)w;
|
|
|
|
b->value( !b->value() );
|
|
|
|
EventMetronomeActive e = EventMetronomeActive( b->value() );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} else if ( strcmp( w->label(), "Tap" ) == 0 ) {
|
2018-03-26 20:28:11 +02:00
|
|
|
if ( Fl::event_button() == FL_RIGHT_MOUSE ) {
|
2018-04-01 09:41:30 +02:00
|
|
|
const char* answer = fl_input("Enter BPM value (range %d and %d):", 0, MIN_TEMPO, MAX_TEMPO);
|
2018-03-26 20:28:11 +02:00
|
|
|
if(answer) {
|
|
|
|
int bpm = atoi(answer);
|
2018-03-31 15:05:16 +02:00
|
|
|
|
|
|
|
if ( bpm >= MIN_TEMPO && bpm <= MAX_TEMPO) {
|
|
|
|
EventTimeBPM e = EventTimeBPM( bpm );
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
}
|
2018-03-26 20:28:11 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
EventTimeTempoTap e;
|
|
|
|
writeToDspRingbuffer( &e );
|
|
|
|
}
|
2016-12-27 13:47:19 +01:00
|
|
|
} else {
|
|
|
|
LUPPP_WARN("Error: unknown command string");
|
|
|
|
}
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
static void gmastertrack_autoStopRec_callback(Fl_Widget *w, void *data) {
|
|
|
|
int clipLength = -1;
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
if(Fl::event_button() == FL_LEFT_MOUSE) {
|
|
|
|
Fl_Menu_Item rclick_menu[] = { { "1" }, { "2" }, { "4" },
|
|
|
|
{ "8" }, { "16" }, { "∞" }, { "Custom" }, { 0 } };
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
Fl_Menu_Item *m = (Fl_Menu_Item *)rclick_menu->popup(
|
|
|
|
Fl::event_x(), Fl::event_y(), 0, 0, 0);
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
if(!m) {
|
|
|
|
return;
|
|
|
|
} else if(strcmp(m->label(), "Custom") == 0) {
|
|
|
|
const char *answer = fl_input(
|
|
|
|
// TODO magic number
|
|
|
|
"Enter Clip Length (range 1 and 64):", 0);
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
if(answer) {
|
|
|
|
clipLength = atoi(answer);
|
|
|
|
|
|
|
|
// TODO magic number
|
|
|
|
if(clipLength < 1 || clipLength > 64) {
|
|
|
|
// do not accept invalid input
|
|
|
|
clipLength = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if(strcmp(m->label(), "∞") == 0) {
|
|
|
|
clipLength = 0;
|
|
|
|
} else {
|
|
|
|
clipLength = atoi(m->label());
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
clipLength = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(clipLength >= 0) {
|
|
|
|
EventAutoStopRecClipLength e = EventAutoStopRecClipLength(clipLength);
|
|
|
|
writeToDspRingbuffer(&e);
|
|
|
|
}
|
|
|
|
}
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
#define OFST 30
|
|
|
|
GMasterTrack::GMasterTrack(int x, int y, int w, int h, const char *l)
|
|
|
|
: Fl_Group(x, y, w, h), title(strdup(l)), bg(x, y, w, h, title),
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
// with "true" master flag: launches scenes instead of clips on tracks
|
|
|
|
clipSel(x + 5, y + 26 + 102, 140, 294, "", true),
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
source(x + 5, y + 26, 140, 100, ""),
|
|
|
|
volBox(x + 5, y + 422, 140, 232, ""),
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
transport(x + w * 2 / 4.f - 18, y + 436 + OFST * 0, 44, 22, "Stop"),
|
|
|
|
tapTempo(x + w * 2 / 4.f - 18, y + 436 + OFST * 1, 44, 22, "Tap"),
|
|
|
|
metronomeButton(
|
|
|
|
x + w * 2 / 4.f - 18, y + 436 + OFST * 2, 44, 22, "Metro"),
|
|
|
|
autoStopRecButton(
|
|
|
|
x + w * 2 / 4.f - 18, y + 436 + OFST * 3, 44, 22, "∞"),
|
2016-12-27 13:47:19 +01:00
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
tempoDial(x + w * 2 / 4.f - 18, y + 436 + OFST * 4, 45, 38, "BPM"),
|
|
|
|
returnVol(
|
|
|
|
x + w * 2 / 4.f - 18, y + 436 + OFST * 5.5, 45, 38, "Return"),
|
|
|
|
|
|
|
|
inputVolume(x + 9, y + 26 + 4, w - 18, 30, ""),
|
|
|
|
|
|
|
|
inputToSend(x + 10, y + 28 + 68, 40, 26, "Snd"),
|
|
|
|
inputToSendVol(x + w * 0.2 - 15, y + 28 + 36, 30, 30, ""),
|
|
|
|
|
|
|
|
inputToSidechainKey(x + w * 0.5 - 20, y + 28 + 68, 40, 26, "Key"),
|
|
|
|
inputToSidechainSignalVol(x + w * 0.5 - 15, y + 28 + 36, 30, 30, ""),
|
|
|
|
|
|
|
|
inputToMix(x + w * 0.8 - 20, y + 28 + 68, 40, 26, "Mix"),
|
|
|
|
inputToMixVol(x + w * 0.8 - 15, y + 28 + 36, 30, 30, ""),
|
|
|
|
|
|
|
|
volume(x + 106, y + 425, 36, 216, "")
|
2016-12-27 13:47:19 +01:00
|
|
|
{
|
|
|
|
ID = privateID++;
|
|
|
|
|
|
|
|
bar = 0;
|
|
|
|
|
|
|
|
inputVolume.value(0.5);
|
|
|
|
inputVolume.setOrientationHorizontal();
|
|
|
|
|
|
|
|
inputVolume.callback( gmastertrack_inputVolume_callback, 0 );
|
|
|
|
|
|
|
|
transport.callback( gmastertrack_transport_callback, &ID );
|
|
|
|
|
|
|
|
tapTempo.callback( gmastertrack_button_callback, &ID );
|
|
|
|
|
|
|
|
metronomeButton.callback( gmastertrack_button_callback, 0 );
|
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
autoStopRecButton.callback(gmastertrack_autoStopRec_callback, &ID);
|
|
|
|
|
2016-12-27 13:47:19 +01:00
|
|
|
tempoDial.callback( gmastertrack_tempoDial_callback, 0 );
|
|
|
|
|
|
|
|
inputToSend.setColor( 0, 1.0, 0 );
|
|
|
|
inputToSend.callback( gmastertrack_sendButton_callback, 0 );
|
|
|
|
inputToSendVol.callback( gmastertrack_sendVol_callback, 0 );
|
|
|
|
|
|
|
|
inputToSidechainKey.setColor( 0, 0.6, 1 );
|
|
|
|
inputToSidechainKey.callback( gmastertrack_sidchainKeyButton_callback, 0 );
|
|
|
|
inputToSidechainSignalVol.value( 0 );
|
|
|
|
inputToSidechainSignalVol.callback( gmastertrack_xSideVol_callback, 0 );
|
|
|
|
|
|
|
|
inputToMix.callback ( gmastertrack_mixButton_callback, 0 );
|
|
|
|
inputToMixVol.callback ( gmastertrack_mixVol_callback, 0 );
|
|
|
|
|
|
|
|
tempoDial.align( FL_ALIGN_CENTER );
|
|
|
|
|
|
|
|
returnVol.value( 1.f );
|
|
|
|
returnVol.align( FL_ALIGN_CENTER );
|
|
|
|
returnVol.callback( gmastertrack_returnVol_callback, 0 );
|
|
|
|
|
|
|
|
for(int i = 0; i < 4; i++) {
|
|
|
|
beatLights[i] = new Avtk::LightButton( x + 10, y + 437 + 54 * i, 40, 42, "" );
|
|
|
|
}
|
|
|
|
beatLights[0]->setColor( 1.0, 0.0 , 0.0 );
|
|
|
|
beatLights[1]->setColor( 1.0, 0.48, 0.0 );
|
|
|
|
beatLights[2]->setColor( 1.0, 1.0 , 0.0 );
|
|
|
|
beatLights[3]->setColor( 0.0, 1.0 , 0.0 );
|
|
|
|
|
|
|
|
volume.amplitude( 0.0, 0.0 );
|
|
|
|
volume.callback( gmastertrack_volume_callback, 0 );
|
|
|
|
|
|
|
|
end(); // close the group
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
|
2013-09-11 00:09:45 +02:00
|
|
|
void GMasterTrack::setBpm( int b )
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
bpm = b;
|
2019-04-15 15:05:40 +02:00
|
|
|
if(!tempoDial.mouseClicked) {
|
|
|
|
tempoDial.value(
|
|
|
|
(bpm - MIN_TEMPO) / (float)(MAX_TEMPO - MIN_TEMPO));
|
|
|
|
}
|
2016-12-27 13:47:19 +01:00
|
|
|
std::stringstream s;
|
|
|
|
s << bpm;
|
2017-04-22 01:26:48 +02:00
|
|
|
tempoDial.copy_label( s.str().c_str() );
|
2013-09-11 00:09:45 +02:00
|
|
|
}
|
|
|
|
|
2013-11-09 22:50:21 +01:00
|
|
|
void GMasterTrack::setInputVol(float f)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
//LUPPP_NOTE(" gmtrck, inputVol %f", f );
|
|
|
|
inputVolume.value( f );
|
2013-11-09 22:50:21 +01:00
|
|
|
}
|
|
|
|
|
2013-11-21 15:11:06 +01:00
|
|
|
void GMasterTrack::setReturnVol(float f)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
LUPPP_NOTE(" gmtrck, returnVol %f", f );
|
|
|
|
returnVol.value( f );
|
2013-11-21 15:11:06 +01:00
|
|
|
}
|
|
|
|
|
2013-11-09 22:50:21 +01:00
|
|
|
void GMasterTrack::setInputTo(int to, float f)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
//LUPPP_NOTE(" gmtrck, inputTO %i, %f", to, f );
|
|
|
|
if ( to == Event::INPUT_TO_MIX )
|
|
|
|
inputToMixVol.value( f );
|
|
|
|
else if ( to == Event::INPUT_TO_SEND )
|
|
|
|
inputToSendVol.value( f );
|
|
|
|
else if ( to == Event::INPUT_TO_XSIDE )
|
|
|
|
inputToSidechainSignalVol.value( f );
|
2013-11-09 22:50:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void GMasterTrack::setInputToActive(int to, bool f)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
//LUPPP_NOTE(" gmtrck, inputToActive %i, %i", to, int(f) );
|
|
|
|
|
|
|
|
if ( to == Event::INPUT_TO_MIX )
|
|
|
|
inputToMix.value( f );
|
|
|
|
else if ( to == Event::INPUT_TO_SEND )
|
|
|
|
inputToSend.value( f );
|
|
|
|
else if ( to == Event::INPUT_TO_SIDE_KEY )
|
|
|
|
inputToSidechainKey.value( f );
|
2013-11-09 22:50:21 +01:00
|
|
|
}
|
|
|
|
|
2013-10-09 01:15:31 +02:00
|
|
|
void GMasterTrack::metronomeEnable( bool b )
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
metronomeButton.value( b );
|
2013-10-09 01:15:31 +02:00
|
|
|
}
|
|
|
|
|
2019-05-31 20:59:48 +02:00
|
|
|
void
|
|
|
|
GMasterTrack::setClipLength(int l)
|
|
|
|
{
|
|
|
|
const char *str;
|
|
|
|
if(l == 0) {
|
|
|
|
str = "∞";
|
|
|
|
} else {
|
|
|
|
std::string tmp = std::to_string(l);
|
|
|
|
str = tmp.c_str();
|
|
|
|
}
|
|
|
|
autoStopRecButton.copy_label(str);
|
|
|
|
}
|
|
|
|
|
2013-09-11 00:09:45 +02:00
|
|
|
int GMasterTrack::getBpm()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return bpm;
|
2013-09-11 00:09:45 +02:00
|
|
|
}
|
|
|
|
|
2013-09-10 22:51:05 +02:00
|
|
|
void GMasterTrack::setTapTempo( bool b )
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
tapTempo.setHighlight( b );
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void GMasterTrack::setBarBeat(int b, int beat)
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
// FIXME: hard coded 4/4 time here
|
|
|
|
if ( beat % 4 == 0 ) {
|
|
|
|
bar = bar % 4 + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// turn all off
|
|
|
|
for( int i = 0; i < 4; i++)
|
|
|
|
beatLights[i]->value( 0 );
|
|
|
|
|
|
|
|
// beat starts at 4
|
|
|
|
// FIXME: hard coded 4/4 time
|
|
|
|
beatLights[ 3 - beat%4 ]->value( 1 );
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
Avtk::Volume* GMasterTrack::getInputVolume()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputVolume;
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
Avtk::Volume* GMasterTrack::getVolume()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &volume;
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
2013-12-10 15:15:08 +01:00
|
|
|
|
|
|
|
Avtk::LightButton* GMasterTrack::getInputToSend()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToSend;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
Avtk::LightButton* GMasterTrack::getInputToSidechainKey()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToSidechainKey;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
Avtk::LightButton* GMasterTrack::getInputToMix()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToMix;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Avtk::Dial* GMasterTrack::getInputToSendVol()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToSendVol;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
Avtk::Dial* GMasterTrack::getInputToXSide()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToSidechainSignalVol;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
Avtk::Dial* GMasterTrack::getInputToMixVol()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &inputToMixVol;
|
2013-12-10 15:15:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-09-10 22:51:05 +02:00
|
|
|
Avtk::ClipSelector* GMasterTrack::getClipSelector()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
return &clipSel;
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
GMasterTrack::~GMasterTrack()
|
|
|
|
{
|
2016-12-27 13:47:19 +01:00
|
|
|
free(title);
|
2013-09-10 22:51:05 +02:00
|
|
|
}
|