X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fgui%2Fqt4%2Fcomponents%2Fpreferences_widgets.hpp;h=d9fa03c3bd3ce0635aaa1c1258bb82b4850370c0;hb=b3da319e29b52d3849d0c3c33d1156a3e532fa67;hp=4bb91ec6f60e3866ccab44130d1a38c89247b66d;hpb=bad8f53f2b734cdc78f18bef8be1dc1589e5db4c;p=vlc diff --git a/modules/gui/qt4/components/preferences_widgets.hpp b/modules/gui/qt4/components/preferences_widgets.hpp index 4bb91ec6f6..d9fa03c3bd 100644 --- a/modules/gui/qt4/components/preferences_widgets.hpp +++ b/modules/gui/qt4/components/preferences_widgets.hpp @@ -23,10 +23,14 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ -#ifndef _INFOPANELS_H_ -#define _INFOPANELS_H_ +#ifndef _PREFERENCESWIDGETS_H_ +#define _PREFERENCESWIDGETS_H_ -#include +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include #include "qt4.hpp" #include @@ -45,11 +49,12 @@ #include -class QFile; class QTreeWidget; class QTreeWidgetItem; class QGroupBox; class QGridLayout; +class QDialogButtonBox; +class QVBoxLayout; class ConfigControl : public QObject { @@ -85,8 +90,11 @@ protected: QString _name; QWidget *widget; bool _advanced; +#if 0 +/* You shouldn't use that now..*/ signals: void Updated(); +#endif }; /******************************************************* @@ -102,7 +110,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 @@ -117,8 +125,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; @@ -154,6 +162,7 @@ private: class IntegerListConfigControl : public VIntConfigControl { +Q_OBJECT public: IntegerListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -161,12 +170,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 @@ -180,6 +192,7 @@ public: virtual int getValue(); virtual void show() { checkbox->show(); } virtual void hide() { checkbox->hide(); } + virtual int getType() { return CONFIG_ITEM_BOOL; } private: QCheckBox *checkbox; void finish(); @@ -198,7 +211,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 @@ -211,8 +224,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; @@ -247,7 +260,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 @@ -260,8 +273,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; @@ -278,8 +291,8 @@ public: QLineEdit *, QPushButton *, bool pwd ); 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: @@ -302,6 +315,7 @@ public slots: virtual void updateField(); }; +#if 0 class FontConfigControl : public FileConfigControl { Q_OBJECT; @@ -314,6 +328,7 @@ public: public slots: virtual void updateField(); }; +#endif class ModuleConfigControl : public VStringConfigControl { @@ -324,8 +339,8 @@ 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; @@ -340,6 +355,7 @@ struct checkBoxListItem { class ModuleListConfigControl : public VStringConfigControl { Q_OBJECT; + friend class ConfigControl; public: ModuleListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -360,6 +376,7 @@ private: class StringListConfigControl : public VStringConfigControl { + Q_OBJECT; public: StringListConfigControl( vlc_object_t *, module_config_t *, QWidget *, bool, QGridLayout*, int& ); @@ -367,13 +384,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, QWidget *parent = 0 ); + #if 0 struct ModuleCheckBox { QCheckBox *checkbox; @@ -398,20 +422,19 @@ 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; } +public slots: + virtual void clear(void) { value = 0; QLineEdit::clear(); } private: - void checkForConflicts( int i_vlckey ); - void keyPressEvent( QKeyEvent *); - void wheelEvent( QWheelEvent *); - QLabel *selected; - QLabel *warning; - const char * keyToChange; - QList values; + int value; + virtual void mousePressEvent( QMouseEvent *event ); +signals: + void pressed(); }; class KeySelectorControl : public ConfigControl @@ -420,18 +443,36 @@ class KeySelectorControl : public ConfigControl 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; private slots: - void selectKey( QTreeWidgetItem *); + void setTheKey(); + void selectKey( QTreeWidgetItem * = NULL ); + void select1Key(); }; +class KeyInputDialog : public QDialog +{ +public: + KeyInputDialog( QTreeWidget *, QString, QWidget * ); + int keyValue; + bool conflicts; +private: + QTreeWidget *table; + void checkForConflicts( int i_vlckey ); + void keyPressEvent( QKeyEvent *); + void wheelEvent( QWheelEvent *); + QLabel *selected; + QVBoxLayout *vLayout; + QDialogButtonBox *buttonBox; +}; #endif