]> sigrok.org Git - pulseview.git/blobdiff - pv/view/analogsignal.h
Added _session reference to Signal objects
[pulseview.git] / pv / view / analogsignal.h
index 86471537abce44236291664b98a1e74084cc187d..7815261ec8cf51d9352bbdb150a377591a062f26 100644 (file)
@@ -29,16 +29,28 @@ namespace pv {
 
 namespace data {
 class Analog;
+class AnalogSnapshot;
 }
 
 namespace view {
 
 class AnalogSignal : public Signal
 {
+private:
+       static const QColor SignalColours[4];
+
+       static const float EnvelopeThreshold;
+
 public:
-       AnalogSignal(QString name,
+       AnalogSignal(pv::SigSession &session, const sr_probe *const probe,
                boost::shared_ptr<pv::data::Analog> data);
 
+       virtual ~AnalogSignal();
+
+       const std::list<QAction*> get_context_bar_actions();
+
+       void set_scale(float scale);
+
        /**
         * Paints the signal with a QPainter
         * @param p the QPainter to paint into.
@@ -52,8 +64,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<pv::data::AnalogSnapshot> &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<pv::data::AnalogSnapshot> &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<pv::data::Analog> _data;
+       float _scale;
 };
 
 } // namespace view