X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fview%2Fanalogsignal.h;h=7815261ec8cf51d9352bbdb150a377591a062f26;hb=82c7f64018db2a90f44704e55ba469151522762f;hp=bb4a2109c0bd4d8d461434afae9a552ce39645da;hpb=785fd8d138e5866ade499c02ea405b8852fee113;p=pulseview.git diff --git a/pv/view/analogsignal.h b/pv/view/analogsignal.h index bb4a2109..7815261e 100644 --- a/pv/view/analogsignal.h +++ b/pv/view/analogsignal.h @@ -29,6 +29,7 @@ namespace pv { namespace data { class Analog; +class AnalogSnapshot; } namespace view { @@ -38,9 +39,15 @@ class AnalogSignal : public Signal private: static const QColor SignalColours[4]; + static const float EnvelopeThreshold; + public: - AnalogSignal(QString name, - boost::shared_ptr data, int probe_index); + AnalogSignal(pv::SigSession &session, const sr_probe *const probe, + boost::shared_ptr data); + + virtual ~AnalogSignal(); + + const std::list get_context_bar_actions(); void set_scale(float scale); @@ -57,6 +64,17 @@ public: void paint(QPainter &p, int y, int left, int right, double scale, double offset); +private: + void paint_trace(QPainter &p, + const boost::shared_ptr &snapshot, + int y, int left, const int64_t start, const int64_t end, + const double pixels_offset, const double samples_per_pixel); + + void paint_envelope(QPainter &p, + const boost::shared_ptr &snapshot, + int y, int left, const int64_t start, const int64_t end, + const double pixels_offset, const double samples_per_pixel); + private: boost::shared_ptr _data; float _scale;