X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=pv%2Fmainwindow.hpp;h=e86dd183bbee32192a6511b58bf29441c585be9c;hb=cef5997ee1e08d713663d2ae02c839a315f41409;hp=1779712f4c93aa9edc5b2182930454021f5099a1;hpb=da30ecb7e72bd2547e524258efa5ec642988b70b;p=pulseview.git diff --git a/pv/mainwindow.hpp b/pv/mainwindow.hpp index 1779712f..e86dd183 100644 --- a/pv/mainwindow.hpp +++ b/pv/mainwindow.hpp @@ -22,8 +22,11 @@ #define PULSEVIEW_PV_MAINWINDOW_HPP #include +#include #include +#include + #include #include "session.hpp" @@ -33,6 +36,7 @@ struct srd_decoder; class QVBoxLayout; namespace sigrok { +class InputFormat; class OutputFormat; } @@ -74,7 +78,8 @@ 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; @@ -85,6 +90,7 @@ public: 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_show_cursors() const; QAction* action_about() const; @@ -98,10 +104,16 @@ public: public Q_SLOTS: void export_file(std::shared_ptr format); + 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(); @@ -113,14 +125,17 @@ private: */ void update_device_list(); + void load_file(QString file_name, + std::shared_ptr format = nullptr, + const std::map &options = + std::map()); + private: void closeEvent(QCloseEvent *event); void keyReleaseEvent(QKeyEvent *event); private Q_SLOTS: - void load_file(QString file_name); - void show_session_error( const QString text, const QString info_text); @@ -138,6 +153,8 @@ private Q_SLOTS: void on_actionViewZoomOneToOne_triggered(); + void on_actionViewStickyScrolling_triggered(); + void on_actionViewShowCursors_triggered(); void on_actionAbout_triggered(); @@ -147,6 +164,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_; @@ -167,6 +188,7 @@ private: 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_show_cursors_; QAction *const action_about_;