X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;f=pv%2Fmainwindow.hpp;h=485b7b6df18243e8a7aa2085290639b86e6268e5;hb=0f8f8c180b32413177f3940ea6f216d1cbadf09b;hp=9a000c2a261f54e3123cdaf7c81d9bc0459e4c12;hpb=2acdb232d6bb452cfdfaea3ef5218fb4da592329;p=pulseview.git diff --git a/pv/mainwindow.hpp b/pv/mainwindow.hpp index 9a000c2..485b7b6 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,9 +59,21 @@ 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); + ~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); + private: void setup_ui(); @@ -65,70 +81,35 @@ 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); + virtual QMenu* createPopupMenu(); - void on_actionOpen_triggered(); - void on_actionSaveAs_triggered(); - void on_actionQuit_triggered(); + virtual bool restoreState(const QByteArray &state, int version = 0); - void on_actionConnect_triggered(); - - void on_actionViewZoomIn_triggered(); - - void on_actionViewZoomOut_triggered(); - - void on_actionViewZoomFit_triggered(); - - void on_actionViewZoomOneToOne_triggered(); +private Q_SLOTS: + void on_actionViewStickyScrolling_triggered(); - void on_actionViewShowCursors_triggered(); + void on_actionViewColouredBg_triggered(); void on_actionAbout_triggered(); - void add_decoder(srd_decoder *decoder); - - void run_stop(); - - void capture_state_changed(int state); - 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_; - SigSession session_; + Session session_; - pv::view::View *view_; + std::map< std::shared_ptr, + std::shared_ptr > view_docks_; - QWidget *central_widget_; - QVBoxLayout *vertical_layout_; + std::string open_file_name_, open_file_format_; - 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