X-Git-Url: http://git.code-monkey.de/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.hpp;h=61430136f5b032a347bf495ea7cb6ecd56cce45f;hp=45aae7f1021f7797e0dc11cf5e53484a81d80f7e;hb=5ed05b699e5367bae21828f533e3d169b9bab348;hpb=17c7f31c7bb674d5017a8de66a5816e34542abb8 diff --git a/pv/views/viewbase.hpp b/pv/views/viewbase.hpp index 45aae7f..6143013 100644 --- a/pv/views/viewbase.hpp +++ b/pv/views/viewbase.hpp @@ -23,15 +23,17 @@ #include #include -#include +#include #include +#include #include #include #include using std::shared_ptr; +using std::unordered_set; namespace pv { @@ -53,6 +55,9 @@ class ViewBase : public QWidget { Q_OBJECT +private: + static const int MaxViewAutoUpdateRate; + public: explicit ViewBase(Session &session, bool is_main_view = false, QWidget *parent = nullptr); @@ -61,6 +66,15 @@ public: virtual void clear_signals(); + /** + * Returns the signal bases contained in this view. + */ + unordered_set< shared_ptr > signalbases() const; + + virtual void clear_signalbases(); + + virtual void add_signalbase(const shared_ptr signalbase); + #ifdef ENABLE_DECODE virtual void clear_decode_signals(); @@ -77,7 +91,10 @@ public Q_SLOTS: virtual void trigger_event(util::Timestamp location); virtual void signals_changed(); virtual void capture_state_updated(int state); - virtual void data_updated(); + virtual void perform_delayed_view_update(); + +private Q_SLOTS: + void on_data_updated(); protected: Session &session_; @@ -85,6 +102,10 @@ protected: const bool is_main_view_; util::TimeUnit time_unit_; + + unordered_set< shared_ptr > signalbases_; + + QTimer delayed_view_updater_; }; } // namespace views