X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fmainwindow.hpp;h=208cbe4367e163062b59fb8fc05e6e3695da219a;hp=8aab988b26c2fc2ce7f6bc87bdb7450d210efcb7;hb=da50281d69f15d125b56971a3009fd31cbbab58b;hpb=696546819ac7b120ac2f8a8b004e62a1f213cbae diff --git a/pv/mainwindow.hpp b/pv/mainwindow.hpp index 8aab988b..208cbe43 100644 --- a/pv/mainwindow.hpp +++ b/pv/mainwindow.hpp @@ -18,12 +18,15 @@ * 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 #include "session.hpp" @@ -33,7 +36,8 @@ struct srd_decoder; class QVBoxLayout; namespace sigrok { -class Device; +class InputFormat; +class OutputFormat; } namespace pv { @@ -50,7 +54,9 @@ class View; } namespace widgets { +#ifdef ENABLE_DECODE class DecoderMenu; +#endif } class MainWindow : public QMainWindow @@ -72,27 +78,45 @@ private: 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); QAction* action_open() const; QAction* action_save_as() const; + QAction* action_save_selection_as() const; QAction* action_connect() const; QAction* action_quit() const; QAction* action_view_zoom_in() const; QAction* action_view_zoom_out() const; 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; +#ifdef ENABLE_DECODE + QMenu* menu_decoder_add() const; +#endif + void run_stop(); - void select_device(std::shared_ptr device); + void select_device(std::shared_ptr device); + +public Q_SLOTS: + void export_file(std::shared_ptr format, + bool selection_only = false); + void import_file(std::shared_ptr format); private: void setup_ui(); + void select_init_device(); + + void load_init_file(const std::string &file_name, + const std::string &format); + void save_ui_settings(); void restore_ui_settings(); @@ -100,20 +124,29 @@ private: void session_error(const QString text, const QString info_text); /** - * Updates the device list in the sampling bar + * Updates the device list in the toolbar */ - void update_device_list(); + void update_device_list(); + + void load_file(QString file_name, + std::shared_ptr format = nullptr, + const std::map &options = + std::map()); + void save_selection_to_file(); + +private: void closeEvent(QCloseEvent *event); -private Q_SLOTS: - void load_file(QString file_name); + void keyReleaseEvent(QKeyEvent *event); +private Q_SLOTS: void show_session_error( const QString text, const QString info_text); void on_actionOpen_triggered(); void on_actionSaveAs_triggered(); + void on_actionSaveSelectionAs_triggered(); void on_actionQuit_triggered(); void on_actionConnect_triggered(); @@ -126,6 +159,10 @@ private Q_SLOTS: void on_actionViewZoomOneToOne_triggered(); + void on_actionViewStickyScrolling_triggered(); + + void on_actionViewColouredBg_triggered(); + void on_actionViewShowCursors_triggered(); void on_actionAbout_triggered(); @@ -135,6 +172,10 @@ private Q_SLOTS: void capture_state_changed(int state); void device_selected(); + void sticky_scrolling_changed(bool state); + + void always_zoom_to_fit_changed(bool state); + private: DeviceManager &device_manager_; @@ -149,16 +190,23 @@ private: QAction *const action_open_; QAction *const action_save_as_; + QAction *const action_save_selection_as_; QAction *const action_connect_; QAction *const action_quit_; QAction *const action_view_zoom_in_; QAction *const action_view_zoom_out_; 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_; + +#ifdef ENABLE_DECODE + QMenu *const menu_decoders_add_; +#endif }; } // namespace pv -#endif // PULSEVIEW_PV_MAINWINDOW_H +#endif // PULSEVIEW_PV_MAINWINDOW_HPP