X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.hpp;h=e6a003a596c7ddda4b03226af3b759f21e4aa75f;hp=3e180830f897574de522b460cf775f43a264361e;hb=873e80357d9622678069fcfe83b010717a68284c;hpb=143d322d0c92ea5c2cc51facc37b68787362c244 diff --git a/pv/views/viewbase.hpp b/pv/views/viewbase.hpp index 3e180830..e6a003a5 100644 --- a/pv/views/viewbase.hpp +++ b/pv/views/viewbase.hpp @@ -21,17 +21,24 @@ #ifndef PULSEVIEW_PV_VIEWS_VIEWBASE_HPP #define PULSEVIEW_PV_VIEWS_VIEWBASE_HPP -#include - +#include #include -#include +#include #include +#include #include #include #include +#ifdef ENABLE_DECODE +#include +#endif + +using std::shared_ptr; +using std::unordered_set; + namespace pv { class Session; @@ -48,23 +55,36 @@ enum ViewType { ViewTypeTabularDecode }; -class ViewBase : public QWidget { +class ViewBase : public QWidget +{ Q_OBJECT +private: + static const int MaxViewAutoUpdateRate; + public: - explicit ViewBase(Session &session, bool is_main_view=false, QWidget *parent = 0); + explicit ViewBase(Session &session, bool is_main_view = false, QWidget *parent = nullptr); Session& session(); const Session& session() const; 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(); - virtual void add_decode_signal(std::shared_ptr signalbase); + virtual void add_decode_signal(shared_ptr signal); - virtual void remove_decode_signal(std::shared_ptr signalbase); + virtual void remove_decode_signal(shared_ptr signal); #endif virtual void save_settings(QSettings &settings) const; @@ -75,7 +95,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_; @@ -83,6 +106,10 @@ protected: const bool is_main_view_; util::TimeUnit time_unit_; + + unordered_set< shared_ptr > signalbases_; + + QTimer delayed_view_updater_; }; } // namespace views