Merge branch 'debian/latest' into debian/bookworm

This commit is contained in:
Dave Hibberd 2023-10-10 23:42:32 +01:00
commit 0a28d4cef1
No known key found for this signature in database
GPG Key ID: 03A1FB7A1904771B
19 changed files with 421 additions and 145 deletions

View File

@ -53,11 +53,14 @@ extern int CWIDInterval;
extern int CWIDLeft; extern int CWIDLeft;
extern int CWIDRight; extern int CWIDRight;
extern int CWIDType; extern int CWIDType;
extern bool afterTraffic;
extern "C" int RSID_SABM[4]; extern "C" int RSID_SABM[4];
extern "C" int RSID_UI[4]; extern "C" int RSID_UI[4];
extern "C" int RSID_SetModem[4]; extern "C" int RSID_SetModem[4];
extern QFont Font;
QSettings* settings = new QSettings("QtSoundModem.ini", QSettings::IniFormat); QSettings* settings = new QSettings("QtSoundModem.ini", QSettings::IniFormat);
@ -236,7 +239,7 @@ void getSettings()
CWIDLeft = settings->value("Modem/CWIDLeft", 0).toInt(); CWIDLeft = settings->value("Modem/CWIDLeft", 0).toInt();
CWIDRight = settings->value("Modem/CWIDRight", 0).toInt(); CWIDRight = settings->value("Modem/CWIDRight", 0).toInt();
CWIDType = settings->value("Modem/CWIDType", 1).toInt(); // on/off CWIDType = settings->value("Modem/CWIDType", 1).toInt(); // on/off
afterTraffic = settings->value("Modem/afterTraffic", false).toBool();
getAX25Params(0); getAX25Params(0);
getAX25Params(1); getAX25Params(1);
@ -353,6 +356,10 @@ void saveSettings()
{ {
QSettings * settings = new QSettings("QtSoundModem.ini", QSettings::IniFormat); QSettings * settings = new QSettings("QtSoundModem.ini", QSettings::IniFormat);
settings->setValue("FontFamily", Font.family());
settings->setValue("PointSize", Font.pointSize());
settings->setValue("Weight", Font.weight());
settings->setValue("PSKWindow", constellationDialog->geometry()); settings->setValue("PSKWindow", constellationDialog->geometry());
settings->setValue("Init/SoundMode", SoundMode); settings->setValue("Init/SoundMode", SoundMode);
settings->setValue("Init/UDPClientPort", UDPClientPort); settings->setValue("Init/UDPClientPort", UDPClientPort);
@ -454,6 +461,7 @@ void saveSettings()
settings->setValue("Modem/CWIDLeft", CWIDLeft); settings->setValue("Modem/CWIDLeft", CWIDLeft);
settings->setValue("Modem/CWIDRight", CWIDRight); settings->setValue("Modem/CWIDRight", CWIDRight);
settings->setValue("Modem/CWIDType", CWIDType); settings->setValue("Modem/CWIDType", CWIDType);
settings->setValue("Modem/afterTraffic", afterTraffic);
saveAX25Params(0); saveAX25Params(0);
saveAX25Params(1); saveAX25Params(1);

View File

@ -3055,7 +3055,7 @@
<widget class="QLabel" name="label_7"> <widget class="QLabel" name="label_7">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>44</x> <x>12</x>
<y>516</y> <y>516</y>
<width>71</width> <width>71</width>
<height>20</height> <height>20</height>
@ -3068,9 +3068,9 @@
<widget class="QLineEdit" name="CWIDCall"> <widget class="QLineEdit" name="CWIDCall">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>114</x> <x>78</x>
<y>516</y> <y>516</y>
<width>51</width> <width>71</width>
<height>20</height> <height>20</height>
</rect> </rect>
</property> </property>
@ -3081,12 +3081,15 @@
<widget class="QRadioButton" name="CWIDType"> <widget class="QRadioButton" name="CWIDType">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>410</x> <x>340</x>
<y>516</y> <y>516</y>
<width>61</width> <width>61</width>
<height>20</height> <height>20</height>
</rect> </rect>
</property> </property>
<property name="layoutDirection">
<enum>Qt::RightToLeft</enum>
</property>
<property name="text"> <property name="text">
<string>FSK</string> <string>FSK</string>
</property> </property>
@ -3094,12 +3097,20 @@
<widget class="QRadioButton" name="radioButton_2"> <widget class="QRadioButton" name="radioButton_2">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>460</x> <x>396</x>
<y>516</y> <y>516</y>
<width>101</width> <width>101</width>
<height>20</height> <height>20</height>
</rect> </rect>
</property> </property>
<property name="font">
<font>
<family>MS Shell Dlg 2</family>
</font>
</property>
<property name="layoutDirection">
<enum>Qt::RightToLeft</enum>
</property>
<property name="text"> <property name="text">
<string>Tone On/Off</string> <string>Tone On/Off</string>
</property> </property>
@ -3107,7 +3118,7 @@
<widget class="QLabel" name="label_66"> <widget class="QLabel" name="label_66">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>190</x> <x>158</x>
<y>516</y> <y>516</y>
<width>61</width> <width>61</width>
<height>20</height> <height>20</height>
@ -3120,7 +3131,7 @@
<widget class="QLineEdit" name="CWIDInterval"> <widget class="QLineEdit" name="CWIDInterval">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>240</x> <x>208</x>
<y>516</y> <y>516</y>
<width>31</width> <width>31</width>
<height>20</height> <height>20</height>
@ -3130,7 +3141,7 @@
<widget class="QLabel" name="label_91"> <widget class="QLabel" name="label_91">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>294</x> <x>248</x>
<y>516</y> <y>516</y>
<width>61</width> <width>61</width>
<height>20</height> <height>20</height>
@ -3143,9 +3154,9 @@
<widget class="QLineEdit" name="CWIDMark"> <widget class="QLineEdit" name="CWIDMark">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>348</x> <x>318</x>
<y>516</y> <y>516</y>
<width>41</width> <width>31</width>
<height>20</height> <height>20</height>
</rect> </rect>
</property> </property>
@ -3156,6 +3167,27 @@
<string/> <string/>
</property> </property>
</widget> </widget>
<widget class="QCheckBox" name="afterTraffic">
<property name="geometry">
<rect>
<x>500</x>
<y>516</y>
<width>91</width>
<height>20</height>
</rect>
</property>
<property name="font">
<font>
<family>MS Shell Dlg 2</family>
</font>
</property>
<property name="layoutDirection">
<enum>Qt::RightToLeft</enum>
</property>
<property name="text">
<string>After Traffic</string>
</property>
</widget>
</widget> </widget>
<resources/> <resources/>
<connections/> <connections/>

View File

@ -46,7 +46,7 @@ along with QtSoundModem. If not, see http://www.gnu.org/licenses
#include <qevent.h> #include <qevent.h>
#include <QStandardItemModel> #include <QStandardItemModel>
#include <QScrollBar> #include <QScrollBar>
#include <QFontDialog>
#include "UZ7HOStuff.h" #include "UZ7HOStuff.h"
@ -61,11 +61,13 @@ QImage *RXLevel;
QLabel *WaterfallCopy[2]; QLabel *WaterfallCopy[2];
QLabel *HeaderCopy[2]; QLabel *HeaderCopy[2];
QLabel * RXLevelCopy;
QTextEdit * monWindowCopy; QTextEdit * monWindowCopy;
extern workerThread *t; extern workerThread *t;
extern QtSoundModem * w; extern QtSoundModem * w;
extern QCoreApplication * a;
QList<QSerialPortInfo> Ports = QSerialPortInfo::availablePorts(); QList<QSerialPortInfo> Ports = QSerialPortInfo::availablePorts();
@ -148,6 +150,8 @@ int CWIDInterval = 0;
int CWIDLeft = 0; int CWIDLeft = 0;
int CWIDRight = 0; int CWIDRight = 0;
int CWIDType = 1; // on/off int CWIDType = 1; // on/off
bool afterTraffic = 0;
bool cwidtimerisActive = false;
int WaterfallMin = 00; int WaterfallMin = 00;
int WaterfallMax = 6000; int WaterfallMax = 6000;
@ -205,6 +209,8 @@ extern "C" int TXPort;
extern char UDPHost[64]; extern char UDPHost[64];
QTimer *cwidtimer; QTimer *cwidtimer;
QWidget * mythis;
QSystemTrayIcon * trayIcon = nullptr; QSystemTrayIcon * trayIcon = nullptr;
@ -379,22 +385,22 @@ void QtSoundModem::resizeEvent(QResizeEvent* event)
if (UsingBothChannels) if (UsingBothChannels)
{ {
ui.HeaderA->setGeometry(QRect(0, A, W, 35)); ui.HeaderA->setGeometry(QRect(0, A, W, 38));
ui.WaterfallA->setGeometry(QRect(0, A + 35, W, 80)); ui.WaterfallA->setGeometry(QRect(0, A + 38, W, 80));
ui.HeaderB->setGeometry(QRect(0, B, W, 35)); ui.HeaderB->setGeometry(QRect(0, B, W, 38));
ui.WaterfallB->setGeometry(QRect(0, B + 35, W, 80)); ui.WaterfallB->setGeometry(QRect(0, B + 38, W, 80));
} }
else else
{ {
if (soundChannel[0] == RIGHT) if (soundChannel[0] == RIGHT)
{ {
ui.HeaderB->setGeometry(QRect(0, A, W, 35)); ui.HeaderB->setGeometry(QRect(0, A, W, 38));
ui.WaterfallB->setGeometry(QRect(0, A + 35, W, 80)); ui.WaterfallB->setGeometry(QRect(0, A + 38, W, 80));
} }
else else
{ {
ui.HeaderA->setGeometry(QRect(0, A, W, 35)); ui.HeaderA->setGeometry(QRect(0, A, W, 38));
ui.WaterfallA->setGeometry(QRect(0, A + 35, W, 80)); ui.WaterfallA->setGeometry(QRect(0, A + 38, W, 80));
} }
} }
} }
@ -456,7 +462,6 @@ void QtSoundModem::initWaterfall(int chan, int state)
} }
Waterfall[chan] = new QImage(1024, 80, QImage::Format_RGB32); Waterfall[chan] = new QImage(1024, 80, QImage::Format_RGB32);
Waterfall[chan]->fill(black); Waterfall[chan]->fill(black);
} }
else else
{ {
@ -480,6 +485,8 @@ QLabel * QualLabel[4];
QLabel *RXOffsetLabel; QLabel *RXOffsetLabel;
QSlider *RXOffset; QSlider *RXOffset;
QFont Font;
extern "C" void CheckPSKWindows() extern "C" void CheckPSKWindows()
{ {
NeedPSKRefresh = 1; NeedPSKRefresh = 1;
@ -515,10 +522,26 @@ void DoPSKWindows()
QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent) QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
{ {
QString family;
int csize;
QFont::Weight weight;
ui.setupUi(this); ui.setupUi(this);
mythis = this;
QSettings mysettings("QtSoundModem.ini", QSettings::IniFormat); QSettings mysettings("QtSoundModem.ini", QSettings::IniFormat);
family = mysettings.value("FontFamily", "Courier New").toString();
csize = mysettings.value("PointSize", 0).toInt();
weight = (QFont::Weight)mysettings.value("Weight", 50).toInt();
Font = QFont(family);
Font.setPointSize(csize);
Font.setWeight(weight);
QApplication::setFont(Font);
constellationDialog = new QDialog(nullptr, Qt::WindowTitleHint | Qt::WindowSystemMenuHint); constellationDialog = new QDialog(nullptr, Qt::WindowTitleHint | Qt::WindowSystemMenuHint);
constellationDialog->resize(488, 140); constellationDialog->resize(488, 140);
constellationDialog->setGeometry(PSKRect); constellationDialog->setGeometry(PSKRect);
@ -625,6 +648,12 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
connect(actModems, SIGNAL(triggered()), this, SLOT(clickedSlot())); connect(actModems, SIGNAL(triggered()), this, SLOT(clickedSlot()));
actFont = new QAction("Setup Font", this);
actFont->setObjectName("actFont");
setupMenu->addAction(actFont);
connect(actFont, SIGNAL(triggered()), this, SLOT(clickedSlot()));
actMintoTray = setupMenu->addAction("Minimize to Tray", this, SLOT(MinimizetoTray())); actMintoTray = setupMenu->addAction("Minimize to Tray", this, SLOT(MinimizetoTray()));
actMintoTray->setCheckable(1); actMintoTray->setCheckable(1);
actMintoTray->setChecked(MintoTray); actMintoTray->setChecked(MintoTray);
@ -643,11 +672,13 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
actAbout = ui.menuBar->addAction("&About"); actAbout = ui.menuBar->addAction("&About");
connect(actAbout, SIGNAL(triggered()), this, SLOT(doAbout())); connect(actAbout, SIGNAL(triggered()), this, SLOT(doAbout()));
// Constellation = new QImage(91, 91, QImage::Format_RGB32); Header[0] = new QImage(1024, 38, QImage::Format_RGB32);
Header[1] = new QImage(1024, 38, QImage::Format_RGB32);
Header[0] = new QImage(1024, 35, QImage::Format_RGB32);
Header[1] = new QImage(1024, 35, QImage::Format_RGB32);
RXLevel = new QImage(150, 10, QImage::Format_RGB32); RXLevel = new QImage(150, 10, QImage::Format_RGB32);
RXLevel->fill(white);
ui.RXLevel->setPixmap(QPixmap::fromImage(*RXLevel));
RXLevelCopy = ui.RXLevel;
DCDLabel[0] = new QLabel(this); DCDLabel[0] = new QLabel(this);
DCDLabel[0]->setObjectName(QString::fromUtf8("DCDLedA")); DCDLabel[0]->setObjectName(QString::fromUtf8("DCDLedA"));
@ -725,9 +756,6 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
wf_Scale(0); wf_Scale(0);
wf_Scale(1); wf_Scale(1);
// RefreshLevel(0);
// RXLevel->setPixmap(QPixmap::fromImage(*RXLevel));
connect(ui.modeA, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int))); connect(ui.modeA, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int)));
connect(ui.modeB, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int))); connect(ui.modeB, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int)));
connect(ui.modeC, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int))); connect(ui.modeC, SIGNAL(currentIndexChanged(int)), this, SLOT(clickedSlotI(int)));
@ -769,10 +797,11 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
connect(ui.DCDSlider, SIGNAL(sliderMoved(int)), this, SLOT(clickedSlotI(int))); connect(ui.DCDSlider, SIGNAL(sliderMoved(int)), this, SLOT(clickedSlotI(int)));
connect(ui.RXOffset, SIGNAL(valueChanged(int)), this, SLOT(clickedSlotI(int))); connect(ui.RXOffset, SIGNAL(valueChanged(int)), this, SLOT(clickedSlotI(int)));
QObject::connect(t, SIGNAL(sendtoTrace(char *, int)), this, SLOT(sendtoTrace(char *, int)), Qt::QueuedConnection); QObject::connect(t, SIGNAL(sendtoTrace(char *, int)), this, SLOT(sendtoTrace(char *, int)), Qt::QueuedConnection);
QObject::connect(t, SIGNAL(updateDCD(int, int)), this, SLOT(doupdateDCD(int, int)), Qt::QueuedConnection); QObject::connect(t, SIGNAL(updateDCD(int, int)), this, SLOT(doupdateDCD(int, int)), Qt::QueuedConnection);
QObject::connect(t, SIGNAL(startCWIDTimer()), this, SLOT(startCWIDTimerSlot()), Qt::QueuedConnection);
connect(ui.RXOffsetA, SIGNAL(returnPressed()), this, SLOT(returnPressed())); connect(ui.RXOffsetA, SIGNAL(returnPressed()), this, SLOT(returnPressed()));
connect(ui.RXOffsetB, SIGNAL(returnPressed()), this, SLOT(returnPressed())); connect(ui.RXOffsetB, SIGNAL(returnPressed()), this, SLOT(returnPressed()));
connect(ui.RXOffsetC, SIGNAL(returnPressed()), this, SLOT(returnPressed())); connect(ui.RXOffsetC, SIGNAL(returnPressed()), this, SLOT(returnPressed()));
@ -786,11 +815,11 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
connect(wftimer, SIGNAL(timeout()), this, SLOT(doRestartWF())); connect(wftimer, SIGNAL(timeout()), this, SLOT(doRestartWF()));
wftimer->start(1000 * 300); wftimer->start(1000 * 300);
cwidtimer = new QTimer(this); cwidtimer = new QTimer(this);
connect(cwidtimer, SIGNAL(timeout()), this, SLOT(CWIDTimer())); connect(cwidtimer, SIGNAL(timeout()), this, SLOT(CWIDTimer()));
if (CWIDInterval)
if (CWIDInterval && afterTraffic == false)
cwidtimer->start(CWIDInterval * 60000); cwidtimer->start(CWIDInterval * 60000);
if (RSID_SetModem[0]) if (RSID_SetModem[0])
@ -798,7 +827,15 @@ QtSoundModem::QtSoundModem(QWidget *parent) : QMainWindow(parent)
RSID_WF = 1; RSID_WF = 1;
RSIDinitfft(); RSIDinitfft();
} }
il2p_init(1); // il2p_init(1);
QTimer::singleShot(200, this, &QtSoundModem::updateFont);
}
void QtSoundModem::updateFont()
{
QApplication::setFont(Font);
} }
void QtSoundModem::MinimizetoTray() void QtSoundModem::MinimizetoTray()
@ -821,8 +858,23 @@ void QtSoundModem::TrayActivated(QSystemTrayIcon::ActivationReason reason)
extern "C" void sendCWID(char * strID, BOOL blnPlay, int Chan); extern "C" void sendCWID(char * strID, BOOL blnPlay, int Chan);
extern "C" void checkforCWID()
{
emit(t->startCWIDTimer());
};
extern "C" void QtSoundModem::startCWIDTimerSlot()
{
if (CWIDInterval && afterTraffic == 1 && cwidtimerisActive == false)
{
cwidtimerisActive = true;
QTimer::singleShot(CWIDInterval * 60000, this, &QtSoundModem::CWIDTimer);
}
}
void QtSoundModem::CWIDTimer() void QtSoundModem::CWIDTimer()
{ {
cwidtimerisActive = false;
sendCWID(CWIDCall, CWIDType, 0); sendCWID(CWIDCall, CWIDType, 0);
calib_mode[0] = 4; calib_mode[0] = 4;
} }
@ -1061,7 +1113,6 @@ void QtSoundModem::clickedSlotI(int i)
return; return;
} }
QMessageBox msgBox; QMessageBox msgBox;
msgBox.setWindowTitle("MessageBox Title"); msgBox.setWindowTitle("MessageBox Title");
msgBox.setText("You Clicked " + ((QPushButton*)sender())->objectName()); msgBox.setText("You Clicked " + ((QPushButton*)sender())->objectName());
@ -1221,6 +1272,27 @@ void QtSoundModem::clickedSlot()
return; return;
} }
if (strcmp(Name, "actFont") == 0)
{
bool ok;
Font = QFontDialog::getFont(&ok, QFont(Font, this));
if (ok)
{
// the user clicked OK and font is set to the font the user selected
QApplication::setFont(Font);
saveSettings();
}
else
{
// the user canceled the dialog; font is set to the initial
// value, in this case Helvetica [Cronyx], 10
QApplication::setFont(Font);
}
return;
}
QMessageBox msgBox; QMessageBox msgBox;
msgBox.setWindowTitle("MessageBox Title"); msgBox.setWindowTitle("MessageBox Title");
msgBox.setText("You Clicked " + ((QPushButton*)sender())->objectName()); msgBox.setText("You Clicked " + ((QPushButton*)sender())->objectName());
@ -1417,6 +1489,8 @@ void QtSoundModem::doModems()
else else
Dlg->CWIDType->setChecked(1); Dlg->CWIDType->setChecked(1);
Dlg->afterTraffic->setChecked(afterTraffic);
Dlg->RSIDSABM_A->setChecked(RSID_SABM[0]); Dlg->RSIDSABM_A->setChecked(RSID_SABM[0]);
Dlg->RSIDSABM_B->setChecked(RSID_SABM[1]); Dlg->RSIDSABM_B->setChecked(RSID_SABM[1]);
Dlg->RSIDSABM_C->setChecked(RSID_SABM[2]); Dlg->RSIDSABM_C->setChecked(RSID_SABM[2]);
@ -1635,7 +1709,9 @@ void QtSoundModem::modemSave()
CWIDInterval = Dlg->CWIDInterval->text().toInt(); CWIDInterval = Dlg->CWIDInterval->text().toInt();
CWIDType = Dlg->radioButton_2->isChecked(); CWIDType = Dlg->radioButton_2->isChecked();
if (CWIDInterval) afterTraffic = Dlg->afterTraffic->isChecked();
if (CWIDInterval && afterTraffic == false)
cwidtimer->start(CWIDInterval * 60000); cwidtimer->start(CWIDInterval * 60000);
else else
cwidtimer->stop(); cwidtimer->stop();
@ -1677,6 +1753,19 @@ void QtSoundModem::modemSave()
get_exclude_list(MyDigiCall[i], &list_digi_callsigns[i]); get_exclude_list(MyDigiCall[i], &list_digi_callsigns[i]);
} }
/*
Q = Dlg->LPFWidthA->text();
lpf[0] = Q.toInt();
Q = Dlg->LPFWidthB->text();
lpf[1] = Q.toInt();
Q = Dlg->LPFWidthC->text();
lpf[2] = Q.toInt();
Q = Dlg->LPFWidthD->text();
lpf[3] = Q.toInt();
*/
} }
void QtSoundModem::modemreject() void QtSoundModem::modemreject()
@ -2030,7 +2119,19 @@ void QtSoundModem::doDevices()
Dev->PTTPort->addItem(info); Dev->PTTPort->addItem(info);
} }
Dev->PTTPort->setCurrentIndex(Dev->PTTPort->findText(PTTPort, Qt::MatchFixedString)); // If we are using a user specifed device add it
i = Dev->PTTPort->findText(PTTPort, Qt::MatchFixedString);
if (i == -1)
{
// Add our device to list
Dev->PTTPort->insertItem(0, PTTPort);
i = Dev->PTTPort->findText(PTTPort, Qt::MatchContains);
}
Dev->PTTPort->setCurrentIndex(i);
PTTPortChanged(0); // Force reevaluation PTTPortChanged(0); // Force reevaluation
@ -2163,7 +2264,13 @@ void QtSoundModem::deviceaccept()
AGWPort = Q.toInt(); AGWPort = Q.toInt();
Q = Dev->PTTPort->currentText(); Q = Dev->PTTPort->currentText();
strcpy(PTTPort, Q.toString().toUtf8());
char temp[256];
strcpy(temp, Q.toString().toUtf8());
if (strlen(temp))
strcpy(PTTPort, temp);
DualPTT = Dev->DualPTT->isChecked(); DualPTT = Dev->DualPTT->isChecked();
TX_rotate = Dev->txRotation->isChecked(); TX_rotate = Dev->txRotation->isChecked();
@ -2312,6 +2419,20 @@ void QtSoundModem::doRestartWF()
initWaterfall(1, 0); initWaterfall(1, 0);
initWaterfall(1, 1); initWaterfall(1, 1);
} }
delete(RXLevel);
delete(ui.RXLevel);
ui.RXLevel = new QLabel(ui.centralWidget);
RXLevelCopy = ui.RXLevel;
ui.RXLevel->setGeometry(QRect(780, 17, 150, 12));
// ui.RXLevel->setFrameShape(QFrame::Box);
// ui.RXLevel->setFrameShadow(QFrame::Sunken);
RXLevel = new QImage(150, 10, QImage::Format_RGB32);
RXLevel->fill(cyan);
// ui.RXLevel->setPixmap(QPixmap::fromImage(*RXLevel));
ui.RXLevel->setVisible(1);
} }
@ -2399,6 +2520,34 @@ void QtSoundModem::RefreshSpectrum(unsigned char * Data)
} }
void RefreshLevel(unsigned int Level)
{
// Redraw the RX Level Bar Graph
unsigned int x, y;
for (x = 0; x < 150; x++)
{
for (y = 0; y < 10; y++)
{
if (x < Level)
{
if (Level < 50)
RXLevel->setPixel(x, y, yellow);
else if (Level > 135)
RXLevel->setPixel(x, y, red);
else
RXLevel->setPixel(x, y, green);
}
else
RXLevel->setPixel(x, y, white);
}
}
RXLevelCopy->setPixmap(QPixmap::fromImage(*RXLevel));
}
extern "C" unsigned char CurrentLevel;
void QtSoundModem::RefreshWaterfall(int snd_ch, unsigned char * Data) void QtSoundModem::RefreshWaterfall(int snd_ch, unsigned char * Data)
{ {
int j; int j;
@ -2584,7 +2733,7 @@ void do_pointer(int waterfall)
// We drew markers every 100 Hz or 100 / binsize pixels // We drew markers every 100 Hz or 100 / binsize pixels
float PixelsPerHz = 1.0 / BinSize; float PixelsPerHz = 1.0 / BinSize;
k = 28; k = 26;
// draw all enabled ports on the ports on this soundcard // draw all enabled ports on the ports on this soundcard
@ -2632,6 +2781,8 @@ void do_pointer(int waterfall)
qPainter.drawLine(pos3, k - 3, pos3, k + 3); qPainter.drawLine(pos3, k - 3, pos3, k + 3);
qPainter.drawLine(pos3 - 2, k - 3, pos3 + 2, k - 3); qPainter.drawLine(pos3 - 2, k - 3, pos3 + 2, k - 3);
} }
k += 3;
} }
HeaderCopy[waterfall]->setPixmap(QPixmap::fromImage(*bm)); HeaderCopy[waterfall]->setPixmap(QPixmap::fromImage(*bm));
} }
@ -2696,6 +2847,10 @@ extern "C" void SMUpdateBusyDetector(int LR, float * Real, float *Imag);
void doWaterfallThread(void * param) void doWaterfallThread(void * param)
{ {
int snd_ch = (int)(size_t)param; int snd_ch = (int)(size_t)param;
int WaterfallNumber = snd_ch;
if (snd_ch == 1 && UsingLeft == 0) // Only using right
snd_ch = 0; // Samples are in first buffer
QImage * bm = Waterfall[snd_ch]; QImage * bm = Waterfall[snd_ch];
@ -2713,6 +2868,7 @@ void doWaterfallThread(void * param)
if (Configuring) if (Configuring)
return; return;
hFFTSize = FFTSize / 2; hFFTSize = FFTSize / 2;
@ -2794,56 +2950,67 @@ void doWaterfallThread(void * param)
SMUpdateBusyDetector(snd_ch, RealOut, ImagOut); SMUpdateBusyDetector(snd_ch, RealOut, ImagOut);
RefreshLevel(CurrentLevel); // Signal Level
if (bm == 0) if (bm == 0)
return; return;
p = Line; try
lineLen = bm->bytesPerLine();
if (raduga == DISP_MONO)
{ {
for (i = Start; i < End; i++)
p = Line;
lineLen = bm->bytesPerLine();
if (raduga == DISP_MONO)
{ {
n = fft_disp[snd_ch][i]; for (i = Start; i < End; i++)
*(p++) = n; // all colours the same {
*(p++) = n; n = fft_disp[snd_ch][i];
*(p++) = n; *(p++) = n; // all colours the same
p++; *(p++) = n;
*(p++) = n;
p++;
}
} }
} else
else
{
for (i = Start; i < End; i++)
{ {
n = fft_disp[snd_ch][i]; for (i = Start; i < End; i++)
memcpy(p, &RGBWF[n], 4); {
p += 4; n = fft_disp[snd_ch][i];
memcpy(p, &RGBWF[n], 4);
p += 4;
}
} }
// Scroll
int TopLine = NextWaterfallLine[snd_ch];
// Write line to cyclic buffer then draw starting with the line just written
memcpy(&WaterfallLines[snd_ch][NextWaterfallLine[snd_ch]++][0], Line, 4096);
if (NextWaterfallLine[snd_ch] > 79)
NextWaterfallLine[snd_ch] = 0;
for (int j = 79; j > 0; j--)
{
p = bm->scanLine(j);
memcpy(p, &WaterfallLines[snd_ch][TopLine][0], lineLen);
TopLine++;
if (TopLine > 79)
TopLine = 0;
}
WaterfallCopy[WaterfallNumber]->setPixmap(QPixmap::fromImage(*bm));
// WaterfallCopy[snd_ch - 1]->setPixmap(*pm);
// WaterfallCopy[1]->setPixmap(QPixmap::fromImage(*bm));
} }
catch (const std::exception& e) // caught by reference to base
// Scroll
int TopLine = NextWaterfallLine[snd_ch];
// Write line to cyclic buffer then draw starting with the line just written
memcpy(&WaterfallLines[snd_ch][NextWaterfallLine[snd_ch]++][0], Line, 4096);
if (NextWaterfallLine[snd_ch] > 79)
NextWaterfallLine[snd_ch] = 0;
for (int j = 79; j > 0; j--)
{ {
p = bm->scanLine(j); qDebug() << " a standard exception was caught, with message '"
memcpy(p, &WaterfallLines[snd_ch][TopLine][0], lineLen); << e.what() << "'\n";
TopLine++;
if (TopLine > 79)
TopLine = 0;
} }
WaterfallCopy[snd_ch]->setPixmap(QPixmap::fromImage(*bm));
// WaterfallCopy[snd_ch - 1]->setPixmap(*pm);
// WaterfallCopy[1]->setPixmap(QPixmap::fromImage(*bm));
} }
@ -3078,17 +3245,19 @@ extern "C" int SMUpdatePhaseConstellation(int chan, float * Phases, float * Mags
int yCenter = (ConstellationHeight - 2) / 2; int yCenter = (ConstellationHeight - 2) / 2;
int xCenter = (ConstellationWidth - 2) / 2; int xCenter = (ConstellationWidth - 2) / 2;
Constellation[chan]->fill(black);
for (i = 0; i < 120; i++)
{
Constellation[chan]->setPixel(xCenter, i, cyan);
Constellation[chan]->setPixel(i, xCenter, cyan);
}
if (Count == 0) if (Count == 0)
return 0; return 0;
if (nonGUIMode == 0)
{
Constellation[chan]->fill(black);
for (i = 0; i < 120; i++)
{
Constellation[chan]->setPixel(xCenter, i, cyan);
Constellation[chan]->setPixel(i, xCenter, cyan);
}
}
dbPhaseStep = 2 * M_PI / intPSKPhase; dbPhaseStep = 2 * M_PI / intPSKPhase;
for (i = 1; i < Count; i++) // Don't plot the first phase (reference) for (i = 1; i < Count; i++) // Don't plot the first phase (reference)
@ -3109,23 +3278,28 @@ extern "C" int SMUpdatePhaseConstellation(int chan, float * Phases, float * Mags
dblPhaseError = fabsf(Phases[i] - intP * dbPhaseStep); // always positive and < .5 * dblPhaseStep dblPhaseError = fabsf(Phases[i] - intP * dbPhaseStep); // always positive and < .5 * dblPhaseStep
dblPhaseErrorSum += dblPhaseError; dblPhaseErrorSum += dblPhaseError;
intX = xCenter + dblRad * cosf(dblPlotRotation + Phases[i]); if (nonGUIMode == 0)
intY = yCenter + dblRad * sinf(dblPlotRotation + Phases[i]); {
intX = xCenter + dblRad * cosf(dblPlotRotation + Phases[i]);
intY = yCenter + dblRad * sinf(dblPlotRotation + Phases[i]);
if (intX > 0 && intY > 0) if (intX > 0 && intY > 0)
if (intX != xCenter && intY != yCenter) if (intX != xCenter && intY != yCenter)
Constellation[chan]->setPixel(intX, intY, yellow); Constellation[chan]->setPixel(intX, intY, yellow);
}
} }
dblAvgRad = dblAvgRad / Count; // the average radius dblAvgRad = dblAvgRad / Count; // the average radius
intQuality = MAX(0, ((100 - 200 * (dblPhaseErrorSum / (Count)) / dbPhaseStep))); // ignore radius error for (PSK) but include for QAM intQuality = MAX(0, ((100 - 200 * (dblPhaseErrorSum / (Count)) / dbPhaseStep))); // ignore radius error for (PSK) but include for QAM
char QualText[64]; if (nonGUIMode == 0)
sprintf(QualText, "Chan %c Qual = %d", chan + 'A', intQuality); {
QualLabel[chan]->setText(QualText); char QualText[64];
constellationLabel[chan]->setPixmap(QPixmap::fromImage(*Constellation[chan])); sprintf(QualText, "Chan %c Qual = %d", chan + 'A', intQuality);
// constellationDialog[chan]->setWindowTitle(QualText); QualLabel[chan]->setText(QualText);
constellationLabel[chan]->setPixmap(QPixmap::fromImage(*Constellation[chan]));
}
return intQuality; return intQuality;
} }

View File

@ -31,13 +31,17 @@ public:
void RefreshWaterfall(int snd_ch, unsigned char * Data); void RefreshWaterfall(int snd_ch, unsigned char * Data);
void initWaterfall(int chan, int state); void initWaterfall(int chan, int state);
void show_grid(); void show_grid();
void checkforCWID();
public slots:
private slots: private slots:
void CWIDTimer();
void doDevices(); void doDevices();
void updateFont();
void MinimizetoTray(); void MinimizetoTray();
void TrayActivated(QSystemTrayIcon::ActivationReason reason); void TrayActivated(QSystemTrayIcon::ActivationReason reason);
void CWIDTimer();
void MyTimerSlot(); void MyTimerSlot();
void returnPressed(); void returnPressed();
void clickedSlotI(int i); void clickedSlotI(int i);
@ -58,6 +62,7 @@ private slots:
void doRSIDD(); void doRSIDD();
void handleButton(int Port, int Act); void handleButton(int Port, int Act);
void doCalibrate(); void doCalibrate();
void RefreshSpectrum(unsigned char * Data);
void doAbout(); void doAbout();
void doRestartWF(); void doRestartWF();
void doupdateDCD(int, int); void doupdateDCD(int, int);
@ -69,6 +74,7 @@ private slots:
void menuChecked(); void menuChecked();
void onTEselectionChanged(); void onTEselectionChanged();
void clickedSlot(); void clickedSlot();
void startCWIDTimerSlot();
protected: protected:
@ -85,6 +91,7 @@ private:
QAction *actDevices; QAction *actDevices;
QAction *actModems; QAction *actModems;
QAction *actFont;
QAction *actMintoTray; QAction *actMintoTray;
QAction *actCalib; QAction *actCalib;
QAction *actAbout; QAction *actAbout;
@ -92,8 +99,8 @@ private:
QAction *actWaterfall1; QAction *actWaterfall1;
QAction *actWaterfall2; QAction *actWaterfall2;
signals:
void RefreshSpectrum(unsigned char * Data);
}; };
class myResize : public QObject class myResize : public QObject

View File

@ -215,26 +215,13 @@
<number>10</number> <number>10</number>
</property> </property>
</widget> </widget>
<widget class="QCheckBox" name="holdPointers">
<property name="geometry">
<rect>
<x>782</x>
<y>6</y>
<width>93</width>
<height>22</height>
</rect>
</property>
<property name="text">
<string>Hold Pointers</string>
</property>
</widget>
<widget class="QLabel" name="HeaderA"> <widget class="QLabel" name="HeaderA">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>25</x> <x>25</x>
<y>460</y> <y>460</y>
<width>1076</width> <width>1076</width>
<height>30</height> <height>38</height>
</rect> </rect>
</property> </property>
<property name="minimumSize"> <property name="minimumSize">
@ -270,7 +257,7 @@
<x>10</x> <x>10</x>
<y>560</y> <y>560</y>
<width>1076</width> <width>1076</width>
<height>30</height> <height>38</height>
</rect> </rect>
</property> </property>
<property name="minimumSize"> <property name="minimumSize">
@ -496,6 +483,49 @@
<set>Qt::AlignCenter</set> <set>Qt::AlignCenter</set>
</property> </property>
</widget> </widget>
<widget class="QLabel" name="RXLevel">
<property name="geometry">
<rect>
<x>780</x>
<y>17</y>
<width>150</width>
<height>12</height>
</rect>
</property>
<property name="frameShape">
<enum>QFrame::Box</enum>
</property>
<property name="frameShadow">
<enum>QFrame::Sunken</enum>
</property>
<property name="text">
<string/>
</property>
</widget>
<widget class="QLabel" name="label_7">
<property name="geometry">
<rect>
<x>780</x>
<y>0</y>
<width>91</width>
<height>16</height>
</rect>
</property>
<property name="font">
<font>
<pointsize>8</pointsize>
</font>
</property>
<property name="text">
<string>Rcv Level:</string>
</property>
<property name="textFormat">
<enum>Qt::PlainText</enum>
</property>
<property name="wordWrap">
<bool>true</bool>
</property>
</widget>
</widget> </widget>
<widget class="QMenuBar" name="menuBar"> <widget class="QMenuBar" name="menuBar">
<property name="geometry"> <property name="geometry">

View File

@ -20,15 +20,15 @@
<DebuggerFlavor>WindowsLocalDebugger</DebuggerFlavor> <DebuggerFlavor>WindowsLocalDebugger</DebuggerFlavor>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Label="QtSettings" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> <PropertyGroup Label="QtSettings" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<QtLastBackgroundBuild>2023-08-31T18:31:29.1703485Z</QtLastBackgroundBuild> <QtLastBackgroundBuild>2023-09-26T11:58:59.9128543Z</QtLastBackgroundBuild>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="QtSettings"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="QtSettings">
<QtLastBackgroundBuild>2023-08-31T18:31:29.3763536Z</QtLastBackgroundBuild> <QtLastBackgroundBuild>2023-09-26T11:59:00.0378577Z</QtLastBackgroundBuild>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Label="QtSettings" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> <PropertyGroup Label="QtSettings" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<QtLastBackgroundBuild>2023-08-31T18:31:30.2753833Z</QtLastBackgroundBuild> <QtLastBackgroundBuild>2023-09-26T11:59:00.1388610Z</QtLastBackgroundBuild>
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="QtSettings"> <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="QtSettings">
<QtLastBackgroundBuild>2023-08-31T18:31:32.1264353Z</QtLastBackgroundBuild> <QtLastBackgroundBuild>2023-09-26T11:59:00.2228656Z</QtLastBackgroundBuild>
</PropertyGroup> </PropertyGroup>
</Project> </Project>

View File

@ -54,6 +54,7 @@ unsigned short * SendtoCard(unsigned short * buf, int n);
short * SoundInit(); short * SoundInit();
void DoTX(int Chan); void DoTX(int Chan);
void UDPPollReceivedSamples(); void UDPPollReceivedSamples();
extern void checkforCWID();
extern int SampleNo; extern int SampleNo;
@ -139,6 +140,8 @@ void soundMain()
init_raduga(); // Set up waterfall colour table init_raduga(); // Set up waterfall colour table
initfft(); initfft();
il2p_init(1);
if (nonGUIMode) if (nonGUIMode)
{ {
@ -563,7 +566,7 @@ int Freq_Change(int Chan, int Freq)
tx_freq[Chan] = Freq; tx_freq[Chan] = Freq;
pnt_change[Chan] = TRUE; pnt_change[Chan] = TRUE;
wf_pointer(soundChannel[Chan]); wf_pointer(Chan);
return Freq; return Freq;
} }
@ -805,6 +808,8 @@ void DoTX(int Chan)
// Start a new send. modulator should handle TXD etc // Start a new send. modulator should handle TXD etc
checkforCWID(); // See if need to start CWID timer in afteractivity mode
Debugprintf("TX Start"); Debugprintf("TX Start");
SampleNo = 0; SampleNo = 0;
@ -1131,7 +1136,9 @@ void OpenPTTPort()
void ClosePTTPort() void ClosePTTPort()
{ {
CloseCOMPort(hPTTDevice); if (hPTTDevice)
CloseCOMPort(hPTTDevice);
hPTTDevice = 0; hPTTDevice = 0;
} }
void CM108_set_ptt(int PTTState) void CM108_set_ptt(int PTTState)

View File

@ -4,8 +4,8 @@
// My port of UZ7HO's Soundmodem // My port of UZ7HO's Soundmodem
// //
#define VersionString "0.0.0.67-2" #define VersionString "0.0.0.68"
#define VersionBytes {0, 0, 0, 67} #define VersionBytes {0, 0, 0, 68}
// Added FX25. 4x100 FEC and V27 not Working and disabled // Added FX25. 4x100 FEC and V27 not Working and disabled
@ -159,6 +159,13 @@
// .68 Monitor XID and TEST // .68 Monitor XID and TEST
// Flag active interface in title bar // Flag active interface in title bar
// Improve header validation in il2p // Improve header validation in il2p
// Add CWID only after traffic option
// Add font selection
// Separate modem bandwidth indicators
// Fix problems with il2p and PSK modes in nogui mode
// Add signal level bar to GUI
// Fix Waterfall display when using right channel only
// Allow PTT device to be added

View File

@ -511,7 +511,7 @@ for (i = 0; i < 100; i++)
static int min = 0, max = 0, lastlevelGUI = 0, lastlevelreport = 0; static int min = 0, max = 0, lastlevelGUI = 0, lastlevelreport = 0;
static UCHAR CurrentLevel = 0; // Peak from current samples UCHAR CurrentLevel = 0; // Peak from current samples
void PollReceivedSamples() void PollReceivedSamples()
{ {
@ -988,9 +988,7 @@ void StdinPollReceivedSamples()
if ((Now - lastlevelGUI) > 2000) // 2 Secs if ((Now - lastlevelGUI) > 2000) // 2 Secs
{ {
// if (WaterfallActive == 0 && SpectrumActive == 0) // Don't need to send as included in Waterfall Line // RefreshLevel(CurrentLevel); // Signal Level
// SendtoGUI('L', &CurrentLevel, 1); // Signal Level
lastlevelGUI = Now; lastlevelGUI = Now;
if ((Now - lastlevelreport) > 10000) // 10 Secs if ((Now - lastlevelreport) > 10000) // 10 Secs

6
debian/changelog vendored
View File

@ -1,3 +1,9 @@
qtsoundmodem (0.0.0.68-1) unstable; urgency=medium
* New Upstream
-- Dave Hibberd <d@vehibberd.com> Tue, 10 Oct 2023 23:03:20 +0100
qtsoundmodem (0.0.0.67-2~bpo12+1) bookworm; urgency=medium qtsoundmodem (0.0.0.67-2~bpo12+1) bookworm; urgency=medium
* Rebuild for bookworm. * Rebuild for bookworm.

2
debian/install vendored
View File

@ -1,3 +1,3 @@
QtSoundModem /opt/oarc/QtSoundModem QtSoundModem /usr/bin
debian/qtsoundmodem.desktop /usr/share/applications debian/qtsoundmodem.desktop /usr/share/applications
debian/QtSoundModem.png /usr/share/pixmaps debian/QtSoundModem.png /usr/share/pixmaps

9
debian/postinst vendored Normal file
View File

@ -0,0 +1,9 @@
#!/bin/sh
set -e
SM="/opt/oarc/QtSoundModem"
if [ -d $SM ]; then
rm -rf /opt/oarc/QtSoundModem
fi

View File

@ -2,7 +2,7 @@
Name=QtSoundModem Name=QtSoundModem
Comment=QtSoundModem Comment=QtSoundModem
Version=1.0 Version=1.0
Exec=/opt/oarc/QtSoundModem/QtSoundModem Exec=/usr/bin/QtSoundModem
GenericName=QtSoundModem GenericName=QtSoundModem
Icon=QtSoundModem Icon=QtSoundModem
NoDisplay=false NoDisplay=false

View File

@ -1,7 +1,10 @@
[General] [General]
geometry=@ByteArray(\x1\xd9\xd0\xcb\0\x3\0\0\0\0\0\a\0\0\0\0\0\0\x3\xca\0\0\x2\xf0\0\0\0\b\0\0\0\x1f\0\0\x3\xc9\0\0\x2\xef\0\0\0\0\0\0\0\0\x5\0\0\0\0\b\0\0\0\x1f\0\0\x3\xc9\0\0\x2\xef) geometry="@ByteArray(\x1\xd9\xd0\xcb\0\x3\0\0\0\0\0z\0\0\0\t\0\0\x4=\0\0\x2\xf9\0\0\0{\0\0\0(\0\0\x4<\0\0\x2\xf8\0\0\0\0\0\0\0\0\x5\0\0\0\0{\0\0\0(\0\0\x4<\0\0\x2\xf8)"
windowState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\0\0\0\x3\xc2\0\0\x2\xbc\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\0) windowState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\0\0\0\x3\xc2\0\0\x2\xb9\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\0)
PSKWindow=@Rect(46 499 366 140) PSKWindow=@Rect(46 499 366 140)
FontFamily=Courier New
PointSize=12
Weight=50
[AX25_A] [AX25_A]
Retries=15 Retries=15
@ -56,7 +59,7 @@ HamLibPort=4532
HamLibHost=127.0.0.1 HamLibHost=127.0.0.1
MinimizetoTray=1 MinimizetoTray=1
multiCore=1 multiCore=1
Wisdom=(fftw-3.3.5 fftwf_wisdom #x08ac4c16 #x457005cc #xea102cf7 #xd7ff9038\n (fftwf_dft_vrank_geq1_register 0 #x10048 #x10048 #x0 #x2fce15e1 #x178d4f4d #x1e956a41 #xf3fd6b80)\n (fftwf_dft_buffered_register 0 #x11048 #x11048 #x0 #x4f8e87b4 #xec4f2fa0 #x79fe76a1 #xa16e32a5)\n (fftwf_codelet_t1fv_6_sse2 0 #x10048 #x10048 #x0 #xd9db29d8 #x3302fcf3 #x19ce6e5d #x869fc341)\n (fftwf_codelet_t1fv_12_sse2 0 #x10048 #x10048 #x0 #x0b0d3933 #x08267d12 #x45613873 #xde496efe)\n (fftwf_codelet_n2fv_12_sse2 0 #x10048 #x10048 #x0 #xb0767e46 #x8d41dd22 #x439264a0 #x18435a99)\n (fftwf_dft_bluestein_register 0 #x11048 #x11048 #x0 #x5e17c068 #x1682c5d6 #x89dd79be #x9b951c0f)\n (fftwf_codelet_t1fuv_8_sse2 0 #x11048 #x11048 #x0 #x34057a74 #x664db78f #xa9524ebc #x606afd88)\n (fftwf_dft_r2hc_register 0 #x11048 #x11048 #x0 #x576d5db6 #xa6a15f8a #x875d87d5 #x7561a866)\n (fftwf_dft_vrank_geq1_register 0 #x11048 #x11048 #x0 #x1e354940 #xac45f390 #x8260fb76 #x1a44862e)\n (fftwf_rdft_rank0_register 0 #x11048 #x11048 #x0 #xff75c762 #x3a0ee093 #x5b78d592 #x6b6be60e)\n (fftwf_dft_nop_register 0 #x11048 #x11048 #x0 #x4a593e24 #xb5f06ddf #xf11fe7f2 #xc010b545)\n)\n Wisdom=(fftw-3.3.5 fftwf_wisdom #x9e7d4dee #xdb14fed1 #x34bf76a4 #xeb6e8fdf\n (fftwf_codelet_n2fv_12_avx 0 #x10048 #x10048 #x0 #xb0767e46 #x8d41dd22 #x439264a0 #x18435a99)\n (fftwf_rdft_rank0_register 0 #x11048 #x11048 #x0 #xff75c762 #x3a0ee093 #x5b78d592 #x6b6be60e)\n (fftwf_codelet_t2fv_2_avx 0 #x11048 #x11048 #x0 #x34057a74 #x664db78f #xa9524ebc #x606afd88)\n (fftwf_dft_nop_register 0 #x11048 #x11048 #x0 #x4a593e24 #xb5f06ddf #xf11fe7f2 #xc010b545)\n (fftwf_dft_bluestein_register 0 #x11048 #x11048 #x0 #x5e17c068 #x1682c5d6 #x89dd79be #x9b951c0f)\n (fftwf_dft_vrank_geq1_register 0 #x10048 #x10048 #x0 #x2fce15e1 #x178d4f4d #x1e956a41 #xf3fd6b80)\n (fftwf_codelet_t1fuv_4_sse2 0 #x11048 #x11048 #x0 #x2fb84bc5 #x2792028e #x8ec66ed5 #x47b5f7dc)\n (fftwf_dft_buffered_register 0 #x11048 #x11048 #x0 #x4f8e87b4 #xec4f2fa0 #x79fe76a1 #xa16e32a5)\n (fftwf_dft_vrank_geq1_register 0 #x11048 #x11048 #x0 #x8a9c355b #xb6dbadad #xbac1daac #xa866ceb3)\n (fftwf_dft_r2hc_register 0 #x11048 #x11048 #x0 #x576d5db6 #xa6a15f8a #x875d87d5 #x7561a866)\n (fftwf_codelet_t1fv_6_avx 0 #x10048 #x10048 #x0 #xd9db29d8 #x3302fcf3 #x19ce6e5d #x869fc341)\n (fftwf_dft_vrank_geq1_register 0 #x11048 #x11048 #x0 #xf7abab03 #x5f0e79b1 #x1b8367ad #xe5028f2c)\n (fftwf_codelet_t1fv_12_avx 0 #x10048 #x10048 #x0 #x0b0d3933 #x08267d12 #x45613873 #xde496efe)\n)\n
WaterfallMin=0 WaterfallMin=0
WaterfallMax=3300 WaterfallMax=3300
@ -131,6 +134,7 @@ RXFreq2=1700
RXFreq3=500 RXFreq3=500
RXFreq4=1700 RXFreq4=1700
CWIDMark= CWIDMark=
afterTraffic=false
[AGWHost] [AGWHost]
Server=1 Server=1

View File

@ -748,6 +748,9 @@
<height>22</height> <height>22</height>
</rect> </rect>
</property> </property>
<property name="editable">
<bool>true</bool>
</property>
</widget> </widget>
<widget class="QLabel" name="label_5"> <widget class="QLabel" name="label_5">
<property name="geometry"> <property name="geometry">

4
il2p.c
View File

@ -4001,8 +4001,8 @@ void il2p_rec_bit(int chan, int subchan, int slice, int dbit)
if (len > 340) if (len > 340)
{ {
Debugprintf("Packet too big for QtSM"); Debugprintf("Packet too big for QtSM");
// F->state = IL2P_SEARCHING; F->state = IL2P_SEARCHING;
// return; return;
} }
if (F->eplen >= 1) { // Need to gather payload. if (F->eplen >= 1) { // Need to gather payload.
F->pc = 0; F->pc = 0;

View File

@ -1,11 +0,0 @@
#define _MSC_EXTENSIONS
#define _INTEGRAL_MAX_BITS 64
#define _MSC_VER 1916
#define _MSC_FULL_VER 191627043
#define _MSC_BUILD 0
#define _WIN32
#define _M_IX86 600
#define _M_IX86_FP 2
#define _CPPRTTI
#define _MT
#define _DLL

View File

@ -728,7 +728,7 @@ void init_speed(int snd_ch)
form1.show_freq_a; form1.show_freq_a;
form1.show_freq_b; form1.show_freq_b;
*/ */
wf_pointer(soundChannel[snd_ch]); wf_pointer(snd_ch);
CheckPSKWindows(); CheckPSKWindows();
} }

View File

@ -64,6 +64,8 @@ signals:
void sendtoTrace(char *, int); void sendtoTrace(char *, int);
void sendtoKISS(void *, unsigned char *, int); void sendtoKISS(void *, unsigned char *, int);
void openSockets(); void openSockets();
void startCWIDTimer();
private: private:
void run(); void run();