29 int LiveLooper::FileResampler::setup(
int _inputRate,
int _outputRate)
32 inputRate = _inputRate;
33 outputRate = _outputRate;
34 if (inputRate == outputRate) {
38 int ret = r_file.setup(inputRate, outputRate, 1, qual);
44 r_file.inp_count = r_file.filtlen() - 1;
46 r_file.inp_data = r_file.out_data = 0;
51 int LiveLooper::FileResampler::run(
int count,
float *input,
float *output)
53 if (inputRate == outputRate) {
54 memcpy(output, input, count*
sizeof(
float));
57 r_file.inp_count = count;
58 r_file.inp_data = input;
59 int m = max_out_count(count);
61 r_file.out_data = output;
63 assert(r_file.inp_count == 0);
64 assert(r_file.out_count <= 1);
65 return m - r_file.out_count;
70 LiveLooper::LiveLooper(ParamMap& param_, sigc::slot<void> sync_,
const string& loop_dir_)
99 name =
N_(
"Live Looper");
101 description =
N_(
"Live Looper");
102 category =
N_(
"Misc");
104 mono_audio = compute_static;
106 set_samplerate = init_static;
107 activate_plugin = activate_static;
108 register_params = register_params_static;
109 load_ui = load_ui_f_static;
110 clear_state = clear_state_f_static;
111 delete_instance = del_instance;
115 LiveLooper::~LiveLooper() {
119 inline void LiveLooper::clear_state_f()
121 for (
int i=0; i<2; i++)
fRec0[i] = 0;
122 for (
int i=0; i<2; i++) iVec0[i] = 0;
123 for (
int i=0; i<tape1_size; i++) tape1[i] = 0;
124 for (
int i=0; i<2; i++) RecSize1[i] = 0;
125 for (
int i=0; i<2; i++)
fRec1[i] = 0;
126 for (
int i=0; i<2; i++) fRec2[i] = 0;
127 for (
int i=0; i<2; i++) iRec3[i] = 0;
128 for (
int i=0; i<2; i++) iRec4[i] = 0;
129 for (
int i=0; i<2; i++) iVec2[i] = 0;
130 for (
int i=0; i<tape2_size; i++) tape2[i] = 0;
131 for (
int i=0; i<2; i++) RecSize2[i] = 0;
132 for (
int i=0; i<2; i++) fRec6[i] = 0;
133 for (
int i=0; i<2; i++) fRec7[i] = 0;
134 for (
int i=0; i<2; i++) iRec8[i] = 0;
135 for (
int i=0; i<2; i++) iRec9[i] = 0;
136 for (
int i=0; i<2; i++) iVec4[i] = 0;
137 for (
int i=0; i<tape3_size; i++) tape3[i] = 0;
138 for (
int i=0; i<2; i++) RecSize3[i] = 0;
139 for (
int i=0; i<2; i++) fRec11[i] = 0;
140 for (
int i=0; i<2; i++) fRec12[i] = 0;
141 for (
int i=0; i<2; i++) iRec13[i] = 0;
142 for (
int i=0; i<2; i++) iRec14[i] = 0;
143 for (
int i=0; i<2; i++) iVec6[i] = 0;
144 for (
int i=0; i<tape4_size; i++) tape4[i] = 0;
145 for (
int i=0; i<2; i++) RecSize4[i] = 0;
146 for (
int i=0; i<2; i++) fRec16[i] = 0;
147 for (
int i=0; i<2; i++) fRec17[i] = 0;
148 for (
int i=0; i<2; i++) iRec18[i] = 0;
149 for (
int i=0; i<2; i++) iRec19[i] = 0;
152 void LiveLooper::clear_state_f_static(
PluginDef *p)
154 static_cast<LiveLooper*
>(p)->clear_state_f();
171 load_file1 =
"tape1";
172 load_file2 =
"tape2";
173 load_file3 =
"tape3";
174 load_file4 =
"tape4";
178 void LiveLooper::init_static(
unsigned int samplingFreq,
PluginDef *p)
180 static_cast<LiveLooper*
>(p)->
init(samplingFreq);
183 void LiveLooper::mem_alloc()
186 if (!tape1) tape1 =
new float[tape1_size];
187 if (!tape2) tape2 =
new float[tape2_size];
188 if (!tape3) tape3 =
new float[tape3_size];
189 if (!tape4) tape4 =
new float[tape4_size];
194 mem_allocated =
true;
198 void LiveLooper::mem_free()
201 mem_allocated =
false;
202 if (tape1) {
delete[] tape1; tape1 = 0; }
203 if (tape2) {
delete[] tape2; tape2 = 0; }
204 if (tape3) {
delete[] tape3; tape3 = 0; }
205 if (tape4) {
delete[] tape4; tape4 = 0; }
208 int LiveLooper::do_resample(
int inrate,
int insize,
float *input,
int maxsize) {
211 getout =
new float[maxsize];
216 smp.run(insize, input, getout);
217 memset(input,0,maxsize*
sizeof(
float));
218 for(
int i = 0; i < maxsize; i++) {
219 input[i] = getout[i];
228 int LiveLooper::do_mono(
int c,
int f,
float *oIn,
float *tape,
int n) {
230 for(
int i = 0; i < (c *f)-c; i+=c) {
231 for(
int j = 0; j < c; j++)
232 tape[p] += oIn[i + j];
240 inline int LiveLooper::load_from_wave(std::string fname,
float **tape,
int tape_size)
247 SNDFILE *sf = sf_open(fname.c_str(),SFM_READ,&sfinfo);
250 _(
"load file %1 "), fname));
251 f = i = sfinfo.frames;
253 r = sfinfo.samplerate;
254 n =
min(tape_size,f*c);
258 i = smp.max_out_count(f);
265 *tape =
new float[i];
272 fSize = sf_read_float(sf,*tape,n);
273 if (res) fSize = do_resample(r, f, *tape, n);
279 oIn =
new float[c * f];
286 i = smp.max_out_count(f);
293 *tape =
new float[i];
300 sf_read_float(sf, oIn, c * f);
301 memset(*tape,0,n*
sizeof(
float));
302 int p = do_mono(c, f, oIn, *tape, n);
304 _(
"mix down to mono file %1 "), fname));
306 if (res) p = do_resample(r, p, *tape, n);
314 inline void LiveLooper::load_array(std::string name)
316 RecSize1[1] = load_from_wave(loop_dir+name+
"1.wav", &tape1, tape1_size);
317 tape1_size =
max(4194304,RecSize1[1]);
318 IOTAR1= RecSize1[1] - int(RecSize1[1]*(100-fclips1)*0.01);
320 RecSize2[1] = load_from_wave(loop_dir+name+
"2.wav", &tape2, tape2_size);
321 tape2_size =
max(4194304,RecSize2[1]);
322 IOTAR2= RecSize2[1] - int(RecSize2[1]*(100-fclips2)*0.01);
324 RecSize3[1] = load_from_wave(loop_dir+name+
"3.wav", &tape3, tape3_size);
325 tape3_size =
max(4194304,RecSize3[1]);
326 IOTAR3= RecSize3[1] - int(RecSize3[1]*(100-fclips3)*0.01);
328 RecSize4[1] = load_from_wave(loop_dir+name+
"4.wav", &tape4, tape4_size);
329 tape4_size =
max(4194304,RecSize4[1]);
330 IOTAR4= RecSize4[1] - int(RecSize4[1]*(100-fclips4)*0.01);
332 cur_name = preset_name;
335 inline void LiveLooper::save_to_wave(std::string fname,
float *tape,
float fSize,
int tape_size)
340 sfinfo.format = SF_FORMAT_WAV | SF_FORMAT_FLOAT;
342 SNDFILE * sf = sf_open(fname.c_str(), SFM_WRITE, &sfinfo);
344 size_t lSize = tape_size - int(fSize/
fConst2);
345 sf_write_float(sf,tape, lSize);
351 inline void LiveLooper::save_array(std::string name)
353 if (name.compare(
"tape")==0 || save_p) {
355 save_to_wave(loop_dir+name+
"1.wav",tape1,rectime0, tape1_size);
359 save_to_wave(loop_dir+name+
"2.wav",tape2,rectime1, tape2_size);
363 save_to_wave(loop_dir+name+
"3.wav",tape3,rectime2, tape3_size);
367 save_to_wave(loop_dir+name+
"4.wav",tape4,rectime3, tape4_size);
373 int LiveLooper::activate(
bool start)
376 if (!mem_allocated) {
379 load_array(preset_name);
381 }
else if (mem_allocated) {
382 save_array(cur_name);
384 load_file1 =
"tape1";
385 load_file2 =
"tape2";
386 load_file3 =
"tape3";
387 load_file4 =
"tape4";
392 int LiveLooper::activate_static(
bool start,
PluginDef *p)
394 return static_cast<LiveLooper*
>(p)->activate(start);
397 void LiveLooper::load_tape1() {
398 if (!load_file1.empty()) {
401 if (cur_name.compare(
"tape")==0 || save_p) {
403 save_to_wave(loop_dir+cur_name+
"1.wav",tape1,rectime0, tape1_size);
407 RecSize1[1] = load_from_wave(load_file1, &tape1, tape1_size);
408 tape1_size =
max(4194304,RecSize1[1]);
409 IOTAR1= RecSize1[1] - int(RecSize1[1]*(100-fclips1)*0.01);
411 load_file1 =
"tape1";
416 void LiveLooper::load_tape2() {
417 if (!load_file2.empty()) {
420 if (cur_name.compare(
"tape")==0 || save_p) {
422 save_to_wave(loop_dir+cur_name+
"2.wav",tape2,rectime1,tape2_size);
426 RecSize2[1] = load_from_wave(load_file2, &tape2, tape2_size);
427 tape2_size =
max(4194304,RecSize2[1]);
428 IOTAR2= RecSize2[1] - int(RecSize2[1]*(100-fclips2)*0.01);
430 load_file2 =
"tape2";
435 void LiveLooper::load_tape3() {
436 if (!load_file3.empty()) {
439 if (cur_name.compare(
"tape")==0 || save_p) {
441 save_to_wave(loop_dir+cur_name+
"3.wav",tape3,rectime2,tape3_size);
445 RecSize3[1] = load_from_wave(load_file3, &tape3, tape3_size);
446 tape3_size =
max(4194304,RecSize3[1]);
447 IOTAR3= RecSize3[1] - int(RecSize3[1]*(100-fclips3)*0.01);
449 load_file3 =
"tape3";
454 void LiveLooper::load_tape4() {
455 if (!load_file4.empty()) {
458 if (cur_name.compare(
"tape")==0 || save_p) {
460 save_to_wave(loop_dir+cur_name+
"4.wav",tape4,rectime3,tape4_size);
464 RecSize4[1] = load_from_wave(load_file4, &tape4, tape4_size);
465 tape4_size =
max(4194304,RecSize4[1]);
466 IOTAR4= RecSize4[1] - int(RecSize4[1]*(100-fclips4)*0.01);
468 load_file4 =
"tape4";
473 void LiveLooper::set_p_state() {
483 cur_name = preset_name;
494 void LiveLooper::play_all_tapes() {
495 play1=play2=play3=play4=play_all;
501 memcpy(output0, input0, count *
sizeof(
float));
505 if(record1 || reset1) save1 =
true;
506 if(record2 || reset2) save2 =
true;
507 if(record3 || reset3) save3 =
true;
508 if(record4 || reset4) save4 =
true;
510 if (rplay1 && !RP1) {play1 = 0.0;RP1=
true;}
511 else if (play1 && RP1) {rplay1 = 0.0;RP1=
false;}
512 if (rplay2 && !RP2) {play2 = 0.0;RP2=
true;}
513 else if (play2 && RP2) {rplay2 = 0.0;RP2=
false;}
514 if (rplay3 && !RP3) {play3 = 0.0;RP3=
true;}
515 else if (play3 && RP3) {rplay3 = 0.0;RP3=
false;}
516 if (rplay4 && !RP4) {play4 = 0.0;RP4=
true;}
517 else if (play4 && RP4) {rplay4 = 0.0;RP4=
false;}
519 record1 = rectime0? record1 : 0.0;
520 record2 = rectime1? record2 : 0.0;
521 record3 = rectime2? record3 : 0.0;
522 record4 = rectime3? record4 : 0.0;
524 if (reset1) {fclip1=100.0;fclips1=0.0;}
525 if (reset2) {fclip2=100.0;fclips2=0.0;}
526 if (reset3) {fclip3=100.0;fclips3=0.0;}
527 if (reset4) {fclip4=100.0;fclips4=0.0;}
529 reset1 = (rectime0 < tape1_size*
fConst2)? reset1 : 0.0;
530 reset2 = (rectime1 < tape2_size*
fConst2)? reset2 : 0.0;
531 reset3 = (rectime2 < tape3_size*
fConst2)? reset3 : 0.0;
532 reset4 = (rectime3 < tape4_size*
fConst2)? reset4 : 0.0;
535 float ph1 = RecSize1[0] ? 1.0/(RecSize1[0] * 0.001) : 0.0;
536 playh1 = (1-iVec0[0]) * fmin(1000,fmax(0,
float(IOTAR1*ph1)));
537 float ph2 = RecSize2[0] ? 1.0/(RecSize2[0] * 0.001) : 0.0;
538 playh2 = (1-iVec2[0]) * fmin(1000,fmax(0,
float(IOTAR2*ph2)));
539 float ph3 = RecSize3[0] ? 1.0/(RecSize3[0] * 0.001) : 0.0;
540 playh3 = (1-iVec4[0]) * fmin(1000,fmax(0,
float(IOTAR3*ph3)));
541 float ph4 = RecSize4[0] ? 1.0/(RecSize4[0] * 0.001) : 0.0;
542 playh4 = (1-iVec6[0]) * fmin(1000,fmax(0,
float(IOTAR4*ph4)));
544 float speed1 = fspeed1;
545 float speed2 = fspeed2;
546 float speed3 = fspeed3;
547 float speed4 = fspeed4;
549 float fSlow0 = (0.0010000000000000009f * powf(10,(0.05f * gain)));
550 float fSlow1 = gain_out;
551 int iSlow3 = int(record1);
552 int iSlow4 = int((1 - reset1));
553 float fSlow5 = (((1 - iSlow3) * gain1) * (play1+rplay1));
554 int iSlow6 = int(record2);
555 int iSlow7 = int((1 - reset2));
556 float fSlow8 = (((1 - iSlow6) * gain2) * (play2+rplay2));
557 int iSlow9 = int(record3);
558 int iSlow10 = int((1 - reset3));
559 float fSlow11 = (((1 - iSlow9) * gain3) * (play3+rplay3));
560 int iSlow12 = int(record4);
561 int iSlow13 = int((1 - reset4));
562 float fSlow14 = (((1 - iSlow12) * gain4) * (play4+rplay4));
563 float fSlow15 = (0.0001f * fSlow1);
564 float iClip1 = fclip1*0.01;
565 float iClip2 = fclip2*0.01;
566 float iClip3 = fclip3*0.01;
567 float iClip4 = fclip4*0.01;
568 float iClips1 = (100-fclips1)*0.01;
569 float iClips2 = (100-fclips2)*0.01;
570 float iClips3 = (100-fclips3)*0.01;
571 float iClips4 = (100-fclips4)*0.01;
573 for (
int i=0; i<count; i++) {
575 float fTemp0 = ((float)input0[i] *
fRec0[0]);
577 float fTemp1 = (iSlow3 * fTemp0);
578 RecSize1[0] = fmin(tape1_size, (
int)(iSlow4 * (((iSlow3 - iVec0[1]) <= 0) * (iSlow3 + RecSize1[1]))));
579 int iTemp2 = (tape1_size - RecSize1[0]);
581 int iTemp3 = fmin(tape1_size-1, (
int)(tape1_size - iTemp2));
583 IOTA1 = IOTA1>int(iTemp3*iClip1)? iTemp3 - int(iTemp3*iClips1):IOTA1+1;
584 tape1[IOTA1] = fTemp1;
587 IOTAR1 = IOTAR1-speed1< (iTemp3 - int(iTemp3*iClips1))?
int(iTemp3*iClip1):(IOTAR1-speed1)-1;
589 IOTAR1 = IOTAR1+speed1>int(iTemp3*iClip1)? iTemp3 - int(iTemp3*iClips1):(IOTAR1+speed1)+1;
592 float fTemp4 = ((int((
fRec1[1] != 0.0f)))?((
int(((fRec2[1] > 0.0f) & (fRec2[1] < 1.0f))))?
fRec1[1]:0):((
int(((fRec2[1] == 0.0f) & (iTemp3 != iRec3[1]))))?
fConst0:((int(((fRec2[1] == 1.0f) & (iTemp3 != iRec4[1]))))?
fConst1:0)));
594 fRec2[0] = fmax(0.0f, fmin(1.0f, (fRec2[1] + fTemp4)));
595 iRec3[0] = ((int(((fRec2[1] >= 1.0f) & (iRec4[1] != iTemp3))))?iTemp3:iRec3[1]);
596 iRec4[0] = ((int(((fRec2[1] <= 0.0f) & (iRec3[1] != iTemp3))))?iTemp3:iRec4[1]);
598 float fTemp5 = (iSlow6 * fTemp0);
599 RecSize2[0] = fmin(tape2_size, (
int)(iSlow7 * (((iSlow6 - iVec2[1]) <= 0) * (iSlow6 + RecSize2[1]))));
600 int iTemp6 = (tape2_size - RecSize2[0]);
602 int iTemp7 = fmin(tape2_size-1, (
int)(tape2_size - iTemp6));
604 IOTA2 = IOTA2>int(iTemp7*iClip2)? iTemp7 - int(iTemp7*iClips2):IOTA2+1;
605 tape2[IOTA2] = fTemp5;
608 IOTAR2 = IOTAR2-speed2< (iTemp7 - int(iTemp7*iClips2))?
int(iTemp7*iClip2):(IOTAR2-speed2)-1;
610 IOTAR2 = IOTAR2+speed2>int(iTemp7*iClip2)? iTemp7 - int(iTemp7*iClips2):(IOTAR2+speed2)+1;
613 float fTemp8 = ((int((fRec6[1] != 0.0f)))?((
int(((fRec7[1] > 0.0f) & (fRec7[1] < 1.0f))))?fRec6[1]:0):((
int(((fRec7[1] == 0.0f) & (iTemp7 != iRec8[1]))))?
fConst0:((int(((fRec7[1] == 1.0f) & (iTemp7 != iRec9[1]))))?
fConst1:0)));
615 fRec7[0] = fmax(0.0f, fmin(1.0f, (fRec7[1] + fTemp8)));
616 iRec8[0] = ((int(((fRec7[1] >= 1.0f) & (iRec9[1] != iTemp7))))?iTemp7:iRec8[1]);
617 iRec9[0] = ((int(((fRec7[1] <= 0.0f) & (iRec8[1] != iTemp7))))?iTemp7:iRec9[1]);
619 float fTemp9 = (iSlow9 * fTemp0);
620 RecSize3[0] = fmin(tape3_size, (
int)(iSlow10 * (((iSlow9 - iVec4[1]) <= 0) * (iSlow9 + RecSize3[1]))));
621 int iTemp10 = (tape3_size - RecSize3[0]);
623 int iTemp11 = fmin(tape3_size-1, (
int)(tape3_size - iTemp10));
625 IOTA3 = IOTA3>int(iTemp11*iClip3)? iTemp11 - int(iTemp11*iClips3):IOTA3+1;
626 tape3[IOTA3] = fTemp9;
629 IOTAR3 = IOTAR3-speed3< (iTemp11 - int(iTemp11*iClips3))?
int(iTemp11*iClip3):(IOTAR3-speed3)-1;
631 IOTAR3 = IOTAR3+speed3>int(iTemp11*iClip3)? iTemp11 - int(iTemp11*iClips3):(IOTAR3+speed3)+1;
634 float fTemp12 = ((int((fRec11[1] != 0.0f)))?((
int(((fRec12[1] > 0.0f) & (fRec12[1] < 1.0f))))?fRec11[1]:0):((
int(((fRec12[1] == 0.0f) & (iTemp11 != iRec13[1]))))?
fConst0:((int(((fRec12[1] == 1.0f) & (iTemp11 != iRec14[1]))))?
fConst1:0)));
636 fRec12[0] = fmax(0.0f, fmin(1.0f, (fRec12[1] + fTemp12)));
637 iRec13[0] = ((int(((fRec12[1] >= 1.0f) & (iRec14[1] != iTemp11))))?iTemp11:iRec13[1]);
638 iRec14[0] = ((int(((fRec12[1] <= 0.0f) & (iRec13[1] != iTemp11))))?iTemp11:iRec14[1]);
640 float fTemp13 = (iSlow12 * fTemp0);
641 RecSize4[0] = fmin(tape4_size, (
int)(iSlow13 * (((iSlow12 - iVec6[1]) <= 0) * (iSlow12 + RecSize4[1]))));
642 int iTemp14 = (tape4_size - RecSize4[0]);
644 int iTemp15 = fmin(tape4_size-1, (
int)(tape4_size - iTemp14));
646 IOTA4 = IOTA4>int(iTemp15*iClip4)? iTemp15 - int(iTemp15*iClips4):IOTA4+1;
647 tape4[IOTA4] = fTemp13;
650 IOTAR4 = IOTAR4-speed4< (iTemp15 - int(iTemp15*iClips4))?
int(iTemp15*iClip4):(IOTAR4-speed4)-1;
652 IOTAR4 = IOTAR4+speed4>int(iTemp15*iClip4)? iTemp15 - int(iTemp15*iClips4):(IOTAR4+speed4)+1;
655 float fTemp16 = ((int((fRec16[1] != 0.0f)))?((
int(((fRec17[1] > 0.0f) & (fRec17[1] < 1.0f))))?fRec16[1]:0):((
int(((fRec17[1] == 0.0f) & (iTemp15 != iRec18[1]))))?
fConst0:((int(((fRec17[1] == 1.0f) & (iTemp15 != iRec19[1]))))?
fConst1:0)));
657 fRec17[0] = fmax(0.0f, fmin(1.0f, (fRec17[1] + fTemp16)));
658 iRec18[0] = ((int(((fRec17[1] >= 1.0f) & (iRec19[1] != iTemp15))))?iTemp15:iRec18[1]);
659 iRec19[0] = ((int(((fRec17[1] <= 0.0f) & (iRec18[1] != iTemp15))))?iTemp15:iRec19[1]);
660 output0[i] = (float)((fSlow15 * ((fSlow14 * ((fRec17[0] * tape4[
int(IOTAR4)]) + ((1.0f - fRec17[0]) * tape4[
int(IOTAR4)]))) + ((fSlow11 * ((fRec12[0] * tape3[int(IOTAR3)]) + ((1.0f - fRec12[0]) * tape3[int(IOTAR3)]))) + ((fSlow8 * ((fRec7[0] * tape2[
int(IOTAR2)]) + ((1.0f - fRec7[0]) * tape2[
int(IOTAR2)]))) + (fSlow5 * ((fRec2[0] * tape1[
int(IOTAR1)]) + ((1.0f - fRec2[0]) * tape1[int(IOTAR1)]))))))) + (fTemp0));
662 iRec19[1] = iRec19[0];
663 iRec18[1] = iRec18[0];
664 fRec17[1] = fRec17[0];
665 fRec16[1] = fRec16[0];
666 RecSize4[1] = RecSize4[0];
668 iRec14[1] = iRec14[0];
669 iRec13[1] = iRec13[0];
670 fRec12[1] = fRec12[0];
671 fRec11[1] = fRec11[0];
672 RecSize3[1] = RecSize3[0];
678 RecSize2[1] = RecSize2[0];
684 RecSize1[1] = RecSize1[0];
690 void __rt_func LiveLooper::compute_static(
int count,
float *input0,
float *output0,
PluginDef *p)
692 static_cast<LiveLooper*
>(p)->
compute(count, input0, output0);
695 int LiveLooper::register_par(
const ParamReg& reg)
697 reg.
registerVar(
"dubber.clip1",
"",
"S",
N_(
"percentage clip at the delay length "),&fclip1, 1e+02f, 0.0f, 1e+02f, 1.0f);
698 reg.
registerVar(
"dubber.clip2",
"",
"S",
N_(
"percentage clip at the delay length "),&fclip2, 1e+02f, 0.0f, 1e+02f, 1.0f);
699 reg.
registerVar(
"dubber.clip3",
"",
"S",
N_(
"percentage clip at the delay length "),&fclip3, 1e+02f, 0.0f, 1e+02f, 1.0f);
700 reg.
registerVar(
"dubber.clip4",
"",
"S",
N_(
"percentage clip at the delay length "),&fclip4, 1e+02f, 0.0f, 1e+02f, 1.0f);
701 reg.
registerVar(
"dubber.clips1",
"",
"S",
N_(
"percentage cut on the delay start "),&fclips1, 0.0f, 0.0f, 1e+02f, 1.0f);
702 reg.
registerVar(
"dubber.clips2",
"",
"S",
N_(
"percentage cut on the delay start "),&fclips2, 0.0f, 0.0f, 1e+02f, 1.0f);
703 reg.
registerVar(
"dubber.clips3",
"",
"S",
N_(
"percentage cut on the delay start "),&fclips3, 0.0f, 0.0f, 1e+02f, 1.0f);
704 reg.
registerVar(
"dubber.clips4",
"",
"S",
N_(
"percentage cut on the delay start "),&fclips4, 0.0f, 0.0f, 1e+02f, 1.0f);
705 reg.
registerVar(
"dubber.speed1",
"",
"S",
N_(
"playback speed "),&fspeed1, 0.0f, -0.9f, 0.9f, 0.01f);
706 reg.
registerVar(
"dubber.speed2",
"",
"S",
N_(
"playback speed "),&fspeed2, 0.0f, -0.9f, 0.9f, 0.01f);
707 reg.
registerVar(
"dubber.speed3",
"",
"S",
N_(
"playback speed "),&fspeed3, 0.0f, -0.9f, 0.9f, 0.01f);
708 reg.
registerVar(
"dubber.speed4",
"",
"S",
N_(
"playback speed "),&fspeed4, 0.0f, -0.9f, 0.9f, 0.01f);
713 reg.
registerVar(
"dubber.gain",
"",
"S",
N_(
"overall gain of the input"),&gain, 0.0f, -2e+01f, 12.0f, 0.1f);
714 reg.
registerVar(
"dubber.level1",
"",
"S",
N_(
"percentage of the delay gain level"),&gain1, 5e+01f, 0.0f, 1e+02f, 1.0f);
715 reg.
registerVar(
"dubber.level2",
"",
"S",
N_(
"percentage of the delay gain level"),&gain2, 5e+01f, 0.0f, 1e+02f, 1.0f);
716 reg.
registerVar(
"dubber.level3",
"",
"S",
N_(
"percentage of the delay gain level"),&gain3, 5e+01f, 0.0f, 1e+02f, 1.0f);
717 reg.
registerVar(
"dubber.level4",
"",
"S",
N_(
"percentage of the delay gain level"),&gain4, 5e+01f, 0.0f, 1e+02f, 1.0f);
718 reg.
registerVar(
"dubber.mix",
"",
"S",
N_(
"overall gain_out of the delay line in percent"),&gain_out, 1e+02f, 0.0f, 1.5e+02f, 1.0f);
719 reg.
registerVar(
"dubber.play1",
"",
"B",
N_(
"play tape 1"),&play1, 0.0, 0.0, 1.0, 1.0);
720 reg.
registerVar(
"dubber.play2",
"",
"B",
N_(
"play tape 2"),&play2, 0.0, 0.0, 1.0, 1.0);
721 reg.
registerVar(
"dubber.play3",
"",
"B",
N_(
"play tape 3"),&play3, 0.0, 0.0, 1.0, 1.0);
722 reg.
registerVar(
"dubber.play4",
"",
"B",
N_(
"play tape 4"),&play4, 0.0, 0.0, 1.0, 1.0);
723 reg.
registerVar(
"dubber.rplay1",
"",
"B",
N_(
"play reverse"),&rplay1, 0.0, 0.0, 1.0, 1.0);
724 reg.
registerVar(
"dubber.rplay2",
"",
"B",
N_(
"play reverse"),&rplay2, 0.0, 0.0, 1.0, 1.0);
725 reg.
registerVar(
"dubber.rplay3",
"",
"B",
N_(
"play reverse"),&rplay3, 0.0, 0.0, 1.0, 1.0);
726 reg.
registerVar(
"dubber.rplay4",
"",
"B",
N_(
"play reverse"),&rplay4, 0.0, 0.0, 1.0, 1.0);
731 reg.
registerVar(
"dubber.rec1",
"",
"B",
N_(
"record"),&record1, 0.0, 0.0, 1.0, 1.0);
732 reg.
registerVar(
"dubber.rec2",
"",
"B",
N_(
"record"),&record2, 0.0, 0.0, 1.0, 1.0);
733 reg.
registerVar(
"dubber.rec3",
"",
"B",
N_(
"record"),&record3, 0.0, 0.0, 1.0, 1.0);
734 reg.
registerVar(
"dubber.rec4",
"",
"B",
N_(
"record"),&record4, 0.0, 0.0, 1.0, 1.0);
735 reg.
registerVar(
"dubber.reset1",
"",
"B",
N_(
"erase"),&reset1, 0.0, 0.0, 1.0, 1.0);
736 reg.
registerVar(
"dubber.reset2",
"",
"B",
N_(
"erase"),&reset2, 0.0, 0.0, 1.0, 1.0);
737 reg.
registerVar(
"dubber.reset3",
"",
"B",
N_(
"erase"),&reset3, 0.0, 0.0, 1.0, 1.0);
738 reg.
registerVar(
"dubber.reset4",
"",
"B",
N_(
"erase"),&reset4, 0.0, 0.0, 1.0, 1.0);
739 reg.
registerVar(
"dubber.load1",
"",
"B",
N_(
"import file"),&load1, 0.0, 0.0, 1.0, 1.0);
740 reg.
registerVar(
"dubber.load2",
"",
"B",
N_(
"import file"),&load2, 0.0, 0.0, 1.0, 1.0);
741 reg.
registerVar(
"dubber.load3",
"",
"B",
N_(
"import file"),&load3, 0.0, 0.0, 1.0, 1.0);
742 reg.
registerVar(
"dubber.load4",
"",
"B",
N_(
"import file"),&load4, 0.0, 0.0, 1.0, 1.0);
743 reg.
registerVar(
"dubber.playall",
"",
"B",
N_(
"play all tapes "),&play_all, 0.0, 0.0, 1.0, 1.0);
744 param[
"dubber.playall"].signal_changed_float().connect(
745 sigc::hide(sigc::mem_fun(
this, &LiveLooper::play_all_tapes)));
746 param.reg_non_midi_par(
"dubber.savefile", &save_p,
false);
747 param.reg_preset_string(
"dubber.filename",
"", &preset_name,
"tape");
748 param[
"dubber.filename"].signal_changed_string().connect(
749 sigc::hide(sigc::mem_fun(
this, &LiveLooper::set_p_state)));
750 param.reg_string(
"dubber.loadfile1",
"", &load_file1,
"tape1");
751 param.reg_string(
"dubber.loadfile2",
"", &load_file2,
"tape2");
752 param.reg_string(
"dubber.loadfile3",
"", &load_file3,
"tape3");
753 param.reg_string(
"dubber.loadfile4",
"", &load_file4,
"tape4");
754 param[
"dubber.loadfile1"].signal_changed_string().connect(
755 sigc::hide(sigc::mem_fun(
this, &LiveLooper::load_tape1)));
756 param[
"dubber.loadfile2"].signal_changed_string().connect(
757 sigc::hide(sigc::mem_fun(
this, &LiveLooper::load_tape2)));
758 param[
"dubber.loadfile3"].signal_changed_string().connect(
759 sigc::hide(sigc::mem_fun(
this, &LiveLooper::load_tape3)));
760 param[
"dubber.loadfile4"].signal_changed_string().connect(
761 sigc::hide(sigc::mem_fun(
this, &LiveLooper::load_tape4)));
765 int LiveLooper::register_params_static(
const ParamReg& reg)
767 return static_cast<LiveLooper*
>(reg.
plugin)->register_par(reg);
770 inline int LiveLooper::load_ui_f(
const UiBuilder& b,
int form)
773 #define PARAM(p) ("dubber" "." p) 951 int LiveLooper::load_ui_f_static(
const UiBuilder& b,
int form)
953 return static_cast<LiveLooper*
>(b.
plugin)->load_ui_f(b, form);
956 void LiveLooper::del_instance(
PluginDef *p)
958 delete static_cast<LiveLooper*
>(p);
void gx_print_info(const char *, const std::string &)
CmdConnection::msg_type start
void(* create_fload_switch)(const char *sw_type, const char *id, const char *idf)
void(* openTabBox)(const char *label)
void(* create_feedback_switch)(const char *sw_type, const char *id)
float *(* registerVar)(const char *id, const char *name, const char *tp, const char *tooltip, float *var, float val, float low, float up, float step)
void(* create_switch_no_caption)(const char *sw_type, const char *id)
void(* create_p_display)(const char *id, const char *idl, const char *idh)
int atomic_get(volatile int &p)
void gx_print_error(const char *, const std::string &)
#define PLUGINDEF_VERSION
void(* openHorizontalBox)(const char *label)
void(* create_port_display)(const char *id, const char *label)
void(* create_small_rackknobr)(const char *id, const char *label)
void(* create_mid_rackknob)(const char *id, const char *label)
void(* openHorizontalhideBox)(const char *label)
void(* create_feedback_slider)(const char *id, const char *label)
void atomic_set(volatile int *p, int v)
void(* registerNonMidiFloatVar)(const char *id, float *var, bool preset, bool nosave, float val, float low, float up, float step)
void(* create_master_slider)(const char *id, const char *label)
void(* openVerticalBox)(const char *label)