LibreVNA/Software/PC_Application/Traces/tracemarker.h

146 lines
4.1 KiB
C
Raw Normal View History

#ifndef TRACEMARKER_H
#define TRACEMARKER_H
#include <QPixmap>
#include <QObject>
#include "trace.h"
2020-10-20 23:03:49 +08:00
#include <QComboBox>
#include "CustomWidgets/siunitedit.h"
2020-12-05 19:59:23 +08:00
#include "savable.h"
2020-10-20 23:03:49 +08:00
class TraceMarkerModel;
2020-12-05 19:59:23 +08:00
class TraceMarker : public QObject, public Savable
{
Q_OBJECT;
public:
TraceMarker(TraceMarkerModel *model, int number = 1, TraceMarker *parent = nullptr, QString descr = QString());
~TraceMarker();
void assignTrace(Trace *t);
Trace* trace();
QString readableData();
QString readableSettings();
QString tooltipSettings();
QString readableType();
2020-11-23 04:25:41 +08:00
double getPosition() const;
std::complex<double> getData() const;
bool isMovable();
bool isTimeDomain();
QPixmap& getSymbol();
int getNumber() const;
void setNumber(int value);
bool editingFrequency;
2020-10-20 03:21:04 +08:00
Trace *getTrace() const;
2020-12-05 19:59:23 +08:00
enum class Type {
Manual,
Maximum,
Minimum,
Delta,
Noise,
PeakTable,
Lowpass,
Highpass,
Bandpass,
TOI,
PhaseNoise,
// keep last at end
Last,
};
Type getType() const;
2020-10-20 23:03:49 +08:00
QWidget *getTypeEditor(QAbstractItemDelegate *delegate = nullptr);
void updateTypeFromEditor(QWidget *c);
SIUnitEdit* getSettingsEditor();
void adjustSettings(double value);
2020-10-20 23:03:49 +08:00
// Updates marker position and data on automatic markers. Should be called whenever the tracedata is complete
void update();
TraceMarker *getParent() const;
const std::vector<TraceMarker *>& getHelperMarkers() const;
TraceMarker *helperMarker(unsigned int i);
2020-12-05 19:59:23 +08:00
void assignDeltaMarker(TraceMarker *m);
QString getSuffix() const;
2020-10-20 23:03:49 +08:00
2020-12-05 19:59:23 +08:00
virtual nlohmann::json toJSON() override;
virtual void fromJSON(nlohmann::json j) override;
// Markers are referenced by pointers throughout this project (e.g. when added to a trace)
// When saving the current marker configuration, the pointer is not useful (e.g. for determining
// the associated delta marker. Instead a marker hash is saved to identify the correct marker.
// The hash should be influenced by every setting the marker can have. It should not depend on
// the marker data.
unsigned int toHash();
public slots:
2020-11-23 04:25:41 +08:00
void setPosition(double freq);
signals:
void deleted(TraceMarker *m);
void dataChanged(TraceMarker *m);
2020-10-20 23:03:49 +08:00
void symbolChanged(TraceMarker *m);
void typeChanged(TraceMarker *m);
2020-12-05 19:59:23 +08:00
void assignedDeltaChanged(TraceMarker *m);
void traceChanged(TraceMarker *m);
void beginRemoveHelperMarkers(TraceMarker *m);
void endRemoveHelperMarkers(TraceMarker *m);
private slots:
void parentTraceDeleted(Trace *t);
void traceDataChanged();
void updateSymbol();
void checkDeltaMarker();
void deltaDeleted();
2020-10-20 23:03:49 +08:00
signals:
void rawDataChanged();
void domainChanged();
private:
std::set<Type> getSupportedTypes();
2020-10-20 23:03:49 +08:00
static QString typeToString(Type t) {
switch(t) {
case Type::Manual: return "Manual";
case Type::Maximum: return "Maximum";
case Type::Minimum: return "Minimum";
case Type::Delta: return "Delta";
2020-11-09 04:28:47 +08:00
case Type::Noise: return "Noise";
case Type::PeakTable: return "Peak Table";
case Type::Lowpass: return "Lowpass";
case Type::Highpass: return "Highpass";
case Type::Bandpass: return "Bandpass";
case Type::TOI: return "TOI/IP3";
2020-11-09 04:28:47 +08:00
case Type::PhaseNoise: return "Phase noise";
2020-10-20 23:03:49 +08:00
default: return QString();
}
}
2020-11-23 04:25:41 +08:00
void constrainPosition();
TraceMarker *bestDeltaCandidate();
void deleteHelperMarkers();
void setType(Type t);
double toDecibel();
bool isVisible();
2020-10-20 23:03:49 +08:00
TraceMarkerModel *model;
Trace *parentTrace;
2020-11-23 04:25:41 +08:00
double position;
int number;
2020-11-23 04:25:41 +08:00
// Frequency domain: S parameter
// Time domain: impulse response
std::complex<double> data;
QPixmap symbol;
2020-10-20 23:03:49 +08:00
Type type;
QString suffix;
QString description;
2020-10-20 23:03:49 +08:00
TraceMarker *delta;
std::vector<TraceMarker*> helperMarkers;
TraceMarker *parent;
// settings for the different marker types
double cutoffAmplitude;
double peakThreshold;
double offset;
};
#endif // TRACEMARKER_H