X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Ftrace%2Fanalogsignal.hpp;h=4c42e579b662e596289b65828b9a3c6edf4e3f56;hp=c588eb88bf26e33abb7e7a8ac0fc53e7dc30af47;hb=HEAD;hpb=0a952555b9d153f42912e47f35fac5dd4643fca9
diff --git a/pv/views/trace/analogsignal.hpp b/pv/views/trace/analogsignal.hpp
index c588eb88..6fbcc24b 100644
--- a/pv/views/trace/analogsignal.hpp
+++ b/pv/views/trace/analogsignal.hpp
@@ -17,8 +17,8 @@
* along with this program; if not, see .
*/
-#ifndef PULSEVIEW_PV_VIEWS_TRACEVIEW_ANALOGSIGNAL_HPP
-#define PULSEVIEW_PV_VIEWS_TRACEVIEW_ANALOGSIGNAL_HPP
+#ifndef PULSEVIEW_PV_VIEWS_TRACE_ANALOGSIGNAL_HPP
+#define PULSEVIEW_PV_VIEWS_TRACE_ANALOGSIGNAL_HPP
#include
@@ -27,6 +27,7 @@
#include
#include
+#include
using std::pair;
using std::shared_ptr;
@@ -42,15 +43,13 @@ class SignalBase;
namespace views {
namespace trace {
-class AnalogSignal : public Signal
+class AnalogSignal : public LogicSignal
{
Q_OBJECT
private:
static const QPen AxisPen;
- static const QColor SignalColors[4];
static const QColor GridMajorColor, GridMinorColor;
- static const QColor SamplingPointColor;
static const QColor SamplingPointColorLo;
static const QColor SamplingPointColorNe;
static const QColor SamplingPointColorHi;
@@ -75,8 +74,6 @@ private:
public:
AnalogSignal(pv::Session &session, shared_ptr base);
- shared_ptr data() const;
-
virtual std::map save_settings() const;
virtual void restore_settings(std::map settings);
@@ -84,28 +81,28 @@ public:
* Computes the vertical extents of the contents of this row item.
* @return A pair containing the minimum and maximum y-values.
*/
- pair v_extents() const;
+ virtual pair v_extents() const;
/**
* Paints the background layer of the signal with a QPainter
* @param p the QPainter to paint into.
* @param pp the painting parameters object to paint with..
*/
- void paint_back(QPainter &p, ViewItemPaintParams &pp);
+ virtual void paint_back(QPainter &p, ViewItemPaintParams &pp);
/**
* Paints the mid-layer of the signal with a QPainter
* @param p the QPainter to paint into.
* @param pp the painting parameters object to paint with..
*/
- void paint_mid(QPainter &p, ViewItemPaintParams &pp);
+ virtual void paint_mid(QPainter &p, ViewItemPaintParams &pp);
/**
* Paints the foreground layer of the item with a QPainter
* @param p the QPainter to paint into.
* @param pp the painting parameters object to paint with.
*/
- void paint_fore(QPainter &p, ViewItemPaintParams &pp);
+ virtual void paint_fore(QPainter &p, ViewItemPaintParams &pp);
private:
void paint_grid(QPainter &p, int y, int left, int right);
@@ -120,15 +117,7 @@ private:
int y, int left, const int64_t start, const int64_t end,
const double pixels_offset, const double samples_per_pixel);
- void paint_logic_mid(QPainter &p, ViewItemPaintParams &pp);
-
- void paint_logic_caps(QPainter &p, QLineF *const lines,
- vector< pair > &edges,
- bool level, double samples_per_pixel, double pixels_offset,
- float x_offset, float y_offset);
-
shared_ptr get_analog_segment_to_paint() const;
- shared_ptr get_logic_segment_to_paint() const;
/**
* Computes the scale factor from the scale index and vdiv settings.
@@ -136,6 +125,7 @@ private:
float get_resolution(int scale_index);
void update_scale();
+ virtual void update_logic_level_offsets();
void update_conversion_widgets();
@@ -197,7 +187,8 @@ private:
int current_pixel_pos_; // Only used during lookup table update
// ---------------------------------------------------------------------------
- // Note: Make sure to update .. when adding a trace-configurable variable here
+ // Note: Make sure to update save_settings() and restore_settings() when
+ // adding a trace-configurable variable here
float scale_;
int scale_index_;
@@ -213,4 +204,4 @@ private:
} // namespace views
} // namespace pv
-#endif // PULSEVIEW_PV_VIEWS_TRACEVIEW_ANALOGSIGNAL_HPP
+#endif // PULSEVIEW_PV_VIEWS_TRACE_ANALOGSIGNAL_HPP