mirror of https://github.com/EspoTek/Labrador.git
235 lines
6.9 KiB
C++
235 lines
6.9 KiB
C++
|
#include "functiongencontrol.h"
|
||
|
#include "platformspecific.h"
|
||
|
|
||
|
|
||
|
functionGenControl::functionGenControl(QWidget *parent) : QLabel(parent)
|
||
|
{
|
||
|
this->hide();
|
||
|
samples_CH1 = (unsigned char *) malloc(0);
|
||
|
samples_CH2 = (unsigned char *) malloc(0);
|
||
|
|
||
|
}
|
||
|
|
||
|
void functionGenControl::waveformName_CH1(QString newName)
|
||
|
{
|
||
|
qDebug() << "newName = " << newName;
|
||
|
newName.append(".tlw");
|
||
|
|
||
|
//QDir *dir = new QDir();
|
||
|
//QString directory = dir->currentPath();
|
||
|
|
||
|
#ifdef PLATFORM_ANDROID
|
||
|
QString waveformFilePath("assets:/waveforms/");
|
||
|
waveformFilePath.append(newName);
|
||
|
|
||
|
QFile fptr(waveformFilePath);
|
||
|
bool success = fptr.open(QIODevice::ReadOnly);
|
||
|
|
||
|
QByteArray line;
|
||
|
char lengthString[16];
|
||
|
char divisibilityString[16];
|
||
|
|
||
|
line = fptr.readLine();
|
||
|
strcpy(lengthString, line.data());
|
||
|
sscanf(lengthString, "%d", &length_CH1);
|
||
|
qDebug() << "lengthString" << lengthString;
|
||
|
|
||
|
line = fptr.readLine();
|
||
|
strcpy(divisibilityString, line.data());
|
||
|
sscanf(divisibilityString, "%d", &divisibility_CH1);
|
||
|
qDebug() << "divisibilityString" << divisibilityString;
|
||
|
|
||
|
qDebug() << "Length = " << length_CH1;
|
||
|
qDebug() << "Divisibility = " << divisibility_CH1;
|
||
|
|
||
|
QByteArray remainingData = fptr.readAll();
|
||
|
char *dataString = remainingData.data();
|
||
|
|
||
|
free(samples_CH1);
|
||
|
samples_CH1 = (unsigned char *) malloc(length_CH1);
|
||
|
|
||
|
int dummy;
|
||
|
char *dataStringCurrent = dataString;
|
||
|
for (int i=0;i<length_CH1;i++){
|
||
|
sscanf(dataStringCurrent, "%d", &dummy);
|
||
|
dataStringCurrent += strcspn(dataStringCurrent, "\t") + 1;
|
||
|
samples_CH1[i] = (unsigned char) dummy;
|
||
|
}
|
||
|
|
||
|
#else
|
||
|
QString directory = QCoreApplication::applicationDirPath();
|
||
|
|
||
|
directory.append("/waveforms/");
|
||
|
directory.append(newName);
|
||
|
QByteArray temp = directory.toLocal8Bit();
|
||
|
char *fileName = temp.data();
|
||
|
|
||
|
qDebug() << "opening" << fileName;
|
||
|
FILE *fptr = fopen(fileName, "r");
|
||
|
if (fptr==NULL){
|
||
|
qFatal("%s could not be opened!", fileName);
|
||
|
}
|
||
|
|
||
|
char lengthString[6];
|
||
|
fgets(lengthString, 5, fptr);
|
||
|
qDebug() << lengthString;
|
||
|
sscanf(lengthString, "%d", &length_CH1);
|
||
|
|
||
|
char divisibilityString[6];
|
||
|
//Bit of bullshit to deal with CRLF line endings on Mac.
|
||
|
do fgets(divisibilityString, 5, fptr);
|
||
|
while ((divisibilityString[0] == '\r') || (divisibilityString[0] == '\n'));
|
||
|
sscanf(divisibilityString, "%d", &divisibility_CH1);
|
||
|
|
||
|
qDebug() << "Length = " << length_CH1;
|
||
|
qDebug() << "Divisibility = " << divisibility_CH1;
|
||
|
|
||
|
free(samples_CH1);
|
||
|
samples_CH1 = (unsigned char *) malloc(length_CH1);
|
||
|
|
||
|
char *dataString = (char *) malloc(length_CH1*5+1);
|
||
|
fgets(dataString, length_CH1*5+1, fptr);
|
||
|
|
||
|
int dummy;
|
||
|
char *dataStringCurrent = dataString;
|
||
|
for (int i=0;i<length_CH1;i++){
|
||
|
sscanf(dataStringCurrent, "%d", &dummy);
|
||
|
dataStringCurrent += strcspn(dataStringCurrent, "\t") + 1;
|
||
|
samples_CH1[i] = (unsigned char) dummy;
|
||
|
}
|
||
|
|
||
|
free(dataString);
|
||
|
fclose(fptr);
|
||
|
#endif
|
||
|
setMaxFreq_CH1(DAC_SPS/(length_CH1>>(divisibility_CH1-1)));
|
||
|
setMinFreq_CH1((double) CLOCK_FREQ/1024/65535/length_CH1);
|
||
|
functionGenToUpdate(0, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::freqUpdate_CH1(double newFreq){
|
||
|
qDebug() << "newFreq = " << newFreq;
|
||
|
freq_CH1 = newFreq;
|
||
|
functionGenToUpdate(0, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::amplitudeUpdate_CH1(double newAmplitude){
|
||
|
qDebug() << "newAmplitude = " << newAmplitude;
|
||
|
amplitude_CH1 = newAmplitude;
|
||
|
functionGenToUpdate(0, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::offsetUpdate_CH1(double newOffset){
|
||
|
qDebug() << "newOffset = " << newOffset;
|
||
|
offset_CH1 = newOffset;
|
||
|
functionGenToUpdate(0, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::waveformName_CH2(QString newName)
|
||
|
{
|
||
|
qDebug() << "newName = " << newName;
|
||
|
newName.append(".tlw");
|
||
|
|
||
|
#ifdef PLATFORM_ANDROID
|
||
|
QString waveformFilePath("assets:/waveforms/");
|
||
|
waveformFilePath.append(newName);
|
||
|
|
||
|
QFile fptr(waveformFilePath);
|
||
|
bool success = fptr.open(QIODevice::ReadOnly);
|
||
|
|
||
|
QByteArray line;
|
||
|
char lengthString[16];
|
||
|
char divisibilityString[16];
|
||
|
|
||
|
line = fptr.readLine();
|
||
|
strcpy(lengthString, line.data());
|
||
|
sscanf(lengthString, "%d", &length_CH2);
|
||
|
qDebug() << "lengthString" << lengthString;
|
||
|
|
||
|
line = fptr.readLine();
|
||
|
strcpy(divisibilityString, line.data());
|
||
|
sscanf(divisibilityString, "%d", &divisibility_CH2);
|
||
|
qDebug() << "divisibilityString" << divisibilityString;
|
||
|
|
||
|
qDebug() << "Length = " << length_CH2;
|
||
|
qDebug() << "Divisibility = " << divisibility_CH2;
|
||
|
|
||
|
QByteArray remainingData = fptr.readAll();
|
||
|
char *dataString = remainingData.data();
|
||
|
|
||
|
free(samples_CH2);
|
||
|
samples_CH2 = (unsigned char *) malloc(length_CH2);
|
||
|
|
||
|
int dummy;
|
||
|
char *dataStringCurrent = dataString;
|
||
|
for (int i=0;i<length_CH2;i++){
|
||
|
sscanf(dataStringCurrent, "%d", &dummy);
|
||
|
dataStringCurrent += strcspn(dataStringCurrent, "\t") + 1;
|
||
|
samples_CH2[i] = (unsigned char) dummy;
|
||
|
}
|
||
|
#else
|
||
|
QString directory = QCoreApplication::applicationDirPath();
|
||
|
|
||
|
directory.append("/waveforms/");
|
||
|
directory.append(newName);
|
||
|
QByteArray temp = directory.toLatin1();
|
||
|
char *fileName = temp.data();
|
||
|
|
||
|
qDebug() << "opening" << fileName;
|
||
|
FILE *fptr = fopen(fileName, "r");
|
||
|
if (fptr==NULL){
|
||
|
qFatal("%s could not be opened!", fileName);
|
||
|
}
|
||
|
|
||
|
char lengthString[5];
|
||
|
fgets(lengthString, 5, fptr);
|
||
|
sscanf(lengthString, "%d", &length_CH2);
|
||
|
|
||
|
char divisibilityString[5];
|
||
|
//Bit of bullshit to deal with CRLF line endings on Mac.
|
||
|
do fgets(divisibilityString, 5, fptr);
|
||
|
while ((divisibilityString[0] == '\r') || (divisibilityString[0] == '\n'));
|
||
|
sscanf(divisibilityString, "%d", &divisibility_CH2);
|
||
|
|
||
|
qDebug() << "Length = " << length_CH2;
|
||
|
qDebug() << "Divisibility = " << divisibility_CH2;
|
||
|
|
||
|
free(samples_CH2);
|
||
|
samples_CH2 = (unsigned char *) malloc(length_CH2);
|
||
|
|
||
|
char *dataString = (char *) malloc(length_CH2*5+1);
|
||
|
fgets(dataString, length_CH2*5+1, fptr);
|
||
|
|
||
|
int dummy;
|
||
|
char *dataStringCurrent = dataString;
|
||
|
for (int i=0;i<length_CH2;i++){
|
||
|
sscanf(dataStringCurrent, "%d", &dummy);
|
||
|
dataStringCurrent += strcspn(dataStringCurrent, "\t") + 1;
|
||
|
samples_CH2[i] = (unsigned char) dummy;
|
||
|
}
|
||
|
|
||
|
free(dataString);
|
||
|
fclose(fptr);
|
||
|
#endif
|
||
|
setMaxFreq_CH2(DAC_SPS/(length_CH2>>(divisibility_CH2-1)));
|
||
|
setMinFreq_CH2((double) CLOCK_FREQ/1024/65535/length_CH2);
|
||
|
functionGenToUpdate(1, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::freqUpdate_CH2(double newFreq){
|
||
|
qDebug() << "newFreq2 = " << newFreq;
|
||
|
freq_CH2 = newFreq;
|
||
|
functionGenToUpdate(1, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::amplitudeUpdate_CH2(double newAmplitude){
|
||
|
qDebug() << "newAmplitude2 = " << newAmplitude;
|
||
|
amplitude_CH2 = newAmplitude;
|
||
|
functionGenToUpdate(1, this);
|
||
|
}
|
||
|
|
||
|
void functionGenControl::offsetUpdate_CH2(double newOffset){
|
||
|
qDebug() << "newOffset2 = " << newOffset;
|
||
|
offset_CH2 = newOffset;
|
||
|
functionGenToUpdate(1, this);
|
||
|
}
|