X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fdialogs%2Fsettings.hpp;h=ca8291def8c7b2f496088b335d15f4025942e691;hp=20c4f91552b184d004ed61642f8d96e13b950c04;hb=48051ccba42d9205959658d6165546334878ad17;hpb=bf9f12687c8d43422455cbdc27ec1cc5d4305149 diff --git a/pv/dialogs/settings.hpp b/pv/dialogs/settings.hpp index 20c4f915..ca8291de 100644 --- a/pv/dialogs/settings.hpp +++ b/pv/dialogs/settings.hpp @@ -20,9 +20,15 @@ #ifndef PULSEVIEW_PV_SETTINGS_HPP #define PULSEVIEW_PV_SETTINGS_HPP +#include #include +#include +#include namespace pv { + +class DeviceManager; + namespace dialogs { class Settings : public QDialog @@ -30,16 +36,34 @@ class Settings : public QDialog Q_OBJECT public: - Settings(QWidget *parent = 0); + Settings(DeviceManager &device_manager, QWidget *parent = nullptr); + + void create_pages(); + QCheckBox *create_checkbox(const QString& key, const char* slot) const; QWidget *get_view_settings_form(QWidget *parent) const; + QWidget *get_decoder_settings_form(QWidget *parent) const; + QWidget *get_about_page(QWidget *parent) const; void accept(); void reject(); private Q_SLOTS: - void on_view_alwaysZoomToFit_changed(int state); + void on_page_changed(QListWidgetItem *current, QListWidgetItem *previous); + void on_view_zoomToFitDuringAcq_changed(int state); + void on_view_zoomToFitAfterAcq_changed(int state); void on_view_colouredBG_changed(int state); + void on_view_stickyScrolling_changed(int state); + void on_view_showSamplingPoints_changed(int state); + void on_view_showAnalogMinorGrid_changed(int state); + void on_view_defaultDivHeight_changed(int value); + void on_view_defaultLogicHeight_changed(int value); + void on_dec_initialStateConfigurable_changed(int state); + +private: + DeviceManager &device_manager_; + QListWidget *page_list; + QStackedWidget *pages; }; } // namespace dialogs