1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <math.h>
#include <qwidget.h>
#include <qstring.h>
#include <qslider.h>
#include <qcheckbox.h>
#include <qlabel.h>
#include <qvbox.h>
#include <qhbox.h>
#include <qspinbox.h>
#include <qradiobutton.h>
#include <qpushbutton.h>
#include <qdialog.h>
#include <qpainter.h>
#include <alsa/asoundlib.h>
#include "synthdata.h"
#include "m_delay.h"
#include "port.h"
M_delay::M_delay(QWidget* parent, const char *name, SynthData *p_synthdata)
: Module(1, parent, name, p_synthdata) {
QString qs;
int l1;
M_type = M_type_delay;
setGeometry(MODULE_NEW_X, MODULE_NEW_Y, MODULE_DELAY_WIDTH, MODULE_DELAY_HEIGHT);
port_M_in = new Port("In", PORT_IN, 0, this, synthdata);
port_M_in->move(0, 35);
port_M_in->outTypeAcceptList.append(outType_audio);
portList.append(port_M_in);
port_out = new Port("Out", PORT_OUT, 0, this, synthdata);
port_out->move(width() - port_out->width(), 55);
port_out->outType = outType_audio;
portList.append(port_out);
qs.sprintf("Delay ID %d", moduleID);
configDialog->setCaption(qs);
configDialog->addSlider(0, 10, delay, "Delay", &delay);
buf = (float **)malloc(synthdata->poly * sizeof(float *));
for (l1 = 0; l1 < synthdata->poly; l1++) {
buf[l1] = (float *)malloc(MAX_DELAY_FRAMES * sizeof(float));
memset(buf[l1], 0, MAX_DELAY_FRAMES * sizeof(float));
}
read_ofs = 0;
}
M_delay::~M_delay() {
int l1;
for (l1 = 0; l1 < synthdata->poly; l1++) {
free(buf[l1]);
}
free(buf);
}
void M_delay::generateCycle() {
int l1, l2, ofs, delay_frames;
if (!cycleReady) {
cycleProcessing = true;
inData = port_M_in->getinputdata();
delay_frames = (int)((float)(MAX_DELAY_FRAMES - 3) * delay / 10.0);
for (l2 = 0; l2 < synthdata->cyclesize; l2++) {
for (l1 = 0; l1 < synthdata->poly; l1++) {
buf[l1][read_ofs] = inData[l1][l2];
ofs = read_ofs - delay_frames;
if (ofs < 0) ofs += MAX_DELAY_FRAMES;
data[0][l1][l2] = buf[l1][ofs];
}
read_ofs++;
if (read_ofs >= MAX_DELAY_FRAMES) read_ofs = 0;
}
}
cycleProcessing = false;
cycleReady = true;
}
void M_delay::showConfigDialog() {
}
|