X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fmainwindow.hpp;h=2bd8dadbf815d8ebdc594c9a3afb92208319a3ad;hp=c7859d0a4cb43ec9f7256d8fcdaf5153c4e931a6;hb=c9da51187f8db0c9822d544a0253e0e7a58945d7;hpb=2b81ae4682ade4109ffa442794de36ceb32045eb diff --git a/pv/mainwindow.hpp b/pv/mainwindow.hpp index c7859d0a..2bd8dadb 100644 --- a/pv/mainwindow.hpp +++ b/pv/mainwindow.hpp @@ -18,15 +18,17 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef PULSEVIEW_PV_MAINWINDOW_H -#define PULSEVIEW_PV_MAINWINDOW_H +#ifndef PULSEVIEW_PV_MAINWINDOW_HPP +#define PULSEVIEW_PV_MAINWINDOW_HPP #include +#include #include #include -#include "sigsession.hpp" +#include "session.hpp" +#include "view/viewwidget.hpp" struct srd_decoder; @@ -38,7 +40,7 @@ class DeviceManager; namespace toolbars { class ContextBar; -class SamplingBar; +class MainBar; } namespace view { @@ -46,7 +48,9 @@ class View; } namespace widgets { +#ifdef ENABLE_DECODE class DecoderMenu; +#endif } class MainWindow : public QMainWindow @@ -55,10 +59,22 @@ class MainWindow : public QMainWindow public: explicit MainWindow(DeviceManager &device_manager, - const char *open_file_name = NULL, + std::string open_file_name = std::string(), + std::string open_file_format = std::string(), QWidget *parent = 0); - void run_stop(); + ~MainWindow(); + + QAction* action_view_sticky_scrolling() const; + QAction* action_view_coloured_bg() const; + QAction* action_about() const; + + std::shared_ptr get_active_view() const; + + std::shared_ptr add_view(const QString &title, + view::ViewType type, Session &session); + + std::shared_ptr add_session(); private: void setup_ui(); @@ -67,69 +83,39 @@ private: void restore_ui_settings(); - void session_error(const QString text, const QString info_text); - - /** - * Updates the device list in the sampling bar - */ - void update_device_list(); - +private: void closeEvent(QCloseEvent *event); -private Q_SLOTS: - void load_file(QString file_name); - - void show_session_error( - const QString text, const QString info_text); - - void on_actionOpen_triggered(); - void on_actionSaveAs_triggered(); - void on_actionQuit_triggered(); + virtual QMenu* createPopupMenu(); - void on_actionConnect_triggered(); + virtual bool restoreState(const QByteArray &state, int version = 0); - void on_actionViewZoomIn_triggered(); - - void on_actionViewZoomOut_triggered(); +private Q_SLOTS: + void on_add_view(const QString &title, view::ViewType type, + Session *session); - void on_actionViewZoomFit_triggered(); + void on_new_session(); + void on_new_view(Session *session); - void on_actionViewZoomOneToOne_triggered(); + void on_actionViewStickyScrolling_triggered(); - void on_actionViewShowCursors_triggered(); + void on_actionViewColouredBg_triggered(); void on_actionAbout_triggered(); - void add_decoder(srd_decoder *decoder); - - void capture_state_changed(int state); - void device_selected(); - private: - /** - * Name of the setting used to remember the directory - * containing the last file that was opened. - */ - static const char *SettingOpenDirectory; - - /** - * Name of the setting used to remember the directory - * containing the last file that was saved. - */ - static const char *SettingSaveDirectory; - DeviceManager &device_manager_; - Session session_; - - pv::view::View *view_; + std::vector< std::shared_ptr > sessions_; - QWidget *central_widget_; - QVBoxLayout *vertical_layout_; + std::map< std::shared_ptr, + std::shared_ptr > view_docks_; - toolbars::SamplingBar *sampling_bar_; + QAction *const action_view_sticky_scrolling_; + QAction *const action_view_coloured_bg_; + QAction *const action_about_; }; } // namespace pv -#endif // PULSEVIEW_PV_MAINWINDOW_H +#endif // PULSEVIEW_PV_MAINWINDOW_HPP