mirror of
https://github.com/jankae/LibreVNA.git
synced 2025-12-06 07:12:10 +01:00
initialize new plots with the correct span
Some checks failed
Build / PC_Application_Ubuntu (push) Has been cancelled
Build / PC_Application_RPi5 (push) Has been cancelled
Build / PC_Application_Windows (push) Has been cancelled
Build / PC_Application_OSX (push) Has been cancelled
Build / PC_Application_OSX_13 (push) Has been cancelled
Build / Embedded_Firmware (push) Has been cancelled
HIL_Tests / Get_Repository (push) Has been cancelled
Unit_Tests / Tests (push) Has been cancelled
HIL_Tests / PC_Application_RPi5 (push) Has been cancelled
HIL_Tests / Embedded_Firmware (push) Has been cancelled
HIL_Tests / HIL (push) Has been cancelled
Some checks failed
Build / PC_Application_Ubuntu (push) Has been cancelled
Build / PC_Application_RPi5 (push) Has been cancelled
Build / PC_Application_Windows (push) Has been cancelled
Build / PC_Application_OSX (push) Has been cancelled
Build / PC_Application_OSX_13 (push) Has been cancelled
Build / Embedded_Firmware (push) Has been cancelled
HIL_Tests / Get_Repository (push) Has been cancelled
Unit_Tests / Tests (push) Has been cancelled
HIL_Tests / PC_Application_RPi5 (push) Has been cancelled
HIL_Tests / Embedded_Firmware (push) Has been cancelled
HIL_Tests / HIL (push) Has been cancelled
This commit is contained in:
parent
7acb847a2b
commit
d77215aecb
|
|
@ -914,7 +914,7 @@ void SpectrumAnalyzer::ConfigureDevice()
|
||||||
average.reset(DeviceDriver::SApoints());
|
average.reset(DeviceDriver::SApoints());
|
||||||
UpdateAverageCount();
|
UpdateAverageCount();
|
||||||
traceModel.clearLiveData();
|
traceModel.clearLiveData();
|
||||||
emit traceModel.SpanChanged(settings.freqStart, settings.freqStop);
|
traceModel.setSpan(settings.freqStart, settings.freqStop);
|
||||||
} else {
|
} else {
|
||||||
if(window->getDevice()) {
|
if(window->getDevice()) {
|
||||||
changingSettings = true;
|
changingSettings = true;
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,8 @@ using namespace std;
|
||||||
TraceModel::TraceModel(QObject *parent)
|
TraceModel::TraceModel(QObject *parent)
|
||||||
: QAbstractTableModel(parent)
|
: QAbstractTableModel(parent)
|
||||||
{
|
{
|
||||||
|
spanFmin = 0.0;
|
||||||
|
spanFmax = 6000000000.0;
|
||||||
traces.clear();
|
traces.clear();
|
||||||
source = DataSource::Unknown;
|
source = DataSource::Unknown;
|
||||||
lastSweepPosition = 0.0;
|
lastSweepPosition = 0.0;
|
||||||
|
|
@ -368,6 +370,13 @@ double TraceModel::getSweepPosition() const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TraceModel::setSpan(double fmin, double fmax)
|
||||||
|
{
|
||||||
|
spanFmin = fmin;
|
||||||
|
spanFmax = fmax;
|
||||||
|
emit SpanChanged(fmin, fmax);
|
||||||
|
}
|
||||||
|
|
||||||
MarkerModel *TraceModel::getMarkerModel() const
|
MarkerModel *TraceModel::getMarkerModel() const
|
||||||
{
|
{
|
||||||
return markerModel;
|
return markerModel;
|
||||||
|
|
|
||||||
|
|
@ -62,6 +62,10 @@ public:
|
||||||
|
|
||||||
double getSweepPosition() const;
|
double getSweepPosition() const;
|
||||||
|
|
||||||
|
void setSpan(double fmin, double fmax);
|
||||||
|
double getSpanStart() {return spanFmin;}
|
||||||
|
double getSpanStop() {return spanFmax;}
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void SpanChanged(double fmin, double fmax);
|
void SpanChanged(double fmin, double fmax);
|
||||||
void traceAdded(Trace *t);
|
void traceAdded(Trace *t);
|
||||||
|
|
@ -80,6 +84,8 @@ private:
|
||||||
QDateTime lastReceivedData;
|
QDateTime lastReceivedData;
|
||||||
std::vector<Trace*> traces;
|
std::vector<Trace*> traces;
|
||||||
MarkerModel *markerModel;
|
MarkerModel *markerModel;
|
||||||
|
|
||||||
|
double spanFmin, spanFmax;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // TRACEMODEL_H
|
#endif // TRACEMODEL_H
|
||||||
|
|
|
||||||
|
|
@ -42,8 +42,7 @@ TracePlot::TracePlot(TraceModel &model, QWidget *parent)
|
||||||
lastUpdate = QTime::currentTime();
|
lastUpdate = QTime::currentTime();
|
||||||
replotTimer.setSingleShot(true);
|
replotTimer.setSingleShot(true);
|
||||||
connect(&replotTimer, &QTimer::timeout, this, qOverload<>(&TracePlot::update));
|
connect(&replotTimer, &QTimer::timeout, this, qOverload<>(&TracePlot::update));
|
||||||
sweep_fmin = std::numeric_limits<double>::lowest();
|
TracePlot::updateSpan(model.getSpanStart(), model.getSpanStop());
|
||||||
sweep_fmax = std::numeric_limits<double>::max();
|
|
||||||
xSweep = std::numeric_limits<double>::quiet_NaN();
|
xSweep = std::numeric_limits<double>::quiet_NaN();
|
||||||
// get notified when the span changes
|
// get notified when the span changes
|
||||||
connect(&model, &TraceModel::SpanChanged, this, qOverload<double, double>(&TracePlot::updateSpan));
|
connect(&model, &TraceModel::SpanChanged, this, qOverload<double, double>(&TracePlot::updateSpan));
|
||||||
|
|
|
||||||
|
|
@ -29,8 +29,7 @@ TraceXYPlot::TraceXYPlot(TraceModel &model, QWidget *parent)
|
||||||
// Setup default axis
|
// Setup default axis
|
||||||
setYAxis(0, YAxis::Type::Magnitude, false, false, YAxis::getDefaultLimitMin(YAxis::Type::Magnitude), YAxis::getDefaultLimitMax(YAxis::Type::Magnitude), 14, true);
|
setYAxis(0, YAxis::Type::Magnitude, false, false, YAxis::getDefaultLimitMin(YAxis::Type::Magnitude), YAxis::getDefaultLimitMax(YAxis::Type::Magnitude), 14, true);
|
||||||
setYAxis(1, YAxis::Type::Phase, false, false, YAxis::getDefaultLimitMin(YAxis::Type::Phase), YAxis::getDefaultLimitMax(YAxis::Type::Phase), 12, true);
|
setYAxis(1, YAxis::Type::Phase, false, false, YAxis::getDefaultLimitMin(YAxis::Type::Phase), YAxis::getDefaultLimitMax(YAxis::Type::Phase), 12, true);
|
||||||
// enable autoscaling and set for full span (no information about actual span available yet)
|
|
||||||
updateSpan(0, 6000000000);
|
|
||||||
setXAxis(XAxis::Type::Frequency, XAxisMode::UseSpan, false, 0, 6000000000, 10, true);
|
setXAxis(XAxis::Type::Frequency, XAxisMode::UseSpan, false, 0, 6000000000, 10, true);
|
||||||
initializeTraceInfo();
|
initializeTraceInfo();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1961,7 +1961,7 @@ void VNA::ConfigureDevice(bool resetTraces, std::function<void(bool)> cb)
|
||||||
double start = settings.sweepType == SweepType::Frequency ? settings.Freq.start : settings.Power.start;
|
double start = settings.sweepType == SweepType::Frequency ? settings.Freq.start : settings.Power.start;
|
||||||
double stop = settings.sweepType == SweepType::Frequency ? settings.Freq.stop : settings.Power.stop;
|
double stop = settings.sweepType == SweepType::Frequency ? settings.Freq.stop : settings.Power.stop;
|
||||||
int npoints = settings.npoints;
|
int npoints = settings.npoints;
|
||||||
emit traceModel.SpanChanged(start, stop);
|
traceModel.setSpan(start, stop);
|
||||||
if (settings.segments > 1) {
|
if (settings.segments > 1) {
|
||||||
// more than one segment, adjust start/stop
|
// more than one segment, adjust start/stop
|
||||||
npoints = ceil((double) settings.npoints / settings.segments);
|
npoints = ceil((double) settings.npoints / settings.segments);
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue