]> sigrok.org Git - pulseview.git/blobdiff - pv/mainwindow.hpp
Make view windows non-closeable
[pulseview.git] / pv / mainwindow.hpp
index bf0aa125b090ebe43ebd5951ad4f03b334cce884..91a0bc5d69d971076f8191b01f9d53316864acfc 100644 (file)
@@ -30,6 +30,7 @@
 #include <QMainWindow>
 
 #include "session.hpp"
+#include "view/viewwidget.hpp"
 
 struct srd_decoder;
 
@@ -92,6 +93,7 @@ public:
        QAction* action_view_zoom_fit() const;
        QAction* action_view_zoom_one_to_one() const;
        QAction* action_view_sticky_scrolling() const;
+       QAction* action_view_coloured_bg() const;
        QAction* action_view_show_cursors() const;
        QAction* action_about() const;
 
@@ -99,6 +101,11 @@ public:
        QMenu* menu_decoder_add() const;
 #endif
 
+       std::shared_ptr<pv::view::View> get_active_view() const;
+
+       std::shared_ptr<pv::view::View> add_view(const QString &title,
+               view::ViewType type, Session &session);
+
        void run_stop();
 
        void select_device(std::shared_ptr<devices::Device> device);
@@ -160,6 +167,8 @@ private Q_SLOTS:
 
        void on_actionViewStickyScrolling_triggered();
 
+       void on_actionViewColouredBg_triggered();
+
        void on_actionViewShowCursors_triggered();
 
        void on_actionAbout_triggered();
@@ -178,10 +187,8 @@ private:
 
        Session session_;
 
-       pv::view::View *view_;
-
-       QWidget *central_widget_;
-       QVBoxLayout *vertical_layout_;
+       std::map< std::shared_ptr<QDockWidget>,
+               std::shared_ptr<pv::view::View> > view_docks_;
 
        toolbars::MainBar *main_bar_;
 
@@ -195,6 +202,7 @@ private:
        QAction *const action_view_zoom_fit_;
        QAction *const action_view_zoom_one_to_one_;
        QAction *const action_view_sticky_scrolling_;
+       QAction *const action_view_coloured_bg_;
        QAction *const action_view_show_cursors_;
        QAction *const action_about_;