X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.hpp;h=eff962311cc549434e51dc48db45f6bda704c5bc;hp=8e09043b22ec811a56a8cfe086047c8bb1af9325;hb=HEAD;hpb=efdec55aec1a137460fa362a381ed1904182bfed diff --git a/pv/views/viewbase.hpp b/pv/views/viewbase.hpp index 8e09043b..972b04ea 100644 --- a/pv/views/viewbase.hpp +++ b/pv/views/viewbase.hpp @@ -21,17 +21,25 @@ #ifndef PULSEVIEW_PV_VIEWS_VIEWBASE_HPP #define PULSEVIEW_PV_VIEWS_VIEWBASE_HPP -#include - +#include #include -#include +#include #include +#include +#include #include #include #include +#ifdef ENABLE_DECODE +#include +#endif + +using std::shared_ptr; +using std::vector; + namespace pv { class Session; @@ -43,44 +51,90 @@ class Signal; namespace views { +// When adding an entry here, don't forget to update ViewTypeNames as well enum ViewType { ViewTypeTrace, - ViewTypeTabularDecode +#ifdef ENABLE_DECODE + ViewTypeDecoderBinary, + ViewTypeTabularDecoder, +#endif + ViewTypeCount // Indicates how many view types there are, must always be last }; -class ViewBase : public QWidget { +extern const char* ViewTypeNames[ViewTypeCount]; + +class ViewBase : public QWidget +{ Q_OBJECT public: - explicit ViewBase(Session &session, QWidget *parent = 0); + static const int MaxViewAutoUpdateRate; + +public: + explicit ViewBase(Session &session, bool is_main_view = false, QMainWindow *parent = nullptr); + + virtual ViewType get_type() const = 0; + bool is_main_view() const; + + /** + * Resets the view to its default state after construction. It does however + * not reset the signal bases or any other connections with the session. + */ + virtual void reset_view_state(); Session& session(); const Session& session() const; - virtual void clear_signals(); + /** + * Returns the signal bases contained in this view. + */ + vector< shared_ptr > signalbases() const; + + virtual void clear_signalbases(); + virtual void add_signalbase(const shared_ptr signalbase); + virtual void remove_signalbase(const shared_ptr signalbase); #ifdef ENABLE_DECODE virtual void clear_decode_signals(); - - virtual void add_decode_signal(std::shared_ptr signalbase); - - virtual void remove_decode_signal(std::shared_ptr signalbase); + virtual void add_decode_signal(shared_ptr signal); + virtual void remove_decode_signal(shared_ptr signal); #endif virtual void save_settings(QSettings &settings) const; - virtual void restore_settings(QSettings &settings); + virtual void focus_on_range(uint64_t start_sample, uint64_t end_sample); + public Q_SLOTS: - virtual void trigger_event(util::Timestamp location); + virtual void trigger_event(int segment_id, util::Timestamp location); virtual void signals_changed(); virtual void capture_state_updated(int state); - virtual void data_updated(); + virtual void on_new_segment(int new_segment_id); + virtual void on_segment_completed(int new_segment_id); + virtual void perform_delayed_view_update(); + +private Q_SLOTS: + void on_samples_added(uint64_t segment_id, uint64_t start_sample, + uint64_t end_sample); + + void on_data_updated(); protected: Session &session_; + const bool is_main_view_; + util::TimeUnit time_unit_; + + vector< shared_ptr > signalbases_; +#ifdef ENABLE_DECODE + vector< shared_ptr > decode_signals_; +#endif + + /// The ID of the currently displayed segment + uint32_t current_segment_; + + QTimer delayed_view_updater_; }; } // namespace views