Dateien hochladen nach „“

pull/100/head
positionhigh 3 years ago
parent f73c9090ec
commit cbbac81e62
  1. 221
      UI.hpp
  2. 2
      config.h

221
UI.hpp

@ -314,6 +314,7 @@ void UI_func_set_sequence_name(uint8_t param);
void UI_func_volume(uint8_t param); void UI_func_volume(uint8_t param);
void UI_func_smart_filter(uint8_t param); void UI_func_smart_filter(uint8_t param);
void UI_func_drum_midi_channel(uint8_t param); void UI_func_drum_midi_channel(uint8_t param);
void UI_func_drum_monitor(uint8_t param);
void UI_func_load_performance(uint8_t param); void UI_func_load_performance(uint8_t param);
void UI_func_save_performance(uint8_t param); void UI_func_save_performance(uint8_t param);
void UI_func_load_voiceconfig(uint8_t param); void UI_func_load_voiceconfig(uint8_t param);
@ -4521,7 +4522,8 @@ void UI_func_seq_vel_editor(uint8_t param)
} }
if (LCDML.FUNC_loop()) // ****** LOOP ********* if (LCDML.FUNC_loop()) // ****** LOOP *********
{ {
if (seq_active_function == 99) { if (seq_active_function == 99)
{
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up())) if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{ {
if (LCDML.BT_checkDown()) if (LCDML.BT_checkDown())
@ -4530,7 +4532,8 @@ void UI_func_seq_vel_editor(uint8_t param)
seq_menu = constrain(seq_menu - 1, 0, 16); seq_menu = constrain(seq_menu - 1, 0, 16);
} }
} }
else if (seq_active_function == 0) { else if (seq_active_function == 0)
{
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up())) if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{ {
if (LCDML.BT_checkDown()) if (LCDML.BT_checkDown())
@ -4539,21 +4542,41 @@ void UI_func_seq_vel_editor(uint8_t param)
seq_active_track = constrain(seq_active_track - 1, 0, 9); seq_active_track = constrain(seq_active_track - 1, 0, 9);
} }
} }
else if (seq_active_function == 1 && seq_content_type[seq_active_track] < 2 ) { //if is Drum or normal Instrument Track if ( seq_data[seq_active_track][seq_menu - 1] > 0 )
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up())) {
if (seq_vel[seq_active_track][seq_menu - 1] < 210) //it is a normal sample
{ {
if (LCDML.BT_checkDown()) if (seq_active_function == 1 && seq_content_type[seq_active_track] < 2 )
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] + 1, 0, 127); { //if is Drum or normal Instrument Track
else if (LCDML.BT_checkUp()) if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] - 1, 0, 127); {
if (LCDML.BT_checkDown())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] + 1, 0, 127);
else if (LCDML.BT_checkUp())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] - 1, 0, 127);
}
}
else if (seq_active_function == 1 && seq_content_type[seq_active_track] > 1 )
{ //is in Chord or Arp Mode
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{
if (LCDML.BT_checkDown())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] + 1, 200, 205);
else if (LCDML.BT_checkUp())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] - 1, 200, 205);
}
}
} }
} else if (seq_active_function == 1 && seq_content_type[seq_active_track] > 1 ) { //is in Chord or Arp Mode else
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{ {
if (LCDML.BT_checkDown()) //is in pitched Sample Mode
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] + 1, 200, 205); if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
else if (LCDML.BT_checkUp()) {
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] - 1, 200, 205); if (LCDML.BT_checkDown())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] + 1, 210, 214);
else if (LCDML.BT_checkUp())
seq_vel[seq_active_track][seq_menu - 1] = constrain(seq_vel[seq_active_track][seq_menu - 1] - 1, 210, 214);
}
} }
} }
if (LCDML.BT_checkEnter()) //handle button presses during menu >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> if (LCDML.BT_checkEnter()) //handle button presses during menu >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
@ -4573,19 +4596,43 @@ void UI_func_seq_vel_editor(uint8_t param)
seq_active_function = 99; seq_active_function = 99;
} }
//button check end <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< //button check end <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
if ( seq_content_type[seq_active_track] > 1 && seq_vel[seq_active_track][seq_menu - 1] < 200) seq_vel[seq_active_track][seq_menu - 1] = 200; if ( seq_content_type[seq_active_track] > 1 && seq_vel[seq_active_track][seq_menu - 1] < 200) seq_vel[seq_active_track][seq_menu - 1] = 200;
if (seq_active_function == 0) {
if (seq_menu > 0 && seq_content_type[seq_active_track] < 2) {
lcd.setCursor(0, 0); lcd.setCursor(0, 0);
lcd.print("Vel:"); if (seq_content_type[seq_active_track] == 0)
sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]); lcd.print("Drum Track ");
lcd.setCursor(4, 0); else if (seq_content_type[seq_active_track] == 1)
lcd.print(tmp); lcd.print("Instr. Track ");
else
lcd.print("Chord Track ");
}
if (seq_menu > 0 && seq_content_type[seq_active_track] == 0)
{
lcd.setCursor(0, 0);
if (seq_vel[seq_active_track][seq_menu - 1] < 210 && seq_vel[seq_active_track][seq_menu - 1] > 0) //it is a normal sample
{
lcd.print("Vel:");
sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]);
lcd.setCursor(4, 0);
lcd.print(tmp);
}
else
{ // else it is a live-pitched sample
if (seq_vel[seq_active_track][seq_menu - 1] > 0) {
lcd.setCursor(0, 0);
lcd.print("Smp:[");
lcd.setCursor(12, 0);
lcd.print("]");
lcd.show(0, 5, 7, basename(drum_config[seq_vel[seq_active_track][seq_menu - 1] - 210].name));
}
}
} }
if (seq_menu == 0) { if (seq_menu == 0) {
lcd.setCursor(4, 0); if (seq_active_function != 0)
lcd.print("--- --- "); {
lcd.setCursor(0, 0);
lcd.print(" ");
}
lcd.setCursor(13, 0); lcd.setCursor(13, 0);
lcd.print("["); lcd.print("[");
lcd.print(seq_active_track); lcd.print(seq_active_track);
@ -4601,10 +4648,14 @@ void UI_func_seq_vel_editor(uint8_t param)
lcd.write(219); // cursor symbol lcd.write(219); // cursor symbol
lcd.setCursor(1, 1); lcd.setCursor(1, 1);
lcd.print(seq_find_shortname(1)[0] ); lcd.print(seq_find_shortname(1)[0] );
sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]); if (seq_vel[seq_active_track][seq_menu - 1] < 210 && seq_content_type[seq_active_track] < 2) //it is a normal sample
lcd.setCursor(4, 0); {
lcd.print(tmp); sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]);
} else if (seq_menu > 1) { lcd.setCursor(4, 0);
lcd.print(tmp);
}
} else if (seq_menu > 1)
{
lcd.setCursor(seq_menu - 1, 1); lcd.setCursor(seq_menu - 1, 1);
lcd.write(219); // cursor symbol lcd.write(219); // cursor symbol
lcd.setCursor(seq_menu - 2, 1); lcd.setCursor(seq_menu - 2, 1);
@ -4616,32 +4667,70 @@ void UI_func_seq_vel_editor(uint8_t param)
} }
if (seq_menu > 0) { if (seq_menu > 0) {
lcd.setCursor(4, 0); lcd.setCursor(4, 0);
if (seq_data[seq_active_track][seq_menu - 1] > 0) { if (seq_data[seq_active_track][seq_menu - 1] > 0)
{
if (seq_content_type[seq_active_track] == 0) //is Drumtrack if (seq_content_type[seq_active_track] == 0) //is Drumtrack
{ {
lcd.show(0, 8, 5, seq_find_drum_name_from_note( seq_data[seq_active_track][seq_menu - 1]) ); lcd.setCursor(0, 0);
if (seq_vel[seq_active_track][seq_menu - 1] < 210) //it is a normal sample
{
lcd.print("Vel:");
sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]);
lcd.setCursor(7, 0);
lcd.print(" ");
lcd.show(0, 8, 5, seq_find_drum_name_from_note( seq_data[seq_active_track][seq_menu - 1]) );
}
else
{ // else it is a live-pitched sample
lcd.setCursor(0, 0);
lcd.print("Smp:[");
lcd.setCursor(12, 0);
lcd.print("]");
lcd.setCursor(1, 0);
lcd.show(0, 5, 7, basename(drum_config[seq_vel[seq_active_track][seq_menu - 1] - 210].name));
}
} else } else
{ lcd.setCursor(0, 0); {
lcd.print(noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][0] ); if ( seq_data[seq_active_track][seq_menu - 1] != 130 ) //note not latched
if (noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][1] != '\0' ) { {
lcd.print(noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][1] ); if (seq_content_type[seq_active_track] < 2)
{
lcd.setCursor(0, 0);
lcd.print("Vel:");
sprintf(tmp, "%03d", seq_vel[seq_active_track][seq_menu - 1]);
lcd.setCursor(4, 0);
lcd.print(tmp);
}
lcd.setCursor(8, 0);
lcd.print(noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][0] );
if (noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][1] != '\0' ) {
lcd.print(noteNames[seq_data[seq_active_track][seq_menu - 1] % 12 ][1] );
}
lcd.print( (seq_data[seq_active_track][seq_menu - 1] / 12) - 1);
lcd.print(" ");
} }
lcd.print( (seq_data[seq_active_track][seq_menu - 1] / 12) - 1); else
lcd.print(" "); { //note is latched
if (seq_content_type[seq_active_track] > 1) { lcd.setCursor(0, 0);
lcd.setCursor(3, 0); lcd.print("latched note ");
}
if (seq_content_type[seq_active_track] > 1)
{
lcd.setCursor(0, 0);
if (seq_vel[seq_active_track][seq_menu - 1] == 200) lcd.print("Major" ); if (seq_vel[seq_active_track][seq_menu - 1] == 200) lcd.print("Major" );
else if (seq_vel[seq_active_track][seq_menu - 1] == 201) lcd.print("Minor" ); else if (seq_vel[seq_active_track][seq_menu - 1] == 201) lcd.print("Minor" );
else if (seq_vel[seq_active_track][seq_menu - 1] == 202) lcd.print("Seven" ); else if (seq_vel[seq_active_track][seq_menu - 1] == 202) lcd.print("Seven" );
else if (seq_vel[seq_active_track][seq_menu - 1] == 203) lcd.print("Aug " ); else if (seq_vel[seq_active_track][seq_menu - 1] == 203) lcd.print("Aug . " );
else if (seq_vel[seq_active_track][seq_menu - 1] == 204) lcd.print("Dim " ); else if (seq_vel[seq_active_track][seq_menu - 1] == 204) lcd.print("Dim . " );
else if (seq_vel[seq_active_track][seq_menu - 1] == 205) lcd.print("Maj7 " ); else if (seq_vel[seq_active_track][seq_menu - 1] == 205) lcd.print("Maj7 " );
} }
} }
} }
else else
lcd.print(" "); {
lcd.setCursor(0, 0);
lcd.print(" ");
}
} }
} }
if (LCDML.FUNC_close()) // ****** STABLE END ********* if (LCDML.FUNC_close()) // ****** STABLE END *********
@ -4714,6 +4803,25 @@ void arp_refresh_display_play_status()
} }
} }
void UI_func_drum_monitor(uint8_t param)
{
if (LCDML.FUNC_setup()) // ****** SETUP *********
{
encoderDir[ENC_R].reset();
lcd.setCursor(0, 0);
lcd.print(F("Drum Status "));
}
if (LCDML.FUNC_loop()) // ****** LOOP *********
{
;
}
if (LCDML.FUNC_close()) // ****** STABLE END *********
{
encoderDir[ENC_R].reset();
}
}
void UI_func_seq_pattern_editor(uint8_t param) void UI_func_seq_pattern_editor(uint8_t param)
{ {
if (LCDML.FUNC_setup()) // ****** SETUP ********* if (LCDML.FUNC_setup()) // ****** SETUP *********
@ -4821,9 +4929,9 @@ void UI_func_seq_pattern_editor(uint8_t param)
if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up())) if ((LCDML.BT_checkDown() && encoderDir[ENC_R].Down()) || (LCDML.BT_checkUp() && encoderDir[ENC_R].Up()))
{ {
if (LCDML.BT_checkDown()) if (LCDML.BT_checkDown())
temp_int = constrain(temp_int + 1, 0, 115 ); //was 114 temp_int = constrain(temp_int + 1, 0, 115 );
else if (LCDML.BT_checkUp()) else if (LCDML.BT_checkUp())
temp_int = constrain(temp_int - 1, 0, 115 );//was 114 temp_int = constrain(temp_int - 1, 0, 115 );
} }
} }
} else if (seq_active_function == 2) } else if (seq_active_function == 2)
@ -4969,10 +5077,12 @@ void UI_func_seq_pattern_editor(uint8_t param)
{ {
if (seq_active_function != 2) seq_active_function = 2; else seq_active_function = 99; if (seq_active_function != 2) seq_active_function = 2; else seq_active_function = 99;
if (seq_content_type[seq_active_track] == 0) { if (seq_content_type[seq_active_track] == 0)
{
if (activesample < NUM_DRUMSET_CONFIG - 1) if (activesample < NUM_DRUMSET_CONFIG - 1)
lcd.show(0, 1, 6, basename(drum_config[activesample].name)); lcd.show(0, 1, 6, basename(drum_config[activesample].name));
} else { } else
{
if (temp_int < 109) { if (temp_int < 109) {
lcd.setCursor(3, 0); lcd.setCursor(3, 0);
lcd.print(" "); lcd.print(" ");
@ -4983,14 +5093,25 @@ void UI_func_seq_pattern_editor(uint8_t param)
} }
} else if (seq_menu > 2 && seq_menu < 30) } else if (seq_menu > 2 && seq_menu < 30)
{ {
if (seq_active_function == 99) { if (seq_active_function == 99)
if (seq_content_type[seq_active_track] == 0) { //Drumtrack {
seq_data[seq_active_track][seq_menu - 3] = drum_config[activesample].midinote; if (seq_content_type[seq_active_track] == 0)
seq_vel[seq_active_track][seq_menu - 3] = 120; { //Drumtrack
//check if note is already there, if not -> insert it, else remove it from grid.
if (seq_data[seq_active_track][seq_menu - 3] == drum_config[activesample].midinote)
{
seq_data[seq_active_track][seq_menu - 3] = 0;
seq_vel[seq_active_track][seq_menu - 3] = 0;
} else
{
seq_data[seq_active_track][seq_menu - 3] = drum_config[activesample].midinote;
seq_vel[seq_active_track][seq_menu - 3] = 120;
}
} }
else else
{ //Inst. Track { //Inst. Track
if (temp_int == 109) { //clear note if (temp_int == 109 || seq_data[seq_active_track][seq_menu - 3] == temp_int )
{ //clear note
seq_data[seq_active_track][seq_menu - 3] = 0; seq_data[seq_active_track][seq_menu - 3] = 0;
seq_vel[seq_active_track][seq_menu - 3] = 0; seq_vel[seq_active_track][seq_menu - 3] = 0;
} else if (temp_int == 110) { //latch note } else if (temp_int == 110) { //latch note

@ -90,7 +90,7 @@
//************************************************************************************************* //*************************************************************************************************
//* DEBUG OUTPUT SETTINGS //* DEBUG OUTPUT SETTINGS
//************************************************************************************************* //*************************************************************************************************
#define DEBUG 1 //#define DEBUG 1
#define SERIAL_SPEED 230400 #define SERIAL_SPEED 230400
#define SHOW_XRUN 1 #define SHOW_XRUN 1
#define SHOW_CPU_LOAD_MSEC 5000 #define SHOW_CPU_LOAD_MSEC 5000

Loading…
Cancel
Save