X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fgui%2Fqt4%2Fcomponents%2Fpreferences_widgets.hpp;h=e007c45ea69c00578e1da01fef010fef7a8d4962;hb=4c4aae84c4b516592ab42c8c08242c400a107e90;hp=56a455f2f1367504dbabbab76fe30faef4a11704;hpb=712f983f22d2880e2fe8f1af101d8b314b87c26b;p=vlc diff --git a/modules/gui/qt4/components/preferences_widgets.hpp b/modules/gui/qt4/components/preferences_widgets.hpp index 56a455f2f1..e007c45ea6 100644 --- a/modules/gui/qt4/components/preferences_widgets.hpp +++ b/modules/gui/qt4/components/preferences_widgets.hpp @@ -23,27 +23,52 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ -#ifndef _INFOPANELS_H_ -#define _INFOPANELS_H_ -#include +#ifndef _PREFERENCESWIDGETS_H_ +#define _PREFERENCESWIDGETS_H_ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include "qt4.hpp" +#include + #include -#include + +#include +#include #include +#include #include +#include #include -#include -#include +#include #include #include -#include -#include -#include -#include - -#include "qt4.hpp" -#include +class QTreeWidget; +class QTreeWidgetItem; +class QGroupBox; class QGridLayout; +class QDialogButtonBox; +class QVBoxLayout; + +/******************************************************* + * Simple widgets + *******************************************************/ + +class InterfacePreviewWidget : public QLabel +{ + Q_OBJECT +public: + InterfacePreviewWidget( QWidget * ); +public slots: + void setPreview( int ); +}; + +/******************************************************* + * Variable controls + *******************************************************/ class ConfigControl : public QObject { @@ -79,8 +104,11 @@ protected: QString _name; QWidget *widget; bool _advanced; +#if 0 +/* You shouldn't use that now..*/ signals: void Updated(); +#endif }; /******************************************************* @@ -96,7 +124,7 @@ public: ConfigControl(a,b) {}; virtual ~VIntConfigControl() {}; virtual int getValue() = 0; - virtual int getType() { return 1; } + virtual int getType() { return CONFIG_ITEM_INTEGER; } }; class IntegerConfigControl : public VIntConfigControl @@ -111,8 +139,8 @@ public: QLabel*, QSlider* ); virtual ~IntegerConfigControl() {}; virtual int getValue(); - virtual void show() { spin->show(); label->show(); } - virtual void hide() { spin->hide(); label->hide(); } + virtual void show() { spin->show(); if( label ) label->show(); } + virtual void hide() { spin->hide(); if( label ) label->hide(); } protected: QSpinBox *spin; @@ -148,6 +176,7 @@ private: class IntegerListConfigControl : public VIntConfigControl { +Q_OBJECT public: IntegerListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -155,12 +184,15 @@ public: QComboBox*, bool ); virtual ~IntegerListConfigControl() {}; virtual int getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } private: - void finish( bool ); + void finish(module_config_t *, bool ); QLabel *label; QComboBox *combo; +private slots: + void actionRequested( int ); + }; class BoolConfigControl : public VIntConfigControl @@ -169,13 +201,14 @@ public: BoolConfigControl( vlc_object_t *, module_config_t *, QWidget *, QGridLayout *, int& ); BoolConfigControl( vlc_object_t *, module_config_t *, - QLabel *, QCheckBox*, bool ); + QLabel *, QAbstractButton*, bool ); virtual ~BoolConfigControl() {}; virtual int getValue(); virtual void show() { checkbox->show(); } virtual void hide() { checkbox->hide(); } -private: - QCheckBox *checkbox; + virtual int getType() { return CONFIG_ITEM_BOOL; } +private: + QAbstractButton *checkbox; void finish(); }; @@ -192,7 +225,7 @@ public: ConfigControl(a,b) {}; virtual ~VFloatConfigControl() {}; virtual float getValue() = 0; - virtual int getType() { return 2; } + virtual int getType() { return CONFIG_ITEM_FLOAT; } }; class FloatConfigControl : public VFloatConfigControl @@ -205,8 +238,8 @@ public: QLabel*, QDoubleSpinBox* ); virtual ~FloatConfigControl() {}; virtual float getValue(); - virtual void show() { spin->show(); label->show(); } - virtual void hide() { spin->hide(); label->hide(); } + virtual void show() { spin->show(); if( label ) label->show(); } + virtual void hide() { spin->hide(); if( label ) label->hide(); } protected: QDoubleSpinBox *spin; @@ -241,7 +274,7 @@ public: ConfigControl(a,b) {}; virtual ~VStringConfigControl() {}; virtual QString getValue() = 0; - virtual int getType() { return 3; } + virtual int getType() { return CONFIG_ITEM_STRING; } }; class StringConfigControl : public VStringConfigControl @@ -254,8 +287,8 @@ public: QLineEdit*, bool pwd ); virtual ~StringConfigControl() {}; virtual QString getValue() { return text->text(); }; - virtual void show() { text->show(); label->show(); } - virtual void hide() { text->hide(); label->hide(); } + virtual void show() { text->show(); if( label ) label->show(); } + virtual void hide() { text->hide(); if( label ) label->hide(); } private: void finish(); QLineEdit *text; @@ -267,13 +300,13 @@ class FileConfigControl : public VStringConfigControl Q_OBJECT; public: FileConfigControl( vlc_object_t *, module_config_t *, QWidget *, - QGridLayout *, int&, bool pwd ); + QGridLayout *, int& ); FileConfigControl( vlc_object_t *, module_config_t *, QLabel *, - QLineEdit *, QPushButton *, bool pwd ); + QLineEdit *, QPushButton * ); virtual ~FileConfigControl() {}; virtual QString getValue() { return text->text(); }; - virtual void show() { text->show(); label->show(); browse->show(); } - virtual void hide() { text->hide(); label->hide(); browse->hide(); } + virtual void show() { text->show(); if( label ) label->show(); browse->show(); } + virtual void hide() { text->hide(); if( label ) label->hide(); browse->hide(); } public slots: virtual void updateField(); protected: @@ -288,14 +321,15 @@ class DirectoryConfigControl : public FileConfigControl Q_OBJECT; public: DirectoryConfigControl( vlc_object_t *, module_config_t *, QWidget *, - QGridLayout *, int&, bool pwd ); + QGridLayout *, int& ); DirectoryConfigControl( vlc_object_t *, module_config_t *, QLabel *, - QLineEdit *, QPushButton *, bool pwd ); + QLineEdit *, QPushButton * ); virtual ~DirectoryConfigControl() {}; public slots: virtual void updateField(); }; +#if 0 class FontConfigControl : public FileConfigControl { Q_OBJECT; @@ -308,6 +342,7 @@ public: public slots: virtual void updateField(); }; +#endif class ModuleConfigControl : public VStringConfigControl { @@ -318,17 +353,23 @@ public: QComboBox*, bool ); virtual ~ModuleConfigControl() {}; virtual QString getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } private: void finish( bool ); QLabel *label; QComboBox *combo; }; +struct checkBoxListItem { + QCheckBox *checkBox; + char *psz_module; +}; + class ModuleListConfigControl : public VStringConfigControl { Q_OBJECT; + friend class ConfigControl; public: ModuleListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -339,16 +380,17 @@ public: virtual void hide(); virtual void show(); public slots: - void wakeUp_TheUserJustClickedOnSomething( int value ); + void onUpdate(); private: void finish( bool ); - QVector modules; + QVector modules; QGroupBox *groupBox; QLineEdit *text; }; class StringListConfigControl : public VStringConfigControl { + Q_OBJECT; public: StringListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -356,13 +398,20 @@ public: QComboBox*, bool ); virtual ~StringListConfigControl() {}; virtual QString getValue(); - virtual void hide() { combo->hide(); label->hide(); } - virtual void show() { combo->show(); label->show(); } + virtual void hide() { combo->hide(); if( label ) label->hide(); } + virtual void show() { combo->show(); if( label ) label->show(); } + QComboBox *combo; private: - void finish( bool ); + void finish(module_config_t *, bool ); QLabel *label; - QComboBox *combo; +private slots: + void actionRequested( int ); + }; + +void setfillVLCConfigCombo(const char *configname, intf_thread_t *p_intf, + QComboBox *combo ); + #if 0 struct ModuleCheckBox { QCheckBox *checkbox; @@ -387,40 +436,65 @@ private slot: /********************************************************************** * Key selector widget **********************************************************************/ -class KeyInputDialog : public QDialog +class KeyShortcutEdit: public QLineEdit { + Q_OBJECT; public: - KeyInputDialog( QList &, const char * ); - int keyValue; - bool conflicts; + void setValue( int _value ){ value = _value; } + int getValue() const { return value; } + + void setGlobal( bool _value ) { b_global = _value; } + bool getGlobal() const { return b_global; } +public slots: + virtual void clear(void) { value = 0; QLineEdit::clear(); b_global = false;} private: - void checkForConflicts( int i_vlckey ); - void keyPressEvent( QKeyEvent *); - void wheelEvent( QWheelEvent *); - QLabel *selected; - QLabel *warning; - const char * keyToChange; - QList values; + int value; + bool b_global; + virtual void mousePressEvent( QMouseEvent *event ); +signals: + void pressed(); }; +class SearchLineEdit; class KeySelectorControl : public ConfigControl { Q_OBJECT; public: KeySelectorControl( vlc_object_t *, module_config_t *, QWidget *, QGridLayout*, int& ); - virtual int getType() { return 4; } + virtual int getType() { return CONFIG_ITEM_KEY; } virtual ~KeySelectorControl() {}; - virtual void hide() { table->hide(); label->hide(); } - virtual void show() { table->show(); label->show(); } + virtual void hide() { table->hide(); if( label ) label->hide(); } + virtual void show() { table->show(); if( label ) label->show(); } void doApply(); private: void finish(); QLabel *label; QTreeWidget *table; + KeyShortcutEdit *shortcutValue; QList values; + SearchLineEdit *actionSearch; private slots: - void selectKey( QTreeWidgetItem *); + void setTheKey(); + void selectKey( QTreeWidgetItem * = NULL, int column = 1 ); + void select1Key(); + void filter( const QString & ); }; +class KeyInputDialog : public QDialog +{ +public: + KeyInputDialog( QTreeWidget *, const QString&, QWidget *, bool b_global = false); + int keyValue; + bool conflicts; +private: + QTreeWidget *table; + void checkForConflicts( int i_vlckey ); + void keyPressEvent( QKeyEvent *); + void wheelEvent( QWheelEvent *); + QLabel *selected, *warning; + QVBoxLayout *vLayout; + QDialogButtonBox *buttonBox; + bool b_global; +}; #endif