X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fview%2Fanalogsignal.h;h=ce1dff105041a77934355f302e5a80168f1cdbff;hp=6e4199acf16f7427382e8aeffee838791d8540e9;hb=4d5d5d6aeb7d936fb6b939f6c6531b3f054dac1f;hpb=568b90d4fcfb5f67f5fb642a9f0fdb3a54607bf3 diff --git a/pv/view/analogsignal.h b/pv/view/analogsignal.h index 6e4199ac..ce1dff10 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,10 +39,14 @@ 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); + void set_scale(float scale); + /** * Paints the signal with a QPainter * @param p the QPainter to paint into. @@ -55,8 +60,20 @@ 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; }; } // namespace view