2020-08-31 04:03:41 +08:00
|
|
|
#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"
|
|
|
|
|
|
|
|
class TraceMarkerModel;
|
2020-08-31 04:03:41 +08:00
|
|
|
|
|
|
|
class TraceMarker : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT;
|
|
|
|
public:
|
2020-11-03 07:37:06 +08:00
|
|
|
TraceMarker(TraceMarkerModel *model, int number = 1, TraceMarker *parent = nullptr, QString descr = QString());
|
2020-08-31 04:03:41 +08:00
|
|
|
~TraceMarker();
|
2020-11-23 04:25:41 +08:00
|
|
|
void setTimeDomain(bool timeDomain);
|
2020-08-31 04:03:41 +08:00
|
|
|
void assignTrace(Trace *t);
|
|
|
|
Trace* trace();
|
|
|
|
QString readableData();
|
2020-10-21 01:15:06 +08:00
|
|
|
QString readableSettings();
|
2020-11-03 07:37:06 +08:00
|
|
|
QString readableType();
|
2020-08-31 04:03:41 +08:00
|
|
|
|
2020-11-23 04:25:41 +08:00
|
|
|
double getPosition() const;
|
2020-08-31 04:03:41 +08:00
|
|
|
std::complex<double> getData() const;
|
2020-11-23 04:25:41 +08:00
|
|
|
Trace::TimedomainData getTimeData() const;
|
2020-11-03 07:37:06 +08:00
|
|
|
bool isMovable();
|
2020-08-31 04:03:41 +08:00
|
|
|
|
|
|
|
QPixmap& getSymbol();
|
|
|
|
|
|
|
|
int getNumber() const;
|
2020-11-03 07:37:06 +08:00
|
|
|
void setNumber(int value);
|
|
|
|
|
2020-09-21 20:06:20 +08:00
|
|
|
bool editingFrequeny;
|
2020-10-20 03:21:04 +08:00
|
|
|
Trace *getTrace() const;
|
|
|
|
|
2020-10-20 23:03:49 +08:00
|
|
|
|
|
|
|
QWidget *getTypeEditor(QAbstractItemDelegate *delegate = nullptr);
|
|
|
|
void updateTypeFromEditor(QWidget *c);
|
|
|
|
SIUnitEdit* getSettingsEditor();
|
2020-10-21 01:15:06 +08:00
|
|
|
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();
|
2020-11-03 07:37:06 +08:00
|
|
|
TraceMarker *getParent() const;
|
|
|
|
const std::vector<TraceMarker *>& getHelperMarkers() const;
|
|
|
|
TraceMarker *helperMarker(unsigned int i);
|
|
|
|
QString getSuffix() const;
|
2020-10-20 23:03:49 +08:00
|
|
|
|
2020-11-23 04:25:41 +08:00
|
|
|
bool isTimeDomain() const;
|
|
|
|
|
2020-08-31 04:03:41 +08:00
|
|
|
public slots:
|
2020-11-23 04:25:41 +08:00
|
|
|
void setPosition(double freq);
|
2020-08-31 04:03:41 +08:00
|
|
|
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-11-03 07:37:06 +08:00
|
|
|
void traceChanged(TraceMarker *m);
|
|
|
|
void beginRemoveHelperMarkers(TraceMarker *m);
|
|
|
|
void endRemoveHelperMarkers(TraceMarker *m);
|
2020-11-23 04:25:41 +08:00
|
|
|
void timeDomainChanged();
|
2020-08-31 04:03:41 +08:00
|
|
|
|
|
|
|
private slots:
|
|
|
|
void parentTraceDeleted(Trace *t);
|
|
|
|
void traceDataChanged();
|
|
|
|
void updateSymbol();
|
2020-10-20 23:03:49 +08:00
|
|
|
signals:
|
|
|
|
void rawDataChanged();
|
2020-08-31 04:03:41 +08:00
|
|
|
private:
|
2020-10-20 23:03:49 +08:00
|
|
|
|
|
|
|
enum class Type {
|
|
|
|
Manual,
|
|
|
|
Maximum,
|
|
|
|
Minimum,
|
|
|
|
Delta,
|
2020-11-09 04:28:47 +08:00
|
|
|
Noise,
|
2020-11-03 07:37:06 +08:00
|
|
|
PeakTable,
|
2020-10-21 01:15:06 +08:00
|
|
|
Lowpass,
|
|
|
|
Highpass,
|
|
|
|
Bandpass,
|
2020-10-23 20:12:45 +08:00
|
|
|
TOI,
|
2020-11-09 04:28:47 +08:00
|
|
|
PhaseNoise,
|
2020-10-20 23:03:49 +08:00
|
|
|
};
|
2020-10-23 20:12:45 +08:00
|
|
|
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";
|
2020-11-03 07:37:06 +08:00
|
|
|
case Type::PeakTable: return "Peak Table";
|
2020-10-21 01:15:06 +08:00
|
|
|
case Type::Lowpass: return "Lowpass";
|
|
|
|
case Type::Highpass: return "Highpass";
|
|
|
|
case Type::Bandpass: return "Bandpass";
|
2020-10-23 20:12:45 +08:00
|
|
|
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();
|
2020-10-20 23:03:49 +08:00
|
|
|
void assignDeltaMarker(TraceMarker *m);
|
2020-10-21 01:15:06 +08:00
|
|
|
void deleteHelperMarkers();
|
2020-10-23 20:12:45 +08:00
|
|
|
void setType(Type t);
|
|
|
|
double toDecibel();
|
2020-11-03 07:37:06 +08:00
|
|
|
bool isVisible();
|
2020-10-20 23:03:49 +08:00
|
|
|
|
|
|
|
TraceMarkerModel *model;
|
2020-08-31 04:03:41 +08:00
|
|
|
Trace *parentTrace;
|
2020-11-23 04:25:41 +08:00
|
|
|
double position;
|
2020-08-31 04:03:41 +08:00
|
|
|
int number;
|
2020-11-23 04:25:41 +08:00
|
|
|
// Frequency domain: S parameter
|
|
|
|
// Time domain: imag part is impulse response, real part is step response
|
2020-08-31 04:03:41 +08:00
|
|
|
std::complex<double> data;
|
2020-11-23 04:25:41 +08:00
|
|
|
Trace::TimedomainData timeData;
|
2020-08-31 04:03:41 +08:00
|
|
|
QPixmap symbol;
|
2020-10-20 23:03:49 +08:00
|
|
|
Type type;
|
2020-10-21 01:15:06 +08:00
|
|
|
QString suffix;
|
2020-11-03 07:37:06 +08:00
|
|
|
QString description;
|
2020-10-20 23:03:49 +08:00
|
|
|
|
|
|
|
TraceMarker *delta;
|
2020-10-21 01:15:06 +08:00
|
|
|
std::vector<TraceMarker*> helperMarkers;
|
2020-11-03 07:37:06 +08:00
|
|
|
TraceMarker *parent;
|
2020-11-09 04:28:47 +08:00
|
|
|
union {
|
|
|
|
double cutoffAmplitude;
|
|
|
|
double peakThreshold;
|
|
|
|
double offset;
|
|
|
|
};
|
2020-11-23 04:25:41 +08:00
|
|
|
|
|
|
|
bool timeDomain;
|
2020-08-31 04:03:41 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // TRACEMARKER_H
|