X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fviews%2Fviewbase.cpp;h=ecdefdcde294a68f188336f8b47180155057ab9e;hb=ec4f16ff84c688f2572c6e3d2e2184aee95f46f7;hp=11ff7a273b6af3a2892fdfcf6c7287f2f99d12c6;hpb=7f894d958eb5221161f0c6f2abbb57d43bb6aae7;p=pulseview.git diff --git a/pv/views/viewbase.cpp b/pv/views/viewbase.cpp index 11ff7a27..ecdefdcd 100644 --- a/pv/views/viewbase.cpp +++ b/pv/views/viewbase.cpp @@ -33,13 +33,20 @@ using std::shared_ptr; namespace pv { namespace views { +const char* ViewTypeNames[ViewTypeCount] = { + "Trace View", +#ifdef ENABLE_DECODE + "Decoder Output View" +#endif +}; + const int ViewBase::MaxViewAutoUpdateRate = 25; // No more than 25 Hz -ViewBase::ViewBase(Session &session, bool is_main_view, QWidget *parent) : +ViewBase::ViewBase(Session &session, bool is_main_view, QMainWindow *parent) : + // Note: Place defaults in ViewBase::reset_view_state(), not here + QWidget(parent), session_(session), - is_main_view_(is_main_view), - ruler_shift_(0), - current_segment_(0) + is_main_view_(is_main_view) { (void)parent; @@ -56,6 +63,16 @@ ViewBase::ViewBase(Session &session, bool is_main_view, QWidget *parent) : delayed_view_updater_.setInterval(1000 / MaxViewAutoUpdateRate); } +bool ViewBase::is_main_view() const +{ + return is_main_view_; +} + +void ViewBase::reset_view_state() +{ + current_segment_ = 0; +} + Session& ViewBase::session() { return session_; @@ -68,6 +85,7 @@ const Session& ViewBase::session() const void ViewBase::clear_signals() { + clear_signalbases(); } unordered_set< shared_ptr > ViewBase::signalbases() const @@ -77,7 +95,7 @@ unordered_set< shared_ptr > ViewBase::signalbases() const void ViewBase::clear_signalbases() { - for (shared_ptr signalbase : signalbases_) { + for (const shared_ptr& signalbase : signalbases_) { disconnect(signalbase.get(), SIGNAL(samples_cleared()), this, SLOT(on_data_updated())); disconnect(signalbase.get(), SIGNAL(samples_added(uint64_t, uint64_t, uint64_t)), @@ -100,16 +118,17 @@ void ViewBase::add_signalbase(const shared_ptr signalbase) #ifdef ENABLE_DECODE void ViewBase::clear_decode_signals() { + decode_signals_.clear(); } void ViewBase::add_decode_signal(shared_ptr signal) { - (void)signal; + decode_signals_.insert(signal); } void ViewBase::remove_decode_signal(shared_ptr signal) { - (void)signal; + decode_signals_.erase(signal); } #endif